Java学习心得(一)

JAVA学习笔记_1

  • 一.String是final修饰的类,不可变的,存放到常量池中
  • 二.当拼接的字符串有一个变量相加,然后赋值给一个新变量它会创建新的地址
  • 三.求字符串的字节数和字符数
  • 四.StringBuilder和StringBuffer的区别
  • 五.正则表达式
    • 1.概念
    • 2.特点
    • 3.常用的正则表达式
  • 六.课后作业
    • 一.输入一个字符串,判定是否是回文
    • 二.1-20个数字或者大写字母中文或者英文,首字母必须为英文,3到5个分别使用match,replace测试
    • 三.将"北京|上海|武汉|成都"用正则表达式分隔为数组

一.String是final修饰的类,不可变的,存放到常量池中

例:

	String s1="HelloWorld";
	String s2="HelloWorld";
	String s3=new String("HelloWorld");
	System.out.println(s2==s1);					//true
	System.out.println(s3==s1);					//false

1.==比较的是地址值
2.new对象创建新的地址,所以不相等;并且new对象也创建了一个字面量
3.如果要比较内容,String可以直接使用equals (注意:!!!String重写了父类的equals方法)

二.当拼接的字符串有一个变量相加,然后赋值给一个新变量它会创建新的地址

例:

	String s4=s1+s2;
	String s5=s1+"HelloWorld";
	String s6="a"+"b"+"c";
	System.out.println(s4==s5);					//false
	System.out.println(s4+","+s5+","+s6);

请问s6创建了几个对象? == 1个==

三.求字符串的字节数和字符数

1.求字符串的字节数,不管中文还是英文,都按照Unicode,字节数=字符个数*2
2.求字符串的长度,一般按照中文2个,英文1个(与编码有关) (常见的编码:ISO-8859-1 UTF-8 GBK/GB2312)

四.StringBuilder和StringBuffer的区别

1.StringBuilder线程不安全的,StringBuffer线程安全
2.两者的api基本一样,除了少数操作变长字符串的时候有无synchronized关键字
3.单线程建议使用StringBuilder,多线程如果要使用建议使用StrungBuffer或者自己做安全处理

五.正则表达式

1.概念

正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。

2.特点

  1. 灵活性,逻辑性和功能性非常强.
  2. 可以迅速地用极简单的方式达到字符串的复杂控制.
  3. 对于刚接触的人来说,比较晦涩难懂.

3.常用的正则表达式

一、校验数字的表达式

  1. 数字:^ [0-9]*$
  2. n位的数字:^\d{n}$
  3. 至少n位的数字:^\d{n,}$
  4. m-n位的数字:^\d{m,n}$
  5. 零和非零开头的数字:^(0|[1-9][0-9]*)$
  6. 非零开头的最多带两位小数的数字:^([1-9][0-9]*)+(.[0-9]{1,2})?$
  7. 带1-2位小数的正数或负数:^(-)?\d+(.\d{1,2})?$
  8. 正数、负数、和小数:^(-|+)?\d+(.\d+)?$
  9. 有两位小数的正实数:^ [0-9]+(.[0-9]{2})?$
  10. 有1~3位小数的正实数:^ [0-9]+(.[0-9]{1,3})?$
  11. 非零的正整数:^ [1-9]\d*$ 或 ^([1-9][0-9]){1,3}$ 或 ^+?[1-9][0-9]$
  12. 非零的负整数:^-[1-9][]0-9"$ 或 ^-[1-9]\d$
  13. 非负整数:^\d+$ 或 ^ [1-9]\d*|0$
  14. 非正整数:^-[1-9]\d*|0$ 或 ^((-\d+)|(0+))$
  15. 非负浮点数:^\d+(.\d+)?$ 或 ^ [1-9]\d*.\d*|0.\d*[1-9]\d*|0?.0+|0$
  16. 非正浮点数:^((-\d+(.\d+)?)|(0+(.0+)?))$ 或 ^(-([1-9]\d*.\d*|0.\d*[1-9]\d*))|0?.0+|0$
  17. 正浮点数:^ [1-9]\d*.\d*|0.\d*[1-9]\d*$ 或 ^(([0-9]+.[0-9][1-9][0-9])|([0-9][1-9][0-9].[0-9]+)|([0-9][1-9][0-9]))$
  18. 负浮点数:^-([1-9]\d*.\d*|0.\d*[1-9]\d*)$ 或 ^(-(([0-9]+.[0-9][1-9][0-9])|([0-9][1-9][0-9].[0-9]+)|([0-9][1-9][0-9])))$
  19. 浮点数:^(-?\d+)(.\d+)?$ 或 ^-?([1-9]\d*.\d*|0.\d*[1-9]\d*|0?.0+|0)$

