不同环境下的str.getBytes().length!=str.length()全角半角判断的区别
2011-06-29 10:30
447 查看
不同环境下的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。
在测试环境中判断是否有全角没有问题的。在正式环境就不一样的结果了。
两个都是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。
相关文章推荐
- 不同环境下的str.getBytes().length!=str.length()区别
- 你真的了解中英文字符么--str.length()与str.getBytes().length的区别
- 全角转半角,半角转全角,判断字符是否为全角
- MySQL存储全角字符和半角字符的区别
- 【PHP】日文全角转半角半角判断
- 全角半角判断
- 半角与全角的区别
- 判断字符串是否有汉字、全角半角的判断
- 分清全角和半角的区别
- str==null、str.length==0以及''''.equals(str)之间的区别
- String的getBytes方法在不同的环境返回不一样的值
- 关于中文输入法的全角和半角的区别
- 如何判断字符是全角还是半角
- 判断一个字符是全角还是半角(占一个字节还是两个字节)
- js 判断浏览器类型 去全角、半角空格 自动关闭当前窗口
- iOS 判断字符是全角还是半角
- 俊鸟的数据输入校验专题(四)全角转半角,半角转全角,判断字符是否为全角【转】
- VC++中CString类在不同环境中的区别
- 【LibUIDK界面库系列文章】Edit控件在不同操作系统及编译环境下的区别
- 正则表达式判断数字,字母的全角或半角