如果我使用带有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 ?
你能帮帮我吗?谢谢!
答案 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')));