Java編程實現(xiàn)遍歷兩個MAC地址之間所有MAC的方法
本文實例講述了Java編程實現(xiàn)遍歷兩個MAC地址之間所有MAC的方法。分享給大家供大家參考,具體如下:
在對發(fā)放的設(shè)備進行后臺管理時,很多時候會用到設(shè)備MAC這個字段,它可以標識唯一一個設(shè)備。然而在數(shù)據(jù)庫批量的存儲MAC地址時,如果使用解析文本逐行添加的方式,難免會顯得操作復(fù)雜,而且事先還需生成MAC地址文本。事實上MAC地址是按照十六進制逐一遞增的,所以只需要給出一個區(qū)間便有可能枚舉出所有MAC地址。以下是筆者封裝的一個通過兩個MAC地址枚舉區(qū)間內(nèi)所有MAC的函數(shù)。
/** 輸出兩個MAC區(qū)間內(nèi)的所有MAC地址 */
public static void countBetweenMac(String macStart, String macEnd){
long start = turnMacToLong(macStart);
long end = turnMacToLong(macEnd);
String prefix = macStart.substring(0,9);
String hex = null;
String suffix = null;
StringBuffer sb = null;
for(long i=start; i< end +1; i++){
hex = Long.toHexString(i);
suffix = hex.substring(hex.length()-6);
sb = new StringBuffer(suffix);
sb.insert(2, ":");
sb.insert(5, ":");
System.out.println(prefix + sb.toString());
}
}
/** 將MAC轉(zhuǎn)換成數(shù)字 */
public static long turnMacToLong(String MAC){
String hex = MAC.replaceAll("\\:", "");
long longMac = Long.parseLong(hex, 16);
return longMac;
}
另附計算兩個MAC之間MAC中個數(shù)函數(shù):
/** 計算區(qū)間內(nèi)MAC總數(shù) */
public static long countMac1(String macStart, String macEnd){
String hexStart = macStart.replaceAll("\\:", "");
String hexEnd = macEnd.replaceAll("\\:", "");
long start = Long.parseLong(hexStart, 16);
long end = Long.parseLong(hexEnd, 16);
return end-start+1;
}
/** 計算區(qū)間內(nèi)MAC總數(shù) */
public static long countMac(String macStart, String macEnd){
String[] start = macStart.split("\\:");
String[] end = macEnd.split("\\:");
int x,y,z;
int a,b,c;
x = Integer.parseInt(start[3],16);
y = Integer.parseInt(start[4],16);
z = Integer.parseInt(start[5],16);
a = Integer.parseInt(end[3],16);
b = Integer.parseInt(end[4],16);
c = Integer.parseInt(end[5],16);
return (a-x)*16*16*16 + (b-y)*16*16 + c-z+1;
}
希望本文所述對大家Java程序設(shè)計有所幫助。
相關(guān)文章
eclipse/intellij idea 遠程調(diào)試hadoop 2.6.0
這篇文章主要介紹了eclipse/intellij idea 遠程調(diào)試hadoop 2.6.0的相關(guān)資料,需要的朋友可以參考下2016-07-07
mybatis的mapper特殊字符轉(zhuǎn)移及動態(tài)SQL條件查詢小結(jié)
mybatis mapper文件中條件查詢符,如>=,<,之類是不能直接寫的會報錯的需要轉(zhuǎn)移一下,本文給大家介紹了常見的條件查詢操作,對mybatis的mapper特殊字符及動態(tài)SQL條件查詢相關(guān)知識感興趣的朋友一起看看吧2021-09-09
Java調(diào)用接口如何獲取json數(shù)據(jù)解析后保存到數(shù)據(jù)庫
這篇文章主要介紹了Java調(diào)用接口如何獲取json數(shù)據(jù)解析后保存到數(shù)據(jù)庫問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03
JSON數(shù)據(jù)轉(zhuǎn)換成Java對象的方法
就目前來講,將Java對象轉(zhuǎn)換成JSON對象還是相當簡單的,但是 將JSON對象轉(zhuǎn)換成Java對象,就相對比較復(fù)雜了些2014-03-03

