解析Unicode转义序列带来的问题

Unicode转义序列的解析是发生在代码编译之前,编译器机械的将\u样式的代码文本转义,即使是注释以及非正常代码,对此步骤来说也没有区别

导致下面的情况:

 1 public class Test {
 2     public static void main(String[] args) {
 3         System.out.println("\u0022+\u0022");//""+""=null
 4         //\u000a System.out.println("annotation !");//print success!
 5         //\n System.out.println("annotation !");//print success!
 6        
 7     }
 8 }
 9 Output:
10 
11 annotation !

由于机械转义,"\u0022+\u0022"实际上是""+""即两个空字符串相加,所以打印为空

注释中的\u000a被转移成\n换行符,所以其后的print代码得以执行

而普通的\n转义序列却不会产生问题

posted @ 2018-03-15 10:57  ArrogantL  阅读(209)  评论(0编辑  收藏  举报