为什么indexOf没有从unicode给出正确的结果?

时间:2015-03-23 09:12:24

标签: java unicode indexof

如果我使用带有Unicode表示形式的indexOf,我不明白为什么我得不到正确的结果?

public class Test {
    public static void main(String[] args) {
        String strg = "Dog?Cat";
        System.out.println("String: " + strg);
        System.out.println("Char: " + strg.indexOf('?'));
        System.out.println("String: " + strg.indexOf(new String("?")));
        System.out.println("Sign: " + String.valueOf('\u0134'));
        System.out.println("Unicode: " + strg.indexOf(String.valueOf('\u0134')));
    }
}

结果:

String: Dog?Cat
Char: 3
String: 3
Sign: ?
Unicode: -1   --> Why is it -1 ?! Why not 3 ?
你能帮帮我吗?谢谢!

1 个答案:

答案 0 :(得分:5)

String.valueOf('\u0134')不是'?'字符。 System.out.println为许多不可打印的字符(例如'?')打印'\u0134',但您的"Dog?Cat"字符串不包含'\u0134'字符。

这会给你预期的3:

String strg = "Dog?Cat";
System.out.println("Unicode: " + strg.indexOf(String.valueOf('\u003f')));