Java 中的正则表达式与递归编程
1. Java 中使用正则表达式
1.1 字符串问题
在 Java 里处理包含正则表达式的字符串时存在一个问题。正则表达式模式依赖反斜杠字符来标记模式的不同元素,但 Java 将字符串字面量中的反斜杠字符视为转义字符。所以不能直接在字符串字面量中引用正则表达式,否则 Java 会在正则表达式类使用之前就处理掉反斜杠字符。
例如,以下代码无法编译:
String regex = "\w\d-\w\d"; // error: won’t compile
编译器看到字符串中的反斜杠,期望找到有效的 Java 转义序列,而不是正则表达式。
解决办法是将所有反斜杠都加倍。Java 将连续两个反斜杠视为转义后的反斜杠,并在字符串中放置一个反斜杠。所以上述代码应写成:
String regex = "\\w\\d-\\w\\d"; // now it will compile
若不确定字符串字面量的编码是否正确,可使用 System.out.println 打印结果字符串,然后检查控制台输出以确保编写正确。
1.2 使用 String 类的正则表达式
若只想检查字符串是否与模式匹配,可使用 String 类的 matches 方法。该方法接受一个正则表达式作为参数,并
超级会员免费看
订阅专栏 解锁全文
42

被折叠的 条评论
为什么被折叠?



