指出下列程序运行的结果()
public class Example{ String str = new String("good"); char[ ] ch = { 'a' , 'b' , 'c' }; public static void main(String args[]){ Example ex = new Example(); ex.change(ex.str,ex.ch); System.out.print(ex.str + " and "); System.out.print(ex.ch); } public void change(String str,char ch[ ]){ str = "test ok"; ch[0] = 'g'; } }
A.good and abc
B.good and gbc
C.test ok and abc
D.test ok and gbc
不是所有的传引用 都是改变原来的值。具体看代码是怎么做的 有可能只改变了指向
本题主要考察传引用会发生的问题。分为两种情况:
通过引用,修改原来的内存
通过引用,修改当前引用的指向
接下来大家参考这个图解。故:选择B。
在 Java 中,直接赋值存放字符串常量的对象属于( )类对象。
A.Character
B.String
C.StringBuffer
D.Vector
A:是char类型的包装类型,可以存储字符
B:可以直接赋值字符串常量。String str = “hello”;
C:StringBuffer不能直接赋值字符串常量。
D:Vector底层是一个动态数组,不可以直接赋值字符串常量。
下面代码将输出什么内容:()
public class SystemUtil{ public static boolean isAdmin(String userId){ return userId.toLowerCase()=="admin"; } public static void main(String[] args){ System.out.println(isAdmin("Admin")); } }
A.true
B.false
C.1
D.编译错误
本题主要考察的代码部分为:
return userId.toLowerCase()=="admin";
==号两边的是引用数据类型,那么比较的是"地址相不相同"。“admin”,存放在常量池当中,但是通过方法,userId.toLowerCase()。返回的是一个新的对象,大家可以看看该方法的源码。最终的返回值是:return new String(形参…); 并不是常量池的"admin"。所以,这里比较的结果就是false。故:选择B。
判断对错 字符串常量是不可变对象, 不能修改字符串的内容()
A:正确。观察String源码,我们发现这样的代码:
private final char value[];
public String( String original) {
this.value = original.value;
this.hash = original.hash;
}
可以看到 value 是私有的,类外获取不到,所以无法修改。
B:正确。
C:正确 。 contains就是 字符串中是否包含某个子字符串,包含返回true,不包含返回false。
D:错误。故选择D。
StringBuffer 比 StringBuilder 更高效 ( )
错
StringBuffer是线程安全的,相比StringBuilder来说,每次为了保证线程安全,加锁和释放锁都会消耗系统资源,从而导致效率变低。