第一篇:人人网Java开发工程师笔试题
人人网Java开发工程师笔试题
填空题(10题)
1、JAVA面向对象三大特征:继承、封装、多态
2、Sleep()和wait()的区别:
sleep()方法是使线程停止一段时间的方法。在sleep 时间间隔期满后,线程不一定立即恢复执行。这是因为在那个时刻,其它线程可能正在运行而且没有被调度为放弃执行,除非(a)“醒来”的线程具有更高的优先级(b)正在运行的线程因为其它原因而阻塞。
wait()是线程交互时,如果线程对一个同步对象x 发出一个wait()调用,该线程会暂停执行,被调对象进入等待状态,直到被唤醒或等待时间到。
3、类被JVM回收的标志
4、重写JAVA equals方法,还要同时重写hashCode()方法
5、String,StringBuilder,StringBuffer的区别
String是固定长度的字符串,如果要发生变化必须重新生成新的实例; String 字符串常量
StringBuffer 字符串变量(线程安全)
StringBuilder 字符串变量(非线程安全)
6、增加数据库一列的SQL语法:ALTER TABLE table_name ADD column_name TYPE;
7、JSP内置对象及方法request、__、__、__(列出3个即可)
Request,response,out,session,page,application,exception, config, pageContext8、List,Set,Map是否继承Collection接口?
List,Set是 ,Map不是
9、数据库事务正确执行的基本要素:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)。
10、10,100,32,45,58,126,3,29,200,400,0利用除商留余法构造存于长度为13的数据的HASH
不是很明白题目的意思,下面是加法hash,可以存于长度为prime的数据hash static int additiveHash(String key, int prime)
{
int hash, i;
for(hash = key.length(), i = 0;i < key.length();i++)
hash += key.charAt(i);
return(hash % prime);
}
选择题(5题)
单选多选不定
1、int I = 42;
long l = 42;
double d = 42.0;
下面为true的是
A、(I == l)
B、(I == d)
C、(l == d)
D、i.equals(d)
E、d.equals(l)
F、i.equals(l)
G、l.equals(42L)
(FG)
2、对于abstract声明的类,下面说法正确的是
A、可以实例化
B、不可以被继承
C、子类为abstract
D、只能被继承
E、可以被抽象类继承
(E)3、4、5、下面代码执行后结果为
Int x = 8, y = 2, z;
z = ++x*y;
Z = x/y++
A、x =16, y = 2
B、x =16, y = 3
C、x =18, y = 2
D、x =18, y = 3
(D)
(中间两题忘了,不难,是单选)
问答题(5题)
1、int I = 0; I = i++;I = i++;是线程安全的吗?如果不是,那它在JVM中是如何实现的?JDK
中有哪个类可以实现这个目标又是线程安全的?这个类线程安全的原理是什么?
AtomicInteger,一个提供原子操作的Integer的类。在Java语言中,++i和i++操作并不
是线程安全的,在使用的时候,不可避免的会用到synchronized关键字。而AtomicInteger则通过一种线程安全的加减操作接口。
(参考:http:///n/10512/这位仁兄估计是参加了早上那场笔试)
2、int a[100] = { 1 2 2 3 ……}, 数组元素都为正整数,且a[i+1] >= a[i], 请快速输出a[i] = i的数。
3、int a[100] = { 1 2 3 3 4 3 2 ……}, 数组中所有元素都为正整数,求a[i] + a[t] = a[x], I, t, x 均
小于等于n,求最大的a[x].4、用java扫描指定文件夹下面所有以.txt,.log结尾的文件,并将其绝对路径输出。
5、简述你所熟悉的设计模式。模拟一个应用场景,并说出你所使用的设计模式的优缺点(单
例模式除外)。
附录:
网友总结的上次人人网笔经、面经
By neoxung@ITEYE 2010-04-06
【笔试】
拿到是JAVA研发工程师基础笔试题,总体感觉是针对应届毕业生,考题比较基础但面比较宽泛。大致记录如下:
1.一个部门1/2为系统工程师,2/5为软件工程师,1/4两者都是,那么两者都不是的比例?---集合覆盖
2.某设计运动员射击10次,总中90环,如果每次射击为0-10环,列出其成绩所有可能值的表达式。---缺失的10环的10次分配
3.高度为h的满树其总结点数为?中序遍历为?---树
4.针对10,100,32,45,58,126,3,29,200,400,0利用除商留余法构造存于长度为13的数据的HASH。---实在不会
5.简述进程与线程的区别。---“本质的区别在于每个进程有它自己的变量的完备集,线程则共享相同的数据”
6.简述网络三次握手的过程。---网络基础
7.关于ICMP的特性。
8.根据子网掩码判断已知的IP地址是否在当前子网内。
9.Linux系统开启新进程的命令?进程间通信的方法。
10.shell编程。
11.仅仅提交更新部分的数据而不是全部数据违反了数据库的什么规则?---数据库
12.第一范式的特性。
13.增加数据表一列的SQL语法。
14.非主键索引为什么能提高搜索效率但会降低更新效率?
15.编写代码将任一字符串按照某子串进行分割,并将处理后的内容反向输出。例如“A B C”,按照“ ”分割,最终输出“C B A”---考察得基础而全面,设计API,正则,StringBuilder等内容
16.编写代码删除某文件目录下的所有子目录和文件,并输出目录的名字,路径以及文件的内容。---同样是对文件系统API及异常的考察
17.Cpp代码
1.int x = 999;
2.int countx = 0;
3.while(x){
4.countx++;
5.x=x&(x-1);
6.}
7.return countx;
---countx最终返回什么内容?
18.列举平常经常浏览的网站以及关注的技术。
19.简述三年的职业规划。
【面试】
前面的笔试已经看出多是考察的基本功,针对社招的有经验者面试官除了扫一遍考题外主要注重以往做过什么项目,用过什么技术,担当什么样的角色,是否 积累了相关行业的从业经验。个人感觉人人比较看重求职者的综合素质和技能,最好什么都会并对互联网行业工作性质比较适应这样基本就能进门了,如果再对分布 式、缓存与服务器集群,负载均衡有实践经验就有资本要价了。如果通过了技术面试官的筛选,接下来更高级别的面试官主要对个人未来的职业规划比较关注,他们 希望了解求职者对互联网、SNS、人人网有怎么样的认知并相对性地有怎样的职业规划,这一般需要互联网行业的实际工作经验才能回答好,我就是因为缺乏对互 联网行业的认知所以回答的不很到位,比较可惜。
【其他】
实话实说千橡的办公环境、休息区都还是挺不错的,和不同级别的面试官聊后也感觉工作氛围是比较开放的,唯一不能避免的就是行业造成的加班(不过通常 也不严重,平均7点半)。特别要说的是面试作为一场博弈有不少细节还是要注意,求职者与面试官其实都是为了同一个目的坐在一起,所以交谈中会不由自主地往 对方靠,比较显而易见的例子就是面试官对求职者的启发,同时面试官也是普通的人,细心的求职者可以通过所掌握的信息迎合他的喜好,这点不好多说,总之就是 要做到细心观察、多交互、恰当应对。
第二篇:Java开发工程师笔试题
Java开发工程师笔试题
一、单项选择题(每题2分,共计30分)
1.下列哪一种叙述是正确的(A).abstract修饰符可修饰字段、方法和类
(B).抽象方法的body部分必须用一对大括号{}包住
(C).声明抽象方法,大括号可有可无
(D).声明抽象方法不可写出大括号
2.如下代码
public class Test {
public int aMethod(){
static int i = 0;
i++;
return i;
}
public static void main(String args[]){
Test test = new Test();
test.aMethod();
int j = test.aMethod();
System.out.println(j);
}
}
输出结果是什么?
(A).0
(B).1
(C).2
(D).编译失败
3.以下代码的输出结果是()?
public class Test1{
public static void main(String[] args){int i = 42;
String s =(i < 40)? “life” :(i > 50)? “universe” : “everything”;System.out.println(s);
}
}
(A).life
(B).universe
(C).everything
(D).以上答案都不对。
4.当你编译和运行下面的代码时,会出现下面选项中的哪种情况?
public class Test{
static boolean paddy;
public static void main(String[] args){
System.out.println(paddy);
}
}
(A).编译时出错
(B).编译通过并输出结果false
(C).编译通过并输出结果true
(D).编译通过并输出结果null
5.如下代码:
class Base {
public Base(){
System.out.print(“Base”);
}
}
public class Alpha extends Base {
public static void main(String[] args){
new Alpha();
new Base();
}
}
结果是什么?
(A).Base
(B).BaseBase
(C).编译失败.(D).代码运行但没有输出.(E).运行时抛出异常
6.如下代码:
public class Foo {
public static void main(String[] args){
try {
return;
} finally {
System.out.println(“Finally”);
}
}
}
输出结果是什么?
(A).Finally
(B).编译失败
(C).代码正常运行但没有任何输出.(D).运行时抛出异常
7.下列关于构造方法的叙述中,错误的是()
(A).Java语言规定构造方法名与类名必须相同
(B).Java语言规定构造方法没有返回值,但不用vold声明
(C).Java语言规定构造方法不可以重载
(D).Java语言规定构造方法只能通过new自动调用
8.构造函数何时被调用()
(A).类定义时
(B).创建对象时
(C).调用对象方法时
(D).使用对象的变量时
9.JDBC中,用于表示数据库连接的对象是:
(A).Statement
(B).Connection
(C).DriverManager
(D).PreparedStatement
10.需要读一个比较大的文本文件,这个文件里有很多字节数据,那么下列最合适读这
类文件的选项是哪一个?
(A).new FileInputStream(“myfile.txt”);
(B).new InputStreamReader(new FileInputStream(“myfile.txt”));
(C).new BufferedReader(new InputStreamReader(new FileInputStream(“myfile.txt”)));
(D).RandomAccessFile raf = new RandomAccessFile(“myfile.txt”, “+rw”);
11.在List,Map,Set等接口中,不能包含重复元素的接口是哪一个?
(A).List
(B).Map
(C).Set
(D).都不是
12.有如下程序:
1.classTest4{
2.public static void main(String []args){
3.boolean x=;
4.boolean y=false;
5.short z=42;
6.7.if((z++==42)&&(y=true))z++;8.if((x=false)||(++z==45))z++;9. 10.System.out.println(“z=”+z);11.} 12.} 结果为:
(A).44
(B).45
(C).46
(D).编译出错
13.有如下程序
11.public class Test {
12.public static void main(String [] args){
13.int x =5;
14.boolean b1 = true;
15.boolean b2 = false;
16.17.if((x==4)&&!b2)
18.System.out.print(“l ”);
19.System.out.print(“2 ”);
20.if((b2 = true)&& b1)
21.System.out.print(“3”);
22.}
23.}
运行的结果为:
(A).2
(B).3
(C).1 2
(D).2 3
(E).1 2 3
(F).编译错误
(G).抛出一个运行时异常
14.以下语句有语法错的是:
(A).int x=1;y=2;z=3
(B).for(int x=10,y=0;x>0;x++);
(C).while(x>5);
(D).for(;;);
15.下面有关类 Demo 的描述正确的有()
public class Demo extends Base{
private int count;
public Demo(){
System.out.println(“A Demo object has been created”);
}
protected void assone(){
count++;
}
}
(A).当创建一个 Demo 类的实例对象时,count 的值为 0
(B).当创建一个 Demo 类的实例对象时,count 的值是不确定的(C).Base 类型的对象中可以包含改变 count 值的方法
(D).Demo 的子类对象可以访问 count
二、1.2.3.4.5.问答题(每题5分,共计25分)String是最基本的数据类型吗? String 和StringBuffer的区别? Java中的“==”和equals()方法有什么区别? 描述一下JSP中转发和重定向的区别? 请说出作用域public,private,protected,以及不写时的区别? List, Set, Map是否继承自Collection接口?分别说出它们的特点?
三、编程题(每题15分,共计45分)
1.已知有一个数列:f(0)= 1,f(1)= 4,f(n+2)=2*f(n+1)+ f(n),其中n是大于0的整数,求f(10)的值。
2.写一个算法对1,8,5,2,4,9,7进行顺序排列。
3.使用输入输出流的API实现文件拷贝功能。
第三篇:JAVA工程师笔试题
一、选择题
1.Java中提供了名为()的包装类来包装原始字符串类型。A.Integer B.Char C.Double D.String
2.java.lang包的()方法比较两个对象是否相等,相等返回true。A.toString()B.equals()C.compare()
D.以上所有选项都不正确
3.下面的集合中,()不可以存储重复元素。A.Set B.Collection C.Map D.List 4.Java接口的修饰符可以为()
A private B protected C final D abstract
5.下面哪些是Thread类的方法()
A start()B run()C exit()D getPriority()
6.下面关于java.lang.Exception类的说法正确的是()
A 继承自Throwable B Serialable C集成自Error D以上都不正确
7.下面程序的运行结果:()
public static void main(String[] args){ // TODO Auto-generated method stub Thread t = new Thread(){ public void run(){ pong();} };t.run();System.out.print(“ping”);} static void pong(){ System.out.print(“pong”);}
A pingpong B pongping C pingpong和pongping都有可能 D 都不输出
8.下面哪个流类属于面向字符的输入流()A BufferedWriter B FileInputStream C ObjectInputStream D InputStreamReader
9.ArrayList list = new ArrayList(20);中的list扩充几次()
A 0 B 1 C 2 D 3
二、问答题
1.String与StringBuffer的区别?
2.谈谈final、finally、finalize的区别?
3.创建一个对象的方法有哪些?
4.编写一个程序,产生ArrayIndexOutOfBoundsException异常,并捕获该异常,在控制台输出异常信息。
5.写一个线程安全的Singleton实例
6.请用JAVA代码实现拷贝一个大于2G的文件到其他盘。
7.设计四个线程,其中两个线程每次对变量i加1,另外两个线程每次对i减1.8.自己编写代码,实现生产者-消费者模型功能.内容自由发挥,只需要表达思想.9.在Mysql中,请用一条SQL语句将现有的三条记录复制一下,达到以下的效果: ID name pass
aaa 111
bbb 222
ccc 333
aaa 111
bbb 222
ccc 333
10.用SQL语句删除上一题的重复记录.。
第四篇:软件开发工程师(JAVA)笔试题A
JAVA笔试题
软件开发工程师(JAVA)笔试题
请在90分钟以内做答 答案请写在答题纸上
一、选择题
1、下面哪项是不合法的标识符:(c e)A.$persons B.TwoUsers C.*point D._endline E.final
2、下列运算符合法的是(a)
A.&& B.<> C.if D.:=
3、下面描述中哪两项相等:(bg)[选择两项] A.<%= YoshiBean.size%> B.<%= YoshiBean.getSize()%> C.<%= YoshiBean.getProperty(“size”)%>
D.
4、设float x = 1,y = 2,z = 3,则表达式 y+=z--/++x的值是:(a)A.3.5 B.3 C.4 D.5 A.equals()方法判定引用值是否指向同一对象 B.==操作符判定两个不同的对象的内容和类型是否一致 C.equal()方法只有在两个对象的内容一致时返回true D.类File重写方法equals()在两个不同的对象的内容和类型一致时返回true
6、如果一个对象仅仅声明实现了cloneable接口,但是不声明clone方法,外部能够调用其clone方法吗?(b)A.能 B.不能 C.不确定
7、下列说法错误的有(bd)
A. 能被java.exe成功运行的java class文件必须有main()方法
B. J2SDK就是Java API
C. Appletviewer.exe可利用jar选项运行.jar文件
D. 能被Appletviewer成功运行的java class文件必须有main()方法
8、下列正确的有(acd)
A. call by value不会改变实际参数的数值
B. call by reference能改变实际参数的参考地址
C. call by reference不能改变实际参数的参考地址
D. call by reference能改变实际参数的内容
9、下列说法错误的有(bcd)
A. 数组是一种对象
B. 数组属于一种原生类
C. int number=[]={31,23,33,43,35,63}
5、下面的哪些叙述为真:(d)
D. 数组的大小可以任意改变
10、不能用来修饰interface的有(ad)
JAVA笔试题
A.private B.public C.protected D.static
11、关于Float,下列说法正确的是(a)
A.Float是一个类 B.Float在java.lang包中 C.Float a=1.0是正确的赋值方法
D.Float a= new Float(1.0)是正确的赋值方法
12、下列哪种说法是正确的(d)
A. 实例方法可直接调用超类的实例方法
B. 实例方法可直接调用超类的类方法
C. 实例方法可直接调用其他类的实例方法
D. 实例方法可直接调用本类的类方法
13、下列说法错误的有(c)
A.在类方法中可用this来调用本类的类方法
B.在类方法中调用本类的类方法时可直接调用
C.在类方法中只能调用本类中的类方法
D.在类方法中绝对不能调用实例方法
14、下面说法哪些是正确的? bd
A.Applet可以访问本地文件
B.对static方法的调用不需要类实例 C.socket类在java.lang中 D.127.0.0.1地址代表本机 1.public class Test1 { 2.public float aMethod(float a, float b)throws 3.IOException { } 4.} 5.public class Test2 extends Test1 { 6.//Line6 7.} 将以下(ac)方法插入行6是不合法的。
A.float aMethod(float a, float b){} B.public int aMethod(int a, int b)throws Exception {} C.public float aMethod(float P, float q){} D.public int aMethod(int a, int b)throws IOException {}
16、关于以下程序段,正确的说法是:(b)
1.String s1 = “abc” + “def”;2.String s2 = new String(s1);3.if(s1.equals(s2))4.System.out.println(“.equals()succeeded”);5.if(s1 == s2)6.System.out.println(“== succeeded”);A.行4与行6都将执行 B.行4执行,行6不执行 ??
15、类Test1、Test2定义如下:
C.行6执行,行4不执行 D.行
4、行6都不执行
JAVA笔试题
17、下面程序的执行结果为:(a)
1.public class Test { 2.static Boolean foo(char c){ 3.System.out.println(c);4.return true;5.} 6.public static void main(String[] args){ 7.int i = 0;8.for(foo(‘A’);foo(‘B’)&&(i<2);foo(‘C’)){ 9.i++;10.foo(‘D’);11.} 12.} 13.} A.ABDCBDCB B.ABCDABCD C.Compilation fails C.An exception is thrown at runtime
18、阅读下面的程序
1.public class Outer { 2.public void someOuterMethod(){ 3.//Line3 4.} 5.public class Inner(){} 6.public static void main(String[] args){ 7.Outer o = new Outer();8.//Line8 9.} 10.} Which instantiates is an instance of Inner?(c)
A.new Inner();// At line3 B.new Inner();// At line 8 C.new o.Inner();// At line 8 C.new Outer.inner();// At line 8
19、选出能正确赋值的: public class TestA { private int a;return m;public int change(int m){
} } public class TestB extend TestA{ public int b;public static void main(){ TestA aa = new TestA();int k;
TestB bb = new TestB();
} } 在Line13处可以正确赋值的有:(d)// Line 13
JAVA笔试题
A.k= m;B.k=b;C.k=aa.a;D.k=bb.change(30);E.k=bb.a 20、已知如下代码: switch(m){ case 0: System.out.println(“Condition 0”);case 1: System.out.println(“Condition 1”);case 2: System.out.println(“Condition 2”);case 3: System.out.println(“Condition 3”);break;default: System.out.println(“Other Condition”);} 当 m 的值为什么时输出 “Condition 2”?(abc)A.0 B.1 C.2 D.3 E.4 F.None
21、给出程序段
public class Parent { public int addValue(int a,int b){ int s;s=a+b;return s;} } class Child extends Parent{} 可以加在Child类的方法有:(cd)A.int addValue(int a,int b){} B.public void addValue(int a,int b){} C.public int addValue(int a){} D.public int addValue(int a,int b){}
22、下述哪些说法是正确的?(d)A.实例变量是类的成员变量
B.实例变量是用static关键字声明的 C.方法变量在方法执行时创建 D.方法变量在使用之前必须初始化
23、对于下列代码:
public class Sample{
long length;
public Sample(long l){ length = l;}
public static void main(String arg[]){
Sample s1, s2, s3;
s1 = new Sample(21L);
s2 = new Sample(21L);
s3 = s2;
long m = 21L;
} } 下列哪些表达式返回值为'true'?(d)
JAVA笔试题
A.s1 = = s2;B.s2 = = s3;C.m = = s1;D.s1.equals(m)
26、当 Frame 改变大小时,放在其中的按钮大小不变,则使用如下哪个 layout?(e)A.FlowLayout B.CardLayout C.North and South of BorderLayout D.East and West of BorderLayout E.GridLayout
27、已知如下的命令执行 java MyTest a b c 请问哪个语句是正确的?(cd)A.args[0] = “MyTest a b c” B.args[0] = “MyTest” C.args[0] = “a” D.args[1]= “b”
28、下面哪个语句是创建数组的正确语句?(ab)A.float f[][] = new float[6][6];B.float []f[] = new float[6][6];C.float f[][] = new float[][6];D.float [][]f = new float[6][6];E.float [][]f = new float[6][];30、以下关于数据库范式的描述,哪些是错误的(c)
A.如果把多个数据项用一个大的 String 表示为一个字段,则不满足
private String name;public String getName(){ return name;} public Ball(String name){ this.name = name;} public void play(){ ball = new Ball(“Football”);
JAVA笔试题
System.out.println(ball.getName());} } 上面代码是否有错,如果有错,错误在何处? 红处
2、详细解释下面的语句: Class.class.getClass()Class与class继承自Object,class试题来代表java运行时的class和interface等等 Class.class就是得到或者生成这个Class类的Class Object 而getClass()本身就是返回一个类对应的Class Object,所以最后Class.class.getClass()最后还是返回Class Object
7、编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。但是要保证汉字不被截半个,如“我ABC”4,应该截为“我AB”,输入“我ABC汉DEF”,应该输出为“我ABC”而不是“我ABC+汉的半个”。
public static boolean isLetter(char c){ int k=0X80;return c/k==0?true:false;}
public static int lengths(String strSrc){ if(strSrc==null){ return 0;} int len=0;char[] strChar=strSrc.toCharArray();for(int i=0;i JAVA笔试题 public static String subString(String origin,int len){ if(origin==null || origin.equals(“")|| len<1){ return ”“;} if(len>lengths(origin)){ return origin;} byte[] strByte=new byte[len];System.arraycopy(origin.getBytes(),0,strByte,0,len);int count=0;for(int i=0;i } public static void main(String[] args){ System.out.println(”“+ subString(”我ABC汉DEF",6));} 10、SQL问答题 表结构: 1、表名:g_cardapply 字段(字段名/类型/长度): g_applyno varchar 8: //申请单号(关键字)g_applydate bigint 8: //申请日期 g_state varchar 2: //申请状态 2、表名:g_cardapplydetail 字段(字段名/类型/长度): g_applyno varchar 8: //申请单号(关键字)g_name varchar 30: //申请人姓名 g_idcard varchar 18: //申请人身份证号 g_state varchar 2: //申请状态 其中,两个表的关联字为申请单号 题目: JAVA笔试题 1、查询身份证号码为***082的申请日期 2、查询同一个身份证号码有两条以上记录的身份证号码及记录个数 3、将身份证号码为***082的记录在两个表中的申请状态均改为07 4、删除g_cardapplydetail表中所有姓李的记录 1、select g_applydate from g_cardapply a,g_cardapplydetail b where a.g_applyno=b.g_applyno and b.g_idcard=’***082’ 2、select g_idcard,count(g_applyno)from g_cardapplydetail group by g_idcard having count(g_applyno)>2 3、update g_cardapply a,g_cardapplydetail b set a.g_state=’07’,b.g_state=’07’ where a.g_applyno=b.applyno and b.g_idcard=’ ***082’ 4、delete from g_cardapplydetail where g_name like ‘李%’ Java软件开发工程师笔试题 一、选择题(25 x 2’ = 50’) 1、一个Java程序运行从上到下的环境次序是() A. 操作系统、Java程序、JRE/JVM、硬件 B. JRE/JVM、Java程序、硬件、操作系统 C. Java程序、JRE/JVM、操作系统、硬件 D. Java程序、操作系统、JRE/JVM、硬件 2、下面代码中的第2行可以插入一行代码()保证程序编译通过。 1、public interface A{ 2、3、} A.void method();B.public void method();C.static void method();D.private void method();E.protected void method(); 3、关于异常下列描述中,错误的是() A.异常机制可以用于流程控制 B.finally代码段在发生异常时不一定必须执行 C.在catch代码段中可以使用return语句来返回到异常抛出点 D.可以把catch到的异常对象再次抛出,使上层try—catch结构继续处理该异常事件 4、关于被私有访问控制符private修饰的成员变量,以下说法正确的是() A. 可以被三种类所引用:该类自身、与它在同一个包中的其他类、在其他包中的该类的子类 B. 可以被两种类访问和引用:该类本身、该类的所有子类 C. 只能被该类自身所访问和修改 D. 只能被同一个包中的类访问 5、某类Example的main()方法参数为args,当命令行中输入Java Example cat时,args[0]的值为()。 A. cat B. Java C. example D. null 6、下面关于Thread类提供的现成控制方法的说法中,错误的是() A. 在线程A中执行现成B的join方法,则线程A等待直到线程B执行完成。B. 线程A通过调用iterrupt方法来中断其阻塞状态 C. 若线程A调用方法isAlive返回值为true,则说明A正在执行中 D. currentThread方法返回当前线程的引用 7、类Test1定义如下: 1.public class Test1{ 2. public float aMethod(float a,float b){ } 1/10 3.4.} 将以下哪种方法插入行3是不合法的。() A. public float aMethod(float a,float b,float c){ } B. public float aMethod(float c,float d){ } C. public int aMethod(int a,int b){ } D. private float aMethod(int a,int b,int c){ } 8、下面程序的输出结果是()private static void foo(){ try { System.out.println(“try”);foo();} catch(Throwable e){ System.out.println(“catch”);foo();} finally { System.out.println(“finally”);foo();} } public static void main(String[] args){ foo();} A.执行一段时间后报栈溢出。B.会一直输出“try”。 C.会一直输出“try”和“finally”。D.会一直输出“try”、“catch”和“finally” 9、下面的哪些程序片断可能导致错误?()A.String s = “Gone with the wind”;String t = “ good ”;String k = s + t; B.String s = “Gone with the wind”;String t;t = s[3] + “one”; C.String s = “Gone with the wind”;String standard = s.toUpperCase(); D.String s = “home directory”;String t = s-“directory”; 10、已知如下代码: 2/10 1: class Example{ 2: String str;3: public Example(){ 4: 5: } 6: public Example(String s){ 7: 8: } 9:} 10: class Demo extends Example{ 11: } 12: public class Test{ 13: public void f(){ 14: 15: 16: } } 哪句语句会导致错误?()A、line 3 B、line 6 C、line 10 D、line 14 E、line 15 11、下面的代码中第4行创建的对象在什么时候符合垃圾回收的条件() 1、class Bar { } 2、class Test { 3、Bar doBar(){ 4、Bar b = new Bar(); 5、return b; 6、} 7、public static void main(String args[]){ 8、Test t = new Test(); 9、Bar newBar = t.doBar();10、11、12、newBar = new Bar();} } Example ex = new Example(“Good”);Demo d = new Demo(“Good”);str=s;str= “example”;A.程序运行第9行之后。B.程序运行第10行之后。C.doBar方法运行结束之后。D.main方法运行结束之后。 12、下列关于for循环和while循环的说法中哪个是正确的?() A. while循环能实现的操作,for循环也都能实现 B. while循环判断条件一般是程序结果,for循环判断条件一般是非程序结果 3/10 C. 两种循环任何时候都可替换 D. 两种循环结构中都必须有循环体,循环体不能为空 13、下述说法中,错误的是()A.Java中,方法的重载是指多个方法可以共享同一个名字 B.Java中,用abstract修饰的类称为抽象类,它不能实例化 C.Java中,接口不包含成员变量和方法实现 D.Java中,构造方法可以有返回值 14、下面哪些是正确的() 11.class ClassA {} 22.ClassB p1 = new ClassB();23.ClassC p2 = new ClassC();24.ClassA p3 = new ClassB();25.ClassA p4 = new ClassC();12.class ClassB extends ClassA {} 13.class ClassC extends ClassA {} and: 21.ClassA p0 = new ClassA();A.p0 = p1; 15、以下代码片段,正确的结果是:() 11.classA { 17.throw new IOException(); 18.} } 19.public static void main(String[] args){ 20.try { new B().process();} 21.catch(IOException e){ 22.System.out.println(”Exception”);} } 12.public void process(){ System.out.print(”A,”);} } 13.class B extends A { 15.super.process();A.Exception B.A,B,Exception C.Compilation fails because of an error in line 20.D.Compilation fails because of an error in line 14.E.A NullPointerException is thrown at runtime.16、用直接插入排序方法对下面四个序列进行排序(由小到大),元素比较次数最少的是()。 A. 94,32,40,90,80,46,21,69 B. 32,40,21,46,69,94,90,80 C. 21,32,46,40,80,69,90,94 D. 90,69,80,46,21,32,94,40 17、设栈最大长度为3,入栈顺序为1,2,3,4,5,6,则不可能的出栈序列是() A.1,2,3,4,5,6 B.2,1,3,4,5,6 C.3,4,2,1,5,6 D.4,3,2,1,5,6 18、设有98个已排序列元素,采用二分法查找时,最大比较次数是() A.49 B.15 C.20 D.7 4/10 14.public void process()throws IOException { 16.System.out.print(”B,”);B.p1 =p2; C.p2 = p4; F.p2 =(ClassC)p4;D.p2 =(ClassC)p1;E.p1 =(ClassB)p3; 19、若一棵二叉树具有10个度为2的结点,5个度为1的结点,则度为0的结点个数是() A.9 B.11 C.15 D.不确定 20、以下与数据的存储结构无关的术语是()。 A.循环队列 B.链表 C.哈希表 D.栈 21、设数组A[10„100,20„100]以行优先的方式顺序存储,每个元素占4个字节,且已知A[10,20]的地址为 1000,则A[50,90]的地址是() A.13240 B.14250 C.24220 D.14240 22、链表不具有的特点是() A.插入、删除不需要移动元素 B.可随机访问任一元素 C.不必事先估计存储空间 D.所需空间与线性长度成正比 23、下面关于线性表的叙述中,错误的是哪一个?() A.线性表采用顺序存储,必须占用一片连续的存储单元。B.线性表采用顺序存储,便于进行插入和删除操作。C.线性表采用链接存储,不必占用一片连续的存储单元。D.线性表采用链接存储,便于插入和删除操作。 24、若一个栈的输入序列为1,2,3,„,n,输出序列的第一个元素是i,则第j个输出元素是()。A.i-j-1 B.i-j C.j-i+1 D.不确定的 25、下列说法不正确的是()。 A.图的遍历是从给定的源点出发每一个顶点仅被访问一次 B.图的深度遍历不适用于有向图 C.遍历的基本算法有两种:深度遍历和广度遍历 D.图的深度遍历是一个递归过程 二、程序改错(5 * 2’ = 10’)1.----public class Unbelievable { static Integer i;public static void main(String[] args){ } } if(i == 42)System.out.println(“Unbelievable”);2.—————————————————————————————————— class Animal { public String noise(){ 5/10 龙通科技有限公司笔试题 } class Dog extends Animal { } class Cat extends Animal { } public class Test { } public static void main(String[] args){ } Animal animal = new Dog();Cat cat =(Cat)animal;cat.noise();public String noise(){ } return “meow”;public String noise(){ } return “bark”;} return “peep”;3.—————————————————————————————————————— abstract class Something { } private abstract String doSomething();4.—————————————————————————————————————— public class Something { } class Other { } public int i;public static void main(String[] args){ } public void addOne(final Other o){ } o.i++;Other o = new Other();new Something().addOne(o);5.—————————————————————————————————————— class Something { final int i;public void doSomething(){ System.out.println(“i = ” + i);6 龙通科技有限公司笔试题 } } 三、程序阅读题(每空2’,共 40’) 1、阅读以下java代码,写出运行结果 class StaticTest { } 2、编写将一维数组a[]中互不相同的数按从小到大顺序重新存于一维数组a[]的程序。 class A{ public static void main(String[] args){ } for(j=0;j } System.out.prinln(a[j]);int a[]={15,7,15,6,4,3,4,6,7};int i,j,k,low,high,mid,t;for(i=k=1;i static int x=1;int y;StaticTest(){ } public static void main(String args[ ]){ StaticTest st=new StaticTest();System.out.println(“x=” + x);System.out.println(“st.y=” + st.y);st=new StaticTest();System.out.println(“st.y=” + st.y); } static { x++;} y++; 龙通科技有限公司笔试题 } 3、请用JAVA编写如下程序:此程序处理一个由0和非0数字成员组成的数组(长度自定),例如0 0 1 2 0 1 0 0 0 1 0 0 0 0 0 2 0 7 8 9 0 0 1 2 3 4,把数组中所有连续两个以上的0去掉,将结果存入一个新数组。如上例处理后结果为,1 2 0 1 1 2 0 7 8 9 1 2 3 4。public static void main(String[] args){ int[] srcArray = {0,0,1,2,0,1,0,0,0,1,0,0,0,0,0,2,0,7,8,9,0,0,1,2,3,4};int[] destArray = new int[50];int i=0,j=0,count=0;for(i=0;i } } for(i=0;i public static void main(String[] args){ } public static int Keeper(int peo, int n){ int k = 0;int peo;System.out.println(“请输入人数:”);Scanner inp = new Scanner(System.in);peo = inp.nextInt();int k = Keeper(peo, 3);System.out.println(“最后留下的是 ” + k + “ 号!”); 4、有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,再从他的下一 8 龙通科技有限公司笔试题 int[] array = new int[peo];for(int i = 1;i < peo;i++){ } for(k = 0;k < peo;k++){ } return k + 1;if(array[k] == 0){ } 4 ; ○int j = 1;while(j <= n){ } if(○1){ } if(j == n){ } j++;3 ; ○ ; ○j--; } } 5、在一个n×n的棋盘上,放置n个不能互相捕捉的国际象棋“皇后”的所有布局。以下是n皇后的算法,请完成填空部分: public class Queen { Queen(int d){ } // 放置皇后的方法 public void place(int row){ int i = 0;if(row == n){ 1 ; ○n = d;queenPos = new int[d];private int n;private int[] queenPos;private double num = 0;// 记录共有多少种摆法 } else { 9 龙通科技有限公司笔试题 } // 判断布局是否合法 private boolean legality(int list){ } // 测试方法 public static void main(String[] args){ }} System.out.println(“输入个数n:”);Scanner in = new Scanner(System.in);int n = in.nextInt();try { } Queen q = new Queen(n);q.place(0);System.out.println(n + “*” + n + “时,” + “共有” + q.num + “种可能摆法。”);System.out.println(“OK!”);e.printStackTrace();if(list == 0) } return true;return true;if(queenPos[i] == queenPos[list])3 ; ○for(int i = 0;i < list;i++){ } for(i = 0;i < n;i++){ } queenPos[row] = i;if(legality(row)); ○if(○4)return false;} catch(Exception e){ 10第五篇:Java软件开发工程师笔试题