java面试题集.pdf
《java面试题集.pdf》由会员分享,可在线阅读,更多相关《java面试题集.pdf(72页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、基础知识:1.C+或 J a v a 中的异常处理机制的简单原理和应用。当 J AVA程序违反了 J AVA的语义规则时,J AVA虚拟机就会将发生的错误表示为一个异常。违反语义规则包括2 种情况。一种是JA V A 类库内置的语义检查。例如数组下标越界,会 引 发 IndexO utO fB oundsE xception;访 问 n u l l 的 对 象 时 会 引 发NullPo in ter Except ion 另一种情况就是J AVA允许程序员扩展这种语义检查,程序员可以创建自己的异常,并自由选择在何时用th r o w 关键字引发异常。所有的异常都是java.lang.Th o
2、wable 的子类。2 .J a v a 的接口和C+的虚类的相同和不同处。由于J a v a 不支持多继承,而有可能某个类或对象要使用分别在几个类或对象里面的方法或属性,现有的单继承机制就不能满足要求。与继承相比,接口有更高的灵活性,因为接口中没有任何实现代码。当一个类实现了接口以后,该类要实现接口里面所有的方法和属性,并且接口里面的属性在默认状态下面都是public static,所有方法默认情况下是public.一个类可以实现多个接口。3.垃圾回收的优点和原理。并考虑2 种回收机制。J a v a 语言中一个显著的特点就是引入了垃圾回收机制,使 C+程序员最头疼的内存管理的问题迎刃而解,
3、它使得J a v a 程序员在编写程序的时候不再需要考虑内存管理。由于有个垃圾回收机制,J a v a 中的对象不再有“作用域”的概念,只有对象的引用才有“作用域”。垃圾回收可以有效的防止内存泄露,有效的使用可以使用的内存。垃圾回收器通常是作为一个单独的低级别的线程运行,不可预知的情况下对内存堆中已经死亡的或者长时间没有使用的对象进行清楚和回收,程序员不能实时的调用垃圾回收器对某个对象或所有对象进行垃圾回收。回收机制有分代复制垃圾回收和标记垃圾回收,增量垃圾回收。4 .请说出你所知道的线程同步的方法。w ait():使一个线程处于等待状态,并且释放所持有的对象的lock,sleep。:使一个正
4、在运行的线程处于睡眠状态,是一个静态方法,调用此方法要捕捉InterruptedE xception 异常。notifyO:唤醒一个处于等待状态的线程,注意的是在调用此方法的时候,并不能确切的唤醒某一个等待状态的线程,而是由JV M 确定唤醒哪个线程,而且不是按优先级。A llnotityO:唤醒所有处入等待状态的线程,注意并不是给所有唤醒线程一个对象的锁,而是让它们竞争。5.请讲一讲析构函数和虚函数的用法和作用。6 .E r ro r 与 E x cep tio n有什么区别?E rro r表示系统级的错误和程序不必处理的异常,E x cep tio n表示需要捕捉或者需要程序进行处理的异常
5、。7.在 ja v a 中一个类被声明为fin a l类型,表示了什么意思?表示该类不能被继承,是顶级类。8 .描述一下你最常用的编程风格。9 .h e a p 和 sta c k 有什么区别。栈是一种线形集合,其添加和删除元素的操作应在同一段完成。栈按照后进先出的方式进行处理。堆是栈的一个组成元素10.如果系统要使用超大整数(超过lo n g 长度范围),请你设计一个数据结构来存储这种超大型数字以及设计一种算法来实现超大整数加法运算)。public class B igint()int ArrO ne=new ArrO ne 1000;String intString=nM;public i
6、nt A rr(String s)in tStr in g=s;fo r(int i=0;i 0);/th rows an A ssertion erro r if a float A flo at f=3.4 是否正确?答:不正确。精度不准确,应该用强制类型转换,如下所示:float f=(float)3.46 1、介绍J AVA中的Collection Fr am eW ork(包括如何写自己的数据结构)?答:Collection Fram eW ork 如下:Collection卜 Li st|pLinkedListI pArrayList|LVector|LStackLSetMappH
7、 ash tablepH ash MapLW eakH ashM apC ollection是最基本的集合接口,一个C ollection代表一组O b je c t,即 C o llectio n的元 素(Elem en ts)M ap 提供k e y 到 v a lu e 的映射6 2、J a v a 中异常处理机制,事件机制?11、JA V A 中的多形与继承?希望大家补上,谢谢6 3、抽象类与接口?答:抽象类与接口都用于抽象,但是抽象类(JA V A 中)可以有自己的部分实现,而接口则完全是一个标识(同时有多重继承的功能)o编程题:1.现在输入n 个数字,以逗号,分开;然后可选择升或者
8、降序排序;按提交键就在另一页面显示按什么排序,结果为,提供reset答 案(1)public static String splitStringByCom m a(String source)if(source=nu 1 1 1 I source.trim ().equals r)return nu 11;StringTokenizer com m aToker=newStringToken izer(source,M,H);String resuIt=new Stringcom m aT oker.countT okens()l;in t i=0;w hile(com m aT oker.h
9、asM oreT okens()resu lti=com m aT oker.nextT oken();i+;)return resuIt;)循环遍历S trin g 数组In teger.parsein t(String s)变成 int 类型组 成 in t 数组A rrays.sort(int a),a 数组升序降序可以从尾部开始输出2.金额转换,阿拉伯数字的金额转换成中国传统的形式如:(Y 1 0 1 1)-(一千零一拾一元整)输出。3、继承时候类的执行顺序问题,一般都是选择题,问你将会打印出什么?答:父类:package test;public class FatherC Iassp
10、ublic FatherC lass()System.ou t.pr in tin(Fath er Class C reate1);子类:package test;im port test.FatherC lass;public class ChildClass extends FatherC lass(public ChildClass()(System.out.pr in tin(Ch ildClass Create*);)public static void m ain(String args)(FatherC lass fc=new FatherC lass();ChildClass
11、cc=new ChildClass();)输出结果:C:java test.ChildC lassFatherC lass CreateFatherC lass CreateChildClass Create4、内部类的实现方式?答:示例代码如下:package test;public class O uterC lass(private class In terClass(public InterC lass()(System.ou t.pr in tin(In terC lass C reate);)public O uterC lass()(InterC lass ic=new Inte
12、rC lass();System.ou t.pr in tin(M Ou ter Class C reate);)public static void m ain(String args)Ou terClass oc=new Ou terC lass();输出结果:C:java test/O uterC lassInterC lass CreateOu terClass Create再一个例题:public class Ou terC lass private dou ble d 1 =1.0;/in sert code here)You need to insert an inner cla
13、ss declaration at line 3.W hich two inner classdeclarations arevalid?(Choose two.)A.class In n er On e public static double m ethoda()return d 1;)B.public class In n erO n estatic double m ethoda()return d 1;)C.private class InnerO nedouble m ethoda()return d 1;D.static class In n erO n eprotected d
14、ouble m ethoda()return d 1;)E.abstract class In nerO ne public abstract double m ethoda();)说明如下:一.静态内部类可以有静态成员,而非静态内部类则不能有静态成员。故 A、B 错二.静态内部类的非静态成员可以访问外部类的静态变量,而不可访问外部类的非静态变量;return d 1 出错。故 D 错三.非静态内部类的非静态成员可以访问外部类的非静态变量。故 C 正确四.答案为C、E5、J a v a 的通信编程,编程题(或问答),用 JAVA SOCKET编程,读服务器几个字符,再写入本地显示?答:S e
15、rv er端程序:package test;im port .*;im port java.io.*;public class Serverprivate Ser ver Socket ss;private Socket socket;private B ufferedR eader in;private P rintW riter out;pu blic Ser ver()(try(ss=new ServerSocket(lOOOO);w hile(true)(socket=ss.accept();String R em otelP=socket.getlnetA ddress().getH
16、 ostA ddress();String R em otePort=,:H+socket.getL ocalPort();System.ou t.pr in tin(A client com e in!IP:M+R em oteIP+Rem oteP ort);in=new B ufferedR eader(newInputS tream R eader(socket.getInputS tream();String line=in.readL ine();System.ou t.pr in tin(Cie in t send is+lin e);ou t=new Pr in tW r it
17、er(socket.get Ou tputS tream(),true);out.println(Y our M essage Received!H);ou t.close();in.close();socket.close();)Jcatch(lO Exception e)(out.prin tin(w rong);)public static void m ain(String args)(new Server(););C lien t端程序:package test;im port java.io.*;im port .*;public class ClientSocket socket
18、;B ufferedR eader in;P rintW riter out;public Client()(try(System.ou t.pr in tin(Try to Con nect to 127.0.0.1:10000);socket=new Socket(n127.0.0.r,10000);System.ou t.pr in tin(The Server Connected!n);System.ou t.pr in tin(Please enter som e C haracter:);B ufferedR eader line=new B ufferedR eader(newI
19、nputS tream R eader(S ystem.in);out=new P rintW riter(socket.getO utputS tream (),true);ou t.pri n tin(line.read Li ne();in=new B ufferedR eader(newInputS tream R eader(socket.getInputS tream();System.out.println(in.readL ine();out.close();in.close();socket.close();catch(lO Exception e)out.prin tin(
20、W rong);)public static void m ain(String args)(new Client(););6、用 JA V A 实现一种排序,JA V A 类实现序列化的方法(二种)?如 在 COLLECTION框架中,实现比较要实现什么样的接口?答:用插入法进行排序代码如下package test;im port java.util.*;class InsertS ort(ArrayList al;pu blic InsertS ort(int n u m,in t m od)(a 1 =new A rrayList(num );Random rand=new Random
21、 ();System.ou t.pr in tin(The Arr ayList Sort B efore:);for(int i=0;in u m;i+)(al.add(new Integer(M ath.abs(rand.nextInt()%m od+1);System.ou t.pr in tin(al+i+=u+al.get(i);)public void Sortlt()(Integer tem pin t;int M axSize=1;for(int i=l;i=(In teger)al.get(M axSize-l).in tValu e()(al.add(M axSize,te
22、m pint);MaxSize+;S ystem.out.println(al.toS tringO);else for(in t j=0;j =tem pInt.intV alue()(al.add(j,tem pint);MaxSize+;System.ou t.pr in tin(al.toStringO);break;System.o u t.p rin tln(MThe A rrayList Sort A fter:);for(int i=0;ial.size();i+)(System.o u t.p rin tln(nal+i+=u+al.get(i);)pu blic stati
23、c void m ain(Strin g args)(InsertS ort is=new InsertSort(10,100);is.Sor tlt();JA V A 类实现序例化的方法是实现java.io.S erializable接口C ollection框架中实现比较要实现Com p a ra b le 接 口 和 Com p a r a to r 接口7、编程:编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。但是要保证汉字不被截半个,如“我 ABC”4,应该截为“我 AB”,输 入“我ABC汉 DEF”,6,应该输出为“我 ABC”而 不 是“我 ABC
24、+汉的半个”。答:代码如下:package test;class SplitString(String SplitStr;int SplitByte;public SplitString(String str,int bytes)(SplitStr=str;SplitByte=bytes;System.ou t.pr in tin(M The String is:,”+Split S tr+;SplitBytes=+Split Byte);)public void Splitlt()int loopC ount;loopCou nt=(SplitStr.length()%SplitByte=O
25、 )?(SplitStr.length()/Split B yte):(SplitStr.length()/SplitByte+1);System.ou t.pr in tin(*W ill Split in to +loopC ount);for(int i=l;i=loopCount;i+)(if(i=loopCoun t)System.out.printin(SplitStr.sub str in g(i-l)*Sp lit Byte,SplitStr.length();else System.ou t.pr in tin(SplitStr.substrin g(i-1)*S p lit
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- java 试题
限制150内