在学习网络编程时,写了一个简单的demo,有这样一段代码
while((len = is.read(buf)) != -1 ) {
String convertedText = new String(buf).toUpperCase();
System.out.println("convertedText = " + "--"+convertedText +"--");
System.out.println("OVER".equals(convertedText));
if("OVER".equalsIgnoreCase(convertedText)) break;
os.write(convertedText.getBytes());
Arrays.fill(buf,(byte) 0);
当服务端接收到 over时,程序结束。但是实际情况是 :输入了 over 依然返回 false,加入log 发现字符串一模一样 ,但就是返回false。
最后终于找到原因了:
int len = 0;
while((len = is.read(buf)) != -1 ) {
String convertedText = new String(buf,0,len).toUpperCase();
System.out.println("convertedText = " + "--"+convertedText +"--");
System.out.println("OVER".equals(convertedText));
if("OVER".equalsIgnoreCase(convertedText)) break;
os.write(convertedText.getBytes());
Arrays.fill(buf,(byte) 0);
原因是,使用byte数组创建字符串时错误, byte数组的长度 是1024,所以 string 的长度也是1024, 比较时返回错误。改成
new String(buf,0,len);
就好了,嘿嘿
本文讨论了在网络编程中遇到的一个问题:在使用byte数组创建字符串时导致的比较错误。通过修改代码,从使用整个数组到使用数组的正确长度部分创建字符串,解决了字符串比较始终返回false的问题。
1016

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