二、校验字符的表达式
20. 汉字:^ [\u4e00-\u9fa5]{0,}$
21. 英文和数字:^ [A-Za-z0-9]+$ 或 ^ [A-Za-z0-9]{4,40}$
22. 长度为3-20的所有字符:^.{3,20}$
23. 由26个英文字母组成的字符串:^ [A-Za-z]+$
24. 由26个大写英文字母组成的字符串:^ [A-Z]+$
25. 由26个小写英文字母组成的字符串:^ [a-z]+$
26. 由数字和26个英文字母组成的字符串:^ [A-Za-z0-9]+$
27. 由数字、26个英文字母或者下划线组成的字符串:^\w+$ 或 ^\w{3,20}$
28. 中文、英文、数字包括下划线:^ [\u4E00-\u9FA5A-Za-z0-9_]+$
29. 中文、英文、数字但不包括下划线等符号:^ [\u4E00-\u9FA5A-Za-z0-9]+$ 或 ^ [\u4E00-\u9FA5A-Za-z0-9]{2,20}$
30. 可以输入含有^%&’,;=?KaTeX parse error: Can't use function '\"' in math mode at position 1: \̲"̲等字符:[^%&',;=?\x22]+
31. 禁止输入含有~的字符:[ ^ ~\x22]+

三、特殊需求表达式
32. Email地址:^\w+([-+.]\w+)@\w+([-.]\w+).\w+([-.]\w+)$
33. 域名:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?
34. InternetURL:[a-zA-z]+://[^\s]
或 ^http://([\w-]+.)+[\w-]+(/[\w-./?%&=])?$
35. 手机号码:^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$
36. 电话号码(“XXX-XXXXXXX”、“XXXX-XXXXXXXX”、“XXX-XXXXXXX”、“XXX-XXXXXXXX”、"XXXXXXX"和"XXXXXXXX):^((\d{3,4}-)|\d{3.4}-)?\d{7,8}$
37. 国内电话号码(0511-4405222、021-87888822):\d{3}-\d{8}|\d{4}-\d{7}
38. 身份证号(15位、18位数字):^\d{15}|\d{18}$
39. 短身份证号码(数字、字母x结尾):^([0-9]){7,18}(x|X)?$ 或 ^\d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$
40. 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^ [a-zA-Z][a-zA-Z0-9_]{4,15}$
41. 密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线):^ [a-zA-Z]\w{5,17}$
42. 强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间):^(?=.
\d)(?=.[a-z])(?=.[A-Z]).{8,10}$
43. 日期格式:^\d{4}-\d{1,2}-\d{1,2}
44. 一年的12个月(01~09和1~12):^(0?[1-9]|1[0-2])$
45. 一个月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$
46. 钱的输入格式:
47. 1.有四种钱的表示形式我们可以接受:“10000.00” 和 “10,000.00”, 和没有 “分” 的 “10000” 和 “10,000”:^ [1-9][0-9]$
48. 2.这表示任意一个不以0开头的数字,但是,这也意味着一个字符"0"不通过,所以我们采用下面的形式:^(0|[1-9][0-9]
)$
49. 3.一个0或者一个不以0开头的数字.我们还可以允许开头有一个负号:^(0|-?[1-9][0-9])$
50. 4.这表示一个0或者一个可能为负的开头不为0的数字.让用户以0开头好了.把负号的也去掉,因为钱总不能是负的吧.下面我们要加的是说明可能的小数部分:^ [0-9]+(.[0-9]+)?$
51. 5.必须说明的是,小数点后面至少应该有1位数,所以"10."是不通过的,但是 “10” 和 “10.2” 是通过的:^ [0-9]+(.[0-9]{2})?$
52. 6.这样我们规定小数点后面必须有两位,如果你认为太苛刻了,可以这样:^ [0-9]+(.[0-9]{1,2})?$
53. 7.这样就允许用户只写一位小数.下面我们该考虑数字中的逗号了,我们可以这样:^ [0-9]{1,3}(,[0-9]{3})
(.[0-9]{1,2})?$
54. 8.1到3个数字,后面跟着任意个 逗号+3个数字,逗号成为可选,而不是必须:^([0-9]+|[0-9]{1,3}(,[0-9]{3}))(.[0-9]{1,2})?$
55. 备注:这就是最终结果了,别忘了"+“可以用”
"替代如果你觉得空字符串也可以接受的话(奇怪,为什么?)最后,别忘了在用函数时去掉去掉那个反斜杠,一般的错误都在这里
56. xml文件:^([a-zA-Z]±?)+[a-zA-Z0-9]+\.[x|X][m|M][l|L]$
57. 中文字符的正则表达式:[\u4e00-\u9fa5]
58. 双字节字符:[ ^\x00-\xff] (包括汉字在内,可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1))
59. 空白行的正则表达式:\n\s*\r (可以用来删除空白行)
60. HTML标记的正则表达式:<(\S*?)[ ^ >]>.?|<.? /> (网上流传的版本太糟糕,上面这个也仅仅能部分,对于复杂的嵌套标记依旧无能为力)
61. 首尾空白字符的正则表达式:^\s
|\s*KaTeX parse error: Expected group after '^' at position 3: 或(^̲\s*)|(\s*) (可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式)
62. 腾讯QQ号:[1-9][0-9]{4,} (腾讯QQ号从10000开始)
63. 中国邮政编码:[1-9]\d{5}(?!\d) (中国邮政编码为6位数字)
64. IP地址:\d+.\d+.\d+.\d+ (提取IP地址时有用)
65. IP地址:((?: (?:25[0-5]|2[0-4]\d|[01]?\d?\d)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d?\d))

