字符串基础问题
来源:互联网 发布:mysql 断电 无法启动 编辑:程序博客网 时间:2024/05/18 16:56
字符串基础问题
题目一
public class Test{ public static void main(String[] args){ String s1 = "abc"; String s2 = s1; String s3 = new String("abc"); String s4 = new String("abc"); String s5 = "abc"; System.out.println(s1==s5); System.out.println(s1==s2); System.out.println(s1.equals(s2)); System.out.println(s3==s4); System.out.println(s1.equals(s4)); System.out.println(s3.equals(s4)); }}
输出是 true true true false true true
记住 == 比较引用. equals 比较值. String 对象会创建一个字符串池 (a pool of string), 如果当前准备新创建的字符串对象的值在这个池子中已经存在,那么就不会生成新对象, 而是复用池中已有的字符串对象. 不过, 只有采用 Object s = “Hello” 方式 (而非用”new“关键字) 声明 String 对象的时候这个规则才会被应用.
题目二
String s = "a" + "b" + "c" + "d" + "e"
创建了几个对象? 1个 赋值号右边都是常量,编译时直接储存它们的字面值, 在编译时直接把结果取出来面成了 "abcde"
题目三
# 创建了几个String Object?二者之间有什么区别? String s = new String("xyz");
两个或一个, ”xyz”对应一个对象, 这个对象放在字符串常量缓冲区, 常量”xyz”不管出现多少遍, 都是缓冲区中的那一个. New String每写一遍, 就创建一个新的对象, 它一句那个常量”xyz”对象的内容来创建出一个新String对象. 如果以前就用过’xyz’, 这句代表就不会创建”xyz”自己了, 直接从缓冲区拿.
题目四
String s1 = new String("777");String s2 = "aaa777";String s3 = "aaa" + "777";String s4 = "aaa" + s1;
s2 == S3 : true s2 == S4 : false s2 == S4.intern() : true
题目五
String str = "ABCDEFGH";String str1 = str.substring(3,5);System.oout.println(str1);
输出是 DE substring 是前包括后不包括
题目六
执行后,原始的 String 对象中的内容到底变了没有? String s = "Hello"; s = s + " world!";
没有. 因为 String 被设计成不可变(immutable)类, 所以它的所有对象都是不可变对象.
在这段代码中, s原先指向一个String对象, 内容是 "Hello",然后我们对s进行了+操作, 这时,s不指向原来那个对象了, 而指向了另一个 String对象, 内容为"Hello world!", 原来那个对象还存在于内存之中, 只是s这个引用变量不再指向它了.
题目七
执行后,输出是什么? 共创建了几个字符串对象?
String s = " Hello "; s += " World "; s.trim( ); System.out.println(s);
再次强调 String 是不可变(immutable)类. 所以共创建了三个对象. 最后输出是 " Hello World ". 只有 s = s.trim() 之后才是 "Hello World".
from: https://dongchuan.gitbooks.io/java-interview-question/java/string_questions.html
- 字符串基础问题
- ASP.NET基础问题----使用随机字符串
- 19:字符串移位包含问题(1.7编程基础之字符串)
- 问题 G(1203): 【基础算法】0/1字符串问题
- 字符串-基础
- 字符串基础
- 字符串基础
- 字符串基础
- C基础/指定长度的字符串排列问题
- 基础练习 完美的代价(蓝桥杯 字符串问题)
- 字符串问题--转义字符串
- 字符串问题---翻转字符串
- 字符串问题
- 字符串问题
- 字符串问题
- 字符串问题
- 字符串问题
- 字符串问题
- 2017武大邀请赛
- [雅礼4-7]T1 prufer序列&&dp
- Zookeeper关于“Error contacting service. It is probably not running”
- MDK的编译过程及文件类型全解
- 栈的基本操作
- 字符串基础问题
- done and doing
- Git .gitignore文件比较完善的写法
- 数据结构----->二叉树
- BF算法
- hdu3487:Play with Chain (splay)
- spoj10606——BALNUM
- 51nod:1174 区间中最大的数(RMQ)
- java 计算两字符串的最大子字符串