当前位置: 首页 > news >正文

Java编程实现遍历两个MAC地址之间所有MAC的方法

Java编程实现遍历两个MAC地址之间所有MAC的方法

本文实例讲述了java编程实现遍历两个MAC地址之间所有MAC的方法。分享给大家供大http://家参考,具体如下:

在对发放的设备进行后台管理时,很多时候会用到设备MAC这个字段,它可以标识唯一一个设备。然而在数据库批量的存储MAC地址时,如果使用解析文本逐行添加的方式,难免会显得操作复杂,而且事先还需生成MAC地址文本。事实上MAC地址是按照十六进制逐一递增的,所以只需要给出一个区间便有可能枚举出所有MAC地址。以下是笔者封装的一个通过两个MAC地址枚举区间内所有MAC的函数。

/** 输出两个MAC区间内的所有MAC地址 */

public static void countBetweenMac(String macSSpyhDbNtart, 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转换成数字 */

public static long turnMacToLong(String MAC){

String hex = MAC.replaceAll("\\:", "");

long longMac = Long.parseLong(hex, 16);

return longMac;}

另附计算两个MAC之间MAC中个数函数:

/** 计算区间内MAC总数 */

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;}

/** 计算区间内MAC总数 */

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程序设计有所帮助。

http://www.lryc.cn/news/95925.html

相关文章:

  • 用AXIS2发布WebService的方法
  • 嵌入式学习_Day 003
  • 常用的数据结构 JAVA
  • 基于机器视觉工具箱和形态学处理的视频中目标形状检测算法matlab仿真
  • 小白入门:sentence-transformer 提取embedding模型转onnx
  • 数据库应用:Redis持久化
  • js版计算比亚迪行驶里程连续12个月计算不超3万公里改进版带echar
  • 一文详解Spring Bean循环依赖
  • 基于PHP+ vue2 + element +mysql自主研发的医院不良事件上报系统
  • 微服务远程调用openFeign简单回顾(内附源码示例)
  • 【云计算小知识】云环境是什么意思?有什么优点?
  • 【搜索引擎Solr】Apache Solr 神经搜索
  • PostgreSQL 设置时区,时间/日期函数汇总
  • 性能测试Ⅱ(压力测试与负载测试详解)
  • 【Python入门系列】第十八篇:Python自然语言处理和文本挖掘
  • 【GD32F103】自定义程序库08-DMA+ADC
  • 集成了Eureka的应用启动失败,端口号变为8080
  • CMU 15-445 -- Timestamp Ordering Concurrency Control - 15
  • MURF2080CT/MURF2080CTR-ASEMI快恢复对管
  • 去除 idea warn Raw use of parameterized class ‘Map‘
  • 使用BERT分类的可解释性探索
  • web APIs-练习二
  • rpc通信原理浅析
  • 【机器学习】分类算法 - KNN算法(K-近邻算法)KNeighborsClassifier
  • Spring Security 6.x 系列【64】扩展篇之多线程支持
  • Elasticsearch 简单搜索查询案例
  • 【RabbitMQ(day1)】RabbitMQ的概述和安装
  • Too many files with unapproved license: 2 See RAT report
  • Windows11的VTK安装:VS201x+Qt5/Qt6 +VTK7.1/VTK9.2.6
  • 大数据时代个人信息安全保护小贴士