`

SCJP笔记整理(六)续

阅读更多

说明:这是2007年复习SCJP期间的学习笔记(JavaSE 5.0),有部分遗失。现在整理一下发到Blog上,一方面做个备份,另一方面分享出来,希望对需要的人有用。

-----------------------------------

第六部分 续

21、提供正则表达式能力的每种语言都使用了一个或多个正则表达式引擎。正则表达式引擎使用编码进表达式中的指令来查找文本数据。

   正则表达式查找的执行顺序是从左到右,一旦在一个匹配中使用了源的字符,就不能再使用它。

   元字符:\d 数字。

           \s 空白字。

           \w 字字符(字母、数字或下划线)。

   [a-fA-F]:查找包括大小写的AF

           + :表示一个或多个的量词。如:0[xX]([0-9a-fA-F])+

           * 0或多个量词。

           ?:01个量词。

           ^ :查找不包含该范围的字符。

           .  : 点元字符,该处可以使用任意字符。

22、贪婪匹配量词:

?是贪婪,??是勉强。

* 是贪婪,* ?是勉强。

+ 是贪婪,+ ?是勉强。

 

源:yyxxxyxx

  模式:.*xx  (*是贪婪)

  匹配:0 yyxxxyxx(贪婪匹配结果)

 

  模式:.*?xx  * ?是勉强)

  匹配:0 yyxx  (勉强匹配结果)

        4 xyxx 

贪婪匹配量词会读取整个数据源,然后它会向后(从右边开始)工作,直至找到最右边的匹配。

23、元字符与字符串的冲突:

String s=”\d”; //编译失败

String s=”\\d”; //正则表达式中的\d

String s=”\\ .”; //正则表达式中的.

24、模式匹配

Java.util.regex.Pattern   //保存正则表达式的值。

Java.util.regex.Matcher  //调用正则表达式引擎,进行匹配操作。

Pattern p=Pattern.compile(“\d\w”);  //使用静态compile方法创建模式实例。

Matcher m=p.matcher(“ab 4 56”);   //创建匹配串实例。

boolean b=false;

System.out.println(m.pattern());     //查看当前匹配模式。

while(b=m.find()){               //寻找匹配结果。

  System.out.println(m.start()+” ”+m.group());   //打印匹配开始位置和匹配串。

}

25、使用Scanner类进行查找。

Scanner s=new Scanner(System.in);  //匹配串由用户键盘输入。

String token=s.findInLine(“\d\d”);

System.out.println(“found ”+ token);

26、利用String.split()进行分解:

Split()获取一个正则表达式作为参数,并返回一个数组。

例:String[] tokens=”ab5 ac6 45 @”.split();

27、利用Scanner进行分解:

Scanner默认定界符是空白。

Scanner scan=new Scanner(“1 true 34 hi”);

while(b=scan.hasNext()){  //只测试,不移动。

    scan.next();  //移动到下一个位置。

}

28printf()format()进行格式化:

Java5Java.io.PrintWriter中加入printf()format()

format()方法使用java.util.Formatter类,来执行格式化工作,同时使用于printf()

 

格式字符串构造,[]为可选部分:

%[arg_index$][flags][width][.precision]conversion char

 

flags”-”左对齐参数。

      “0”0填充参数。

      “+”让这个参数包括正负符号。

      “,”使用货币分隔符。

      “(”符号放在括号内。

width:至少要输出多少个字符,不足以空格填充。

conversion charb布尔型 c字符型 d整型 f浮点型s字符串型

 

例:

System.out.printf(“%2$d+%1$d”,123,456); // ”456+123”注意生成都是字符串,不做加法。

格式化数据总是开始于一个%字符。

2$代表第二个参数。

System.out.printf(“%0,7d”,123456);   // ”0123,456”

System.out.format(“%+-7d”,123456);  // ”+123456”  (+也算作width中的一个)

29Matcher.start()----只要有下一个字符就打印其位置,不管是否匹配。

Matcher.group()----打印匹配串,没有就什么都不打印。

30、相同的基本类型,且值相等,包装器的equals返回true,否则返回false.

基本类型不同,值相等,可用==比较返回true.

若布尔表达式中含包装器类型则会自动拆箱。

31、串行化时,被串行化对象继承不可串行化类(IS-A),串行化运行正常。

串行化时,被串行化对象包含不可串行化类对象(HAS-A),串行化时抛出异常。

32hasNext(), hasNextInt()……不会推进,只是测试。

使用next(), nextInt()……推进.

33transient实例变量不会被串行化,static实例变量不会被串行化,但串行化时都不会抛出异常。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics