目录
Java编程思想(一)第1~4章:概述
Java编程思想(二)第5章:初始化和清理
Java编程思想(三)第6章:访问权限
Java编程思想(四)第7章:复用类
Java编程思想(五)第8章:多态
Java编程思想(六)第9章:接口
Java编程思想(七)第10章:内部类
Java编程思想(八)第11章:持有对象
Java编程思想(九)第12章:异常
Java编程思想(十)第13章:字符串
Java编程思想(十一)第14章:类型信息
Java编程思想(十二)第15章:泛型
Java编程思想(十三)第16章:数组
Java编程思想(十四)第17章:深入研究容器
Java编程思想(十五)第18章:Java I/O系统
Java编程思想(十六)第19章:枚举
Java编程思想(十七)第20章:注解
Java编程思想(十八)第21章:并发
第十三章、字符串
目录
13.1 不可变字符串
13.2 重载“+”与 StringBuilder.append()
13.3 无意识的递归
13.4 格式化输出
13.5 正则表达式
13.6 String StringBuilder StringBuffer区别
13.7 Scanner & StringTokenize
String对象是不可变的(Thread-Safe): 线程安全的。
String s = "abc" + "def" + 4.7 ;
String类中每个看起来会修改String值的方法,实际上都是创建了一个全新的String对象,以包含修改后的字符串内容。而最初的String对象则丝毫未动。
用于String的“+”与“+=”是Java中仅有的两个重载过的运算符,Java不允许程序员重载任何运算符(但其实Java语言比C++更容易实现运算符的重载)。
String的不可变性带来了一定的效率问题,比如String的“+”运算,每“+”一次都会生成一个新的String对象(内存垃圾)。
Java编译器(javac)一般会自动优化,但不同情况下,优化的程度不够。
由String对象后面跟着一个“+”,再后面的对象不是String时,编译器会使后面的对象通过toString()自动类型转换成String.
如果这发生在自定义的类的重写的toString()方法体内,就有可能发生无限递归,运行时抛出java.lang.StackOverflowError栈溢出异常。
// InfiniteRecursion.java
public class InfiniteRecursion{
public String toString(){
//应该调用Object.toString()方法,所以此处应为super.toString()。
return " InfiniteRecursion address: " + this + "\n"; //此处会递归调用toString(),出现异常。
}
public static void main(String[] args){
List v = new ArrayList();
for(int i = 0; i < 10; i++)
v.add(new InfiniteRecursion());
System.out.println(v);
}
}
a. System.out.format("Row [%d %f]", x, y);
b. Formatter类:Formatter.format();
a. 强大&灵活的文本处理工具;
b. 使用编程方式,构造复杂的文本模式;
作用: 可实现:匹配&选择&编辑&验证String。
13.5.1 语法(Pattern&Matcher)
Pattern p = Pattern.compile(arg);
Matcher m = p.matcher(arg[0]); //判断输入的String 是否满足正则表达式
a. String: Java 提供了 String 类来创建和操作字符串。
b. StringBuffer 和 StringBuilder:
当对字符串进行修改的时候,需要使用 StringBuffer 和 StringBuilder 类。
c. StringBuilder 类在 Java 5 中被提出,它和 StringBuffer 之间的最大不同在于 StringBuilder 的方法不是线程安全的(不能同步访问)。
d. 由于 StringBuilder 相较于 StringBuffer 有速度优势,所以多数情况下建议使用 StringBuilder 类。然而在应用程序要求线程安全的情况下,则必须使用 StringBuffer 类。
Scanner定界符:为Java SE1.5 新增
StringTokenize:废弃使用!