A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 王峰230321 中级黑马   /  2013-7-26 17:48  /  1085 人查看  /  6 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 王峰230321 于 2013-7-26 19:42 编辑

为什么 .  这个    over  不会 break?     
在下面加上else  就可以  但是 不加 else 就不行.   这个  还会影响到 break吗?

import java.io.*;
public class JAVAjiaqiang
{
        public static void main(String[] args)throws Exception
        {
        InputStream in=System.in;
        StringBuffer sb=new StringBuffer();
        int num=0;
        q:while(true)
        {
                num=in.read();
                if(num=='\r')
                        continue;
                if(num=='\n')
                {
                        String st=sb.toString();
                           System.out.println(st.toUpperCase());
                    sb.delete(0,sb.length());
                    if("over".equals(st))
                                break;

                }
                        sb.append((char)num);
        }

        }
}


6 个回复

倒序浏览
求解!!!!!
回复 使用道具 举报
你不写else的话,\r\n也被添加到stringbuffer里了,造成往后的每次结果都多一个换行,程序就停不住了
回复 使用道具 举报
String st=sb.toString().trim();
你把这条改成这样看看
主要是你多了个换行
回复 使用道具 举报
  1. package test;

  2. import java.io.*;
  3. public class test1
  4. {
  5.         public static void main(String[] args)throws Exception
  6.         {
  7.                 InputStream in=System.in;
  8.                 StringBuffer sb=new StringBuffer();
  9.                 int num=0;
  10.                 while(true)
  11.                 {
  12.                      num=in.read();
  13.                      if(num=='\r')
  14.                      {                      
  15.                          continue;
  16.                      }
  17.                      if(num=='\n')
  18.                      {
  19.                                
  20.                         String st=sb.toString();
  21.                         System.out.println(st.toUpperCase());
  22.                         System.out.println(st);
  23.                         sb.delete(0,sb.length());
  24.                         
  25.                         //下边不加else,用这个代码就能说明问题,
  26.                         //判断跳出循环的格式应该为这样:"\nover"
  27.                         if("\nover".equals(st))
  28.                            break;
  29.                      }
  30.                                           
  31.                      //每次输出换行后,该代码仍然后执行到,
  32.                      //相当于在字符串容器的首位存放了一个\n
  33.                      sb.append((char)num);
  34.                 }

  35.         }
  36. }
复制代码
不加else,可以通过这样来说明问题,结束标记的字符串定义错误。
回复 使用道具 举报
薛淑凯 发表于 2013-7-26 19:13
你不写else的话,\r\n也被添加到stringbuffer里了,造成往后的每次结果都多一个换行,程序就停不住了 ...

嗯.  我已经弄明白了 .  好长时间 没人回复..     编码 像这么写的 .  如果 over在第一行的时候 还能认出来 .
但是 如果 是在下面.  就是 每一次   字母前面 都会多一个 newLine..    也就跟over匹配不上了.
回复 使用道具 举报
恩 我也学习了东西,谢谢啊
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马