我正在 CLI 电子表格程序上做一个项目。我使用此代码从文件输入:
DataInputStream in=new DataInputStream(System.in);
System.out.print("nEnter filename (with path) - ");
String fn=in.readLine();
FileReader fr=new FileReader(fn);
BufferedReader br=new BufferedReader(fr);
String sen="";
while(true)
{
String sn=br.readLine();
if(sn==null)
break;
sen=sen+sn;
}
StringTokenizer st=new StringTokenizer(sen,"|");
String s[][][]=new String[(st.countTokens()/9)][9][3];
int r_0=(st.countTokens()/9);
int r,c;
r=c=0;
for(int i=0;i<st.countTokens();i++)
{
StringTokenizer st1=new StringTokenizer(st.nextToken(),"ɰ");
s[r][c][0]=st1.nextToken();
s[r][c][1]=st1.nextToken();
s[r][c][2]=st1.nextToken();
System.out.println(s[r][c][0]+"t"+s[r][c][1]+"t"+s[r][c][2]); // to be deleted
c++;
if(c==9)
{
r++;
c=0;
}
}
默认情况下,电子表格有 8 个可见行(总共 9 行)。直到第 5 行,第 5 列(或直到 s[5][5][0/1/2]),程序正确读取文件中的值。但之后它开始读取空值。我想知道这种突然偏离正常行为的原因。它与内存使用有关吗?[更新 - 它发生在细胞数量的一半之后,而不是具体 [5,5,0]]
示例输入:
ɰ ɰ |Aɰ ɰ |Bɰ ɰ |Cɰ ɰ |Dɰ ɰ |Eɰ ɰ |Fɰ ɰ |Gɰ ɰ |Hɰ ɰ |1ɰ ɰ |8ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ |2ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ |3ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ |4ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ |5ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ |6ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ | ɰ ɰ |
你应该将 for 循环与
while (st.hasMoreTokens())
而不是for
循环。无论如何,您都没有使用该i
。
此外,countTokens()
函数在检索令牌期间更改其值(请参阅 Javadoc)