1.下面代码输出的结果为
public class Test {
public static void main(String[] args) {
Object o = new Object() {
public boolean equals(Object obj) {
return true;
}
};
System.out.println(o.equals("Fred"));
}
}
2.关于访问权限说法正确 的是 ? ( )
A.外部类前面可以修饰public,protected和private
B.成员内部类前面可以修饰public,protected和private
C.局部内部类前面可以修饰public,protected和private
D.以上说法都不正确
3.ocket编程中,以下哪个socket的操作是不属于服务端操作的()?
A.accept
B.recieve
C.getInputStream
D.close
4.()运算符和()运算符分别把一个值的位向左和向右移动
A.<<
B.>>
C.&&
D.||
5.String s=null;
下面哪个代码片段可能会抛出NullPointerException?
A.if((s!=null)&(s.length()>0))
B.if((s!=null)&&(s.length()>0))
C.if((s==null)|(s.length()0))
D.if((snull)||(s.length()==0))
6.区分类中重载方法的依据是( )。
A.不同的形参名称
B.不同的返回值类型
C.不同的形参列表
D.不同的访问权限
7.下面哪个选项没有实现 java.util.Map 接口?
A.Hashtable
B.HashMap
C.Vector
D.IdentityHashMap
8.以下 _____ 不是 Object 类的方法
A.clone()
B.finalize()
C.toString()
D.hasNext()
9.在java7中,下列不能做switch()的参数类型是?
A.int型
B.枚举类型
C.字符串
D.浮点型
10.下列说法正确的是( )
A.volatile,synchronized 都可以修改变量,方法以及代码块
B.volatile,synchronized 在多线程中都会存在阻塞问题
C.volatile能保证数据的可见性,但不能完全保证数据的原子性,synchronized即保证了数据的可见性也保证了原子性
D.volatile解决的是变量在多个线程之间的可见性、原子性,而sychroized解决的是多个线程之间访问资源的同步性
(1)B.
1.建立了一个匿名内部类,并重写了Object的equals方法。
2.通过o调用了equals方法,方法返回true。
(2)B
对于普通的类,可用的修饰符有 final 、 abstract 、 strictfp 、 public 和默认的包访问,不可以用 private 修饰。
(3)C
1,3.connect()与accept():这两个系统调用用于完成一个完整相关的建立,其中connect()用于建立连接。accept()用于使服务器等待来自某客户进程的实际连接。
2.listen():此调用用于面向连接服务器,表明它愿意接收连接。listen()需在accept()之前调用.
4.关闭套接字──closesocket()关闭套接字s,并释放分配给该套接字的资源;如果s涉及一个打开的TCP连接,则该连接被释放。
(4)AB
(5)答案:AC
s为null,因此只要调用了s.length()都会抛出空指针异常。因此这个题目就是考察if语句的后半部分会不会执行。
A,单个与操作的符号& 用在整数上是按位与,用在布尔型变量上跟&&功能类似,但是区别是无论前面是否为真,后面必定执行,因此抛出异常
B,与操作,前半部分判断为假,后面不再执行
C,这里跟 & 和&& 的区别类似,后面必定执行,因此抛出异常
D,或语句,前面为真,整个结果必定为真,后面不执行
(6)C
两个重载函数必须在下列一个或两个方面有所区别: 1、函数的参数个数不同。 2、函数的参数类型不同或者参数类型顺序不同
(7)答案:C
A,B,D都实现了Map接口,其中A与B的区别是一个是线程安全的,一个是线程不安全的
C中Vector是实现了List接口,是一个线程安全的List
(8)D
1.clone方法 保护方法,实现对象的浅复制,只有实现了Cloneable接口才可以调用该方法,否则抛出CloneNotSupportedException异常。 2.getClass方法 final方法,获得运行时类型。 3.toString方法 该方法用得比较多,一般子类都有覆盖。 4.finalize方法 该方法用于释放资源。因为无法确定该方法什么时候被调用,很少使用。 5.equals方法 该方法是非常重要的一个方法。一般equals和==是不一样的,但是在Object中两者是一样的。子类一般都要重写这个方法。 6.hashCode方法 该方法用于哈希查找,重写了equals方法一般都要重写hashCode方法。这个方法在一些具有哈希功能的Collection中用到。 一般必须满足obj1.equals(obj2)==true。可以推出obj1.hash- Code()==obj2.hashCode(),但是hashCode相等不一定就满足equals。不过为了提高效率,应该尽量使上面两个条件接近等价。 7.wait方法 wait方法就是使当前线程等待该对象的锁,当前线程必须是该对象的拥有者,也就是具有该对象的锁。wait()方法一直等待,直到获得锁或者被中断。wait(long timeout)设定一个超时间隔,如果在规定时间内没有获得锁就返回。 调用该方法后当前线程进入睡眠状态,直到以下事件发生。 (1)其他线程调用了该对象的notify方法。 (2)其他线程调用了该对象的notifyAll方法。 (3)其他线程调用了interrupt中断该线程。 (4)时间间隔到了。 此时该线程就可以被调度了,如果是被中断的话就抛出一个InterruptedException异常。 8.notify方法 该方法唤醒在该对象上等待的某个线程。 9.notifyAll方法 该方法唤醒在该对象上等待的所有线程。
(9)D
jdk1.7 以后含1.7 ,有 int byte char short及其包装类型 和 enum类型, String类型是在 1.7 新增的
(10)C
原子 有序 可见 其中 volatile 是有序和可见 重量锁是 有序 可见 原子 值得注意的是 两种方式表达的有序性是不一样的 volatile 是通过内存屏障 禁止指令重排的有序 重量锁 是通过互斥锁 使得进入临界区的线程只有一个的 这也是临界区代码是原子的原因 那么这样看 代码就和天然有序一样 内部代码依旧可能指令重排 有兴趣的同学可以看看周志明的深入理解 JVM~