3

我正在从书中做一个简单的练习,我对 java 函数 parseInt 的工作方式有点困惑。我从输入文件中读取了一行,使用 StringTokenizer 将其拆分,现在我想将每个部分解析为整数。

我在监视窗口中检查了 parseInt 函数的输入确实是一个看起来是有效整数的字符串(例如“35”)。但是,当我尝试对持有值“35”的str.charAt变量使用该函数时,会得到奇怪的结果:str

str.charAt(0) == ""
str.charAt(1) == "3"
str.charAt(2) == ""
str.charAt(3) == "5"

这似乎是一个可能与编码有关的问题,所以我尝试使用这种读取文件的方式来修复它:

InputStreamReader reader = new InputStreamReader(new FileInputStream(inputfile), "UTF-8");

(我已经在我的编辑器中使用 UTF-8 编码明确保存了文件),但这并没有帮助。任何想法可能是什么问题以及如何解决它?

编辑:我的样本

        InputStreamReader reader = new InputStreamReader(new FileInputStream(inputfile), "UTF-8");
        BufferedReader bfreader = new BufferedReader(reader);

        line = bfreader.readLine();
        while (line !=null)
        {
                String[] valueStrings = line.split(" ");
                String hole = valueStrings[0]; 

                int[] values = new int[4];
                for (int i = 0; i <values.length; i++){

                    String nr = valueStrings[i+1].trim(); 
                    values [i] = Integer.parseInt(nr);
                }

                // it breaks at the parseInt here, the rest is not even executed...

         }
4

1 回答 1

11

我的猜测是它实际上是

str.charAt(0) == '\0'
str.charAt(1) == '3'
str.charAt(2) == '\0'
str.charAt(3) == '5'

听起来它可能实际上保存在 UTF-16 而不是 UTF-8 中 - 但如果您的文本编辑器认为它是为了保存“空”字符,那将是有道理的。尝试在二进制十六进制编辑器中查看文本文件——我怀疑你会发现每隔一个字节都是 0。

如果这没有帮助,请发布一个简短但完整的程序来演示该问题 - 到目前为止,我们只看到了您的一行代码。

于 2010-02-12T20:40:16.450 回答