搜人2013笔试题(java)

今天应该又不少同学去ZD参加搜狗的笔试,由于时间冲突,我选择了去三星。回来看看搜狗的笔试题,总体上感觉还好,不是很“难”(纯粹马后炮)。现奉上题(只关注java部分和DS部分)。

字符串问题

搜人2013笔试题(java)_第1张图片

分析:

A:s1==s2为false,前者定义是对象的引用,"abc"存储在堆内存中,而s2中的“abc”存储在常量池中,用s1的栈内存地址和“abc”比较自然是否。

B:String是final类,故是正确的。

C、D:StringBuffer 与 StringBuilder 中的方法和功能完全是等价的,只是StringBuffer 中的方法大都采用了 synchronized 关键字进行修饰,因此是线程安全的,而 StringBuilder 没有这个修饰,可以被认为是线程不安全的。
StringBuffer 始于 JDK 1.0
StringBuilder 始于 JDK 1.5
从 JDK 1.5 开始,带有字符串变量的连接操作(+),JVM 内部采用的是StringBuilder 来实现的,而之前这个操作是采用 StringBuffer 实现的。

故BC为正确答案。

java内存管理

搜人2013笔试题(java)_第2张图片

解析:

A:gc()建议jvm执行垃圾回收,可行

B:可行,避免

C:可行,在JVM垃圾收集器收集一个对象之前 ,一般要求程序调用适当的方法释放资源,但在没有明确释放资源的情况下,Java提供了缺省机制来终止化该对象心释放资源,这个方法就是finalize()。http://blog.csdn.net/yu422560654/article/details/7326852

D:避免堆内存溢出,可行

E:可行。

runFinalization
public static void runFinalization()调用Finalize()释放资源
运行处于挂起终止状态的所有对象的终止方法。  
调用该方法说明 Java 虚拟机做了一些努力运行已被丢弃对象的 finalize 方法,但是这些对象的 finalize 方法至今尚未运行。当控制权从方法调用中返回时,Java 虚拟机已经尽最大努力去完成所有未执行的终止方法。  
调用 System.runFinalization() 实际上等效于调用:  Runtime.getRuntime().runFinalization()

线程问题


搜人2013笔试题(java)_第3张图片

解析:t2唤醒t1时,此时obj是同步状态,必须t2执行完后,才到t1,所以选择B。

(该题不确定,希望比较懂的人给点意见)

字节数

搜人2013笔试题(java)_第4张图片

解析:

writeInt写入四个字节,writeChar写入两个字节。故6

参见:http://blog.csdn.net/androidbluetooth/article/details/6430797

你可能感兴趣的:(java,String,三星,搜狗)