码迷,mamicode.com
首页 > 系统相关 > 详细

使用正则表达式判断字符串是否为MAC地址

时间:2015-07-17 09:55:56      阅读:223      评论:0      收藏:0      [点我收藏+]

标签:android   算法   java   正则表达式   mac地址   

      今天Boss给了一个小任务,要求给定一个字符串,判断该字符串是否是MAC地址,并用Java和正则表达式实现。于是我顺便百度了下MAC地址,并在cmd下使用getmac获取本机的MAC地址,了解了一点后,就用Java实现了。为了方便测试与输入输出,选择使用Android作为UI交互。反正都是用Java,对于这个问题,一个Java项目和Android区别不大。

       首先看一个MAC地址:48-5D-60-61-3D-C5。其中由6个字节(十六进制)组成,简单理解为数字、大小写字母(a-fA-F)、短横线-组成。废话不说,先写MAC的正则表达式,我总共写了3个正则表达式,是不断优化的结果。

正则表达式:

(1)"[A-Fa-f0-9][A-Fa-f0-9]-[A-Fa-f0-9][A-Fa-f0-9]-[A-Fa-f0-9][A-Fa-f0-9]-[A-Fa-f0-9][A-Fa-f0-9]-[A-Fa-f0-9][A-Fa-f0-9]-[A-Fa-f0-9][A-Fa-f0-9]"

这个表达式虽然看起来长,但是是逻辑最简单的,最容易理解的,也是完全正确的。A-F  a-f   0-9都表示其中的某一个,中间是“或”的关系。短横线-可以直接进行匹配。


(2)"[A-Fa-f0-9]{2}-[A-Fa-f0-9]{2}-[A-Fa-f0-9]{2}-[A-Fa-f0-9]{2}-[A-Fa-f0-9]{2}-[A-Fa-f0-9]{2}"

进行优化后,长度剪短了一半。{2}就是把前面的部分循环2次。在第一种方法的基础上,这也是容易理解的。


(3)"([A-Fa-f0-9]{2}-){5}[A-Fa-f0-9]{2}"

在(2)的基础上继续进行优化。把“[A-Fa-f0-9]{2}-“作为一个单元进行提取。{5}并循环5次,因为面·前面5个都是重复的,有很大压缩的空间。


      代码编写较为简单,在Android上进行可视化编写:

public class MainActivity extends Activity {

	private EditText isMAC;
	private Button startMAC;
	private TextView result;

	private static String judgeMacAddress;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		isMAC = (EditText) findViewById(R.id.id_edit);
		startMAC = (Button) findViewById(R.id.id_btn);
		result = (TextView) findViewById(R.id.id_text);

		startMAC.setOnClickListener(new OnClickListener() {

			@Override
			public void onClick(View v) {
				judgeMacAddress = isMAC.getText().toString();
				boolean isMAC = stringIsMac(judgeMacAddress);

				if (isMAC) {
					result.setText("这是MAC地址");
				} else {

					result.setText("这不是MAC地址");
				}
			}
		});
	}

	private boolean stringIsMac(String val) {
		String trueMacAddress = "([A-Fa-f0-9]{2}-){5}[A-Fa-f0-9]{2}";
		// 这是真正的MAV地址;正则表达式;
		if (val.matches(trueMacAddress)) {
			return true;
		} else {
			return false;
		}
	}
}

(1)(2)(3)最后的实现效果如下:

技术分享


技术分享


技术分享


技术分享


技术分享.


       至此,已经对MAC地址进行了判断。可能最后的那种正则表达式还有优化的方法,请大家给予批评与建议。

版权声明:本文为博主原创文章,未经博主允许不得转载。

使用正则表达式判断字符串是否为MAC地址

标签:android   算法   java   正则表达式   mac地址   

原文地址:http://blog.csdn.net/chenyufeng1991/article/details/46919105

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!