Java中String类的常见面试题
1. 判断定义为String类型的s1和s2是否相等
String s1 = "ab";
String s2 = "abc";
String s3 = s1 + "c";
System.out.println(s3 == s2); //true
System.out.println(s3.equals(s2)); //true
解答:
false //s1是变量,s2与常量"c"相加
true
2. String与StringBuffer传递
/**
* 基本数据类型的值传递,不改变其值
* 引用数据类型的值传递,改变其值
*/
private static void test4() {
String s = "heima";
System.out.println(s);
change(s);
System.out.println(s); System.out.println("------------------");
StringBuffer stringBuffer = new StringBuffer();
stringBuffer.append("heima");
System.out.println(stringBuffer);
change(stringBuffer);
System.out.println(stringBuffer);
} /**
* 调用该方法时实际参数的sb和形式参数的sb指向的是同一个对象(StringBuffer容器)
* 方法内部又在该容器里添加了"itcast",所以方法结束时,局部变量的sb消失,但是
* 实际参数的sb所指向的容器的内部的内容已经发生了改变
* @param stringBuffer
*/
private static void change(StringBuffer stringBuffer) {
stringBuffer.append("itcast");
} /**
* 因为str是属于局部变量,在调用该方法是实际参数s和形式参数str指向的是同一个对象,但是
* 在方法内部将str又指向了一个新的字符串对象,而此时s还是指向的原来的字符串对象
* 该方法执行完毕,局部变量str消失,方法内部产生的新的字符串对象称为垃圾,但是s还是指向
* 原有的字符串对象,并没有改变
* @param str
*/
private static void change(String str) {
str += "itcast";
}
3. Integer的面试题
private static void test5() {
Integer i1 = 97;
Integer i2 = 97;
System.out.println(i1 == i2);
System.out.println("-----------------");
Integer i3 = 199;
Integer i4 = 199;
System.out.println(i3 == i4);
/**
* -128到127是byte的取值范围,如果在这个取值范围内,自动装箱就不会新创建对象,
* 而是从常量池中获取,如果超过了byte取值范围就会再新创建对象
* 源码分析:
*/
public static Integer valueOf(int i) {
if (i >= -128 && i <= 127)
return Integer.IntegerCache.cache[i + (-Integer.IntegerCache.low)];
return new Integer(i);
}
}
4. 为什么针对安全保密高的信息,char[]比String更好?
因为String是不可变的,就是说它一旦创建,就不能更改了,直到垃圾收集器将它回收走。而字符数组中的元素是可以更改的。这就意味着可以在使用完之后将其更改,而不会保留原始的数据)。
所以使用字符数组的话,安全保密性高的信息(Eg. 密码之类的)将不会存在与系统中被他人看到。
5. 如何将字符串转换成时间
private static void test6() {
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String today = simpleDateFormat.format(new Date());
ParsePosition position = new ParsePosition(0);
Date date = simpleDateFormat.parse(today, position);
}
6. 如何计算一个字符串某个字符的出现次数?
private static void test7() {
int n = StringUtils.countMatches("111122233333111", "1");
System.out.println(n);
}
7. 如何重复一个字符串
private static void test8() {
String str = "abcd ";
String repeated = StringUtils.repeat(str, 3);
System.out.println(repeated);
}
Java中String类的常见面试题的更多相关文章
- Java面试炼金系列 (1) | 关于String类的常见面试题剖析
Java面试炼金系列 (1) | 关于String类的常见面试题剖析 文章以及源代码已被收录到:https://github.com/mio4/Java-Gold 0x0 基础知识 1. '==' 运 ...
- String类的常见面试题(3)
1.判断定义为String类型的s1和s2是否相等 String s1 = "abc"; //这个"abc"对象首先会进常量池 String s2 = &quo ...
- Java中String类的方法及说明
String : 字符串类型 一. String sc_sub = new String(c,3,2); // String sb_copy = new String(sb) ...
- java中String类学习
java中String类的相关操作如下: (1)初始化:例如,String s = “abc”; (2)length:返回字符串的长度. (3)charAT:字符操作,按照索引值获得字符串中的指定字符 ...
- 在java中String类为什么要设计成final
在java中String类为什么要设计成final? - 胖胖的回答 - 知乎 https://www.zhihu.com/question/31345592/answer/114126087
- 【转载】Java中String类的方法及说明
转载自:http://www.cnblogs.com/YSO1983/archive/2009/12/07/1618564.html String : 字符串类型 一. String sc_ ...
- 在java中String类为什么要设计成final?
大神链接:在java中String类为什么要设计成final? - 程序员 - 知乎 我进行了重新排版,并且更换了其中的一个例子,让我们更好理解. String很多实用的特性,比如说“不可变性”,是工 ...
- Java中String类为什么被设计为final?
Java中String类为什么被设计为final 首先,String是引用类型,也就是每个字符串都是一个String实例.通过源码可以看到String底层维护了一个byte数组:private f ...
- java中String类的面试题大全含答案
1.下面程序的运行结果是()(选择一项)String str1="hello";String str2=new String("hello");System.o ...
随机推荐
- x-杂项-maven-repository-lombok-intro:使用PROJECT LOMBOK减少BOILERPLATE代码
ylbtech-杂项-maven-repository-lombok-intro:使用PROJECT LOMBOK减少BOILERPLATE代码 1.返回顶部 1. REDUCING BOILERPL ...
- iOS扩展Extension之Today
1.简介 扩展(Extension)是iOS 8中引入的一个新特性.扩展让app之间的数据交互成为可能.在iOS 8系统之前,每一个app在物理上都是彼此独立的,app之间不能互访彼此的私有数据.而在 ...
- iOS开发之SceneKit框架--SCNAction.h
1.SCNAction简介 主要负责节点SCNNode的属性,实现node的渐变.移动.出现.消失.实现动画等. 2.相关API 节点的移动(earthNode的初始坐标(5,0,0)) //从当前位 ...
- mybatis框架中XxxxMaper.xml的文件
我们知道在mybatis框架中,config.xml中会关联到许多的XxxxMapper的xml文件,这些文件又对应着一个个的接口,来观察下这些xml文件 从以下这个文件为例子: <?xml v ...
- POJ 1269 /// 判断两条直线的位置关系
题目大意: t个测试用例 每次给出一对直线的两点 判断直线的相对关系 平行输出NODE 重合输出LINE 相交输出POINT和交点坐标 1.直线平行 两向量叉积为0 2.求两直线ab与cd交点 设直线 ...
- Hadoop 2.x 版本中的依赖 jar
- leetcode-95-不同的二叉搜索树(卡特兰数)
题目描述: 方法一:动态规划 O(n^2) O(n) class Solution: def numTrees(self, n: int) -> int: dp = [0]*(n+1) dp[0 ...
- Python3基础笔记_列表
# Python 列表(List) list1 = ['physics', 'chemistry', 1997, 2000] list2 = [1, 2, 3, 4, 5] list3 = [&quo ...
- 大O法时间复杂度计算
困惑的点——log,如何计算得出? ① 上限:用来表示该算法可能有的最高增长率. ② 大O表示法:如果某种算法的增长率上限(最差情况下)是f(n),那么说这种算法“在O(f(n))中”.n为输入规模. ...
- css3中 百分比宽度减去固定宽度的写法
div{ /*实现了宽度为父容器宽度减去固定的300像素*/ width:-webkit-calc(100% - 300px); width:-moz-calc(100% - 300px); widt ...