不同环境下的str.getBytes().length!=str.length()区别


不同环境下的str.getBytes().length!=str.length()区别?
在测试环境中判断是否有全角没有问题的。在正式环境就不一样的结果了。
两个都是Unix系统,但是系统语言不一样。
有没有办法使之在不同环境下运行结果一致?
也就是说要以什么编码去取,才会一致。
页面是以UTF-8编码的。
是否str.getBytes('UTF-8').length!=str.length()即可,
还是需要str.getBytes('UNICODE').length!=str.length().
getByte()采用默认的编码。
使用UTF-8最为保险:
str.getBytes("UTF-8").length!=str.length();
使用Unicode就有问题了,下面这个不等式不管什么字符永远是true。
str.getBytes("Unicode").length!=str.length();


另外不同环境下str.getBytes().length全角字符取得的长度不同
测试:
str.getBytes().length
在windows XP环境下,一个全角字符是2的长度;
在liunx环境下,一个全角字符是3的长度。

解决方法:
由于是在日文的操作系统上的,所以加上编码 MS932
str.getBytes("MS932").length
这样两个系统环境下的长度都是2。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值