六.课后作业

一.输入一个字符串,判定是否是回文

	Scanner sc=new Scanner(System.in);
	System.out.print("请输入字符串:");
	String s=sc.nextLine();
	StringBuffer s1=new StringBuffer(s);
	StringBuffer s2=new StringBuffer(s1.reverse().toString());
	if(s2.toString().equals(s)) {
		System.out.println("是回文");
	}else {
		System.out.println("不是回文");
	}

二.1-20个数字或者大写字母中文或者英文,首字母必须为英文,3到5个分别使用match,replace测试

  		String regex1="[a-zA-Z]{3}[0-9a-zA-Z\\u4e00-\\u9fa5]{17}";
		String regex2="[a-zA-Z]{4}[0-9a-zA-Z\\u4e00-\\u9fa5]{16}";
		String regex3="[a-zA-Z]{5}[0-9a-zA-Z\\u4e00-\\u9fa5]{15}";
		String s="Cts1234567890zxcvbnm";
		boolean b1=s.matches(regex1);
		boolean b2=s.matches(regex2);
		boolean b3=s.matches(regex3);
		System.out.println(b1||b2||b3);
		
		String s1=s.substring(0, 3);
		String s2=s.substring(3);
		String s11=s1.replaceAll("[a-zA-Z]","*");
		String s12=s2.replaceAll("[0-9a-zA-Z\\u4e00-\\u9fa5]", "*");
		String s3=s.substring(0, 4);
		String s4=s.substring(4);
		String s23=s3.replaceAll("[a-zA-Z]","*");
		String s24=s4.replaceAll("[0-9a-zA-Z\\u4e00-\\u9fa5]", "*");
		String s5=s.substring(0, 5);
		String s6=s.substring(5);
		String s35=s5.replaceAll("[a-zA-Z]","*");
		String s36=s6.replaceAll("[0-9a-zA-Z\\u4e00-\\u9fa5]", "*");
		System.out.println((s11+s12).equals("********************")||(s23+s24).equals("********************")||(s35+s36).equals("********************"));

三.将"北京|上海|武汉|成都"用正则表达式分隔为数组

		String regex="\\|";		   				
		String s="北京|上海|武汉|成都";
		String s1[]=s.split(regex);
		System.out.println(Arrays.toString(s1));

你可能感兴趣的:(Java笔记)