关于' \uxxxx'字符在编译时的处理

如下所示代码:

class GrammarTest{
	public static void main(String[] args){
		char ch=0x30;
		System.out.println(ch); //正常,输出0
		ch='\u0030';
		System.out.println(ch);  //正常,输出0
		System.out.println("a\u0022.length() + \u0022b".length());  //输出2
	}
}

    结果说明,编译结果错误提示如下:

113056_O3G4_2011779.png

    上述程序有编译错误。如果删除多行注释,则编译错误消除.

    【结果分析】:

    首先分析编译错误的原因,可以肯定编译错误是由多行注释引起的,它包含了一个\u开头的Unicode转义字符序列,但是却没有紧跟着4个16进制的数(0~65535),导致该转义失效。java是允许在注释以及代码中使用\u开头的Unicode转义字符的,但是要求转义必须有效,否则编译器会报告错误。

    删除该段注释或者使该转义有效之后,执行上述代码得到的结果是2,又是为什么呢?原来,Java 对在字符串字面常量中的 Unicode 转义字符没有提供任何特殊处理。编译器在将程序解析成各种符号之前,先将Unicode转义字符转换成为它们所表示的字符。所以,程序中的第一个 Unicode转义字符将作为一个单字符字符串字面常量( "a")的结束引号,而第二个Unicode 转义字符将作为另一个单字符字符串字面常量( "b")的开始引号,该程序实际运行的代码如下:

System.out.println("a".length() + "b".length());

    这样来看,输出结果为2也就不足为奇了。注意对于字符串类型

源代码地址:https://github.com/rocwinger/java-disabuse

 

转载于:https://my.oschina.net/ray1421/blog/738208

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值