有时需要记录ipv4地址到数据库,直接保存字符varchar(15)可能有些浪费,如果直接保存一个整数的话性价比会更好一些,ipv4有4段,每段取值范围都是0~255,使用1个字节就可以保存,如果转换为一个整数4个字节就可以搞定,注意mysql需使用无符号int。

注意在java中Integer是有符号的,最大值为2147483647,所以需要Long来盛放转换后的整数;位移运算优先级低于加法运算,位移处加了括号:

public static Long getIpNum(final String ip) {
   Long ipNum = 0L;
   final String[] ipStr = ip.trim().split("\\.");
   for (final String str : ipStr) {
       ipNum = (ipNum << 8) + Integer.parseInt(str);
   }
   return ipNum;
}
同时mysql也提供了相关函数,可以方便进行转换:
select INET_ATON('255.255.255.255');-- 4294967295
select INET_NTOA(4294967295);-- 255.255.255.255

本文代码出发点是考虑包括两个极端的情况,即0.0.0.0~255.255.255.255,所以代码中使用Long类型,Long类型占用8字节,而数据库支持无符号整型,4字节就可以保存。由整数转为ipv4地址可以直接使用mysql的函数,也可以在代码中使用右移操作取出每个字节所代表的的整数,然后拼接"."。


©著作权归作者所有:来自51CTO博客作者mb5fdb0a4002420的原创作品,如需转载,请注明出处,否则将追究法律责任

更多相关文章

  1. Java与php的一些关联
  2. 还不明白可空类型原理? 我可要挖到底了
  3. 字节三面:详解一条 SQL 的执行过程
  4. 自定义类型的认识
  5. 不重启JVM,替换掉已经加载的类,偷天换日?
  6. 学C语言之路
  7. 2021-02-16:n皇后问题。给定一个整数n,返回n皇后的摆法有多少种?
  8. 只有1个字节的文件实际占用多少磁盘空间
  9. PHP7内存性能优化的思想精髓

随机推荐

  1. Linux系统下安装android sdk的方法步骤
  2. 各自为战不如抱团取暖 WP成立开发者联盟
  3. Android 之 Socket 通信
  4. Android蓝牙默认名称的修改
  5. 利用一个singleInstance的activity实现音
  6. Android在SDcard建文件夹(在Android中移动
  7. android 适配器Adpter的使用总结 之 Curs
  8. Android获取设备型号和系统版本号、mac地
  9. 鸿洋大神博文Android(安卓)自定义View (
  10. 4.AutoCompleteTextView