欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    java软件工程面试题集锦.pdf

    • 资源ID:90893289       资源大小:14.10MB        全文页数:134页
    • 资源格式: PDF        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    java软件工程面试题集锦.pdf

    面试题集面试题集共分为以下十部分:一、Core Java:1 一 95 题 1 一 24 页基础及语法:1 6 1 题 1 1 3 页异常:62 6 9 题 13 1 5 页集合:70 8 0 题 15 1 8 页线程:81 9 0 题 18 2 1 页10&Socket:91 95 题 21 24 页二、00AD&UML:96 一 101 题 24 25 页三、XML:102 105 题 26 29 页四、SQL:106 109 题 29 31 页五、JDBC&Hibernate:110 一 121 题 31 35 页六、Web:122 161 题 35 44 页七、EJB&Spring:162 179 题 44 47 页八、数据结构&算法&计算机基础:180 187题 47 5 1 页九、C+:188 201 题 51 55 页十、Weblogic及其它(附加部分)1 1 3 题 55 5 7 页一、CoreJava部分:(共 9 5 题:基础9 1 道,中等难度4 道)基础及语法部分:(共 6 1 题:基础6 0 道、中等难度1 道)1、面向对象的特征有哪些方面?【基础】答:面向对象的特征主要有以下儿个方面:1)抽象:抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面。抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节。抽象包括两个方面,一是过程抽象,二是数据抽象。2)继承:继承是一种联结类的层次模型,并且允许和鼓励类的重用,它提供了一种明确表述共性的方法。对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以修改或增加新的方法使之更适合特殊的需要。3)封装:封装是把过程和数据包围起来,对数据的访问只能通过已定义的界面。面向对象计算始于这个基本概念,即现实世界可以被描绘成一系列完全自治、封装的对象,这些对象通过一个受保护的接口访问其他对象。4)多态性:多态性是指允许不同类的对象对同一消息作出响应。多态性包括参数化多态性和包含多态性。多态性语言具有灵活、抽象、行为共享、代码共享的优势,很好的解决了应用程序函数同名问题。2、作用域public,private,protected,以及不写时的区别?【基础】答:区别如下:作用域当前类 同包子孙类 其他public V V V Vprotected V V V Xdefault V V X Xprivate V X X X不写时默认为defaulto3、String是最基本的数据类型吗?【基础】答:不是。4、flo a t型floatf=3.4是否正确?【基础】答:不正确;精度不准确,应该用强制类型转换,如下所示:floatf=(float)3.4 o5、语句floatf=:L3;编译能否通过?【基础】答:不能;应该用强制类型转换,如下所示:floatf=(float)1.3;。6、short si=1;si=si+1;有什么错?short si=1;s i+=1;有 什 么错?【基础】答:5死心1=1;51=51+1;$1+1运算结果是屁型,需要强制转换类型;short si=1;si+=1;可以正确编译,自动类型提升。7、Java有没有got。?【基础】答:g o to是ja v a中的保留字,现在没有在ja v a中使用。8 in t和Integer有什么区别?【基础】答:Java提供两种不同的类型:引用类型和原始类型(或内置类型);in t是ja v a的原始数据类型,Integer是ja v a为in t提供的封装类。Java为每个原始类型提供了封装类:原始类型:boolean,char,byte,short,int,long,float,double封装类型:Boolean,Character,Byte,Short,Integer,Long,Float,Double引用类型和原始类型的行为完全不同,并且它们具有不同的语义。引用类型和原始类型具有不同的特征和用法,它们包括:大小和速度问题,这种类型以哪种类型的数据结构存储,当引用类型和原始类型用作某个类的实例数据时所指定的缺省值。对象引用实例变量的缺省值为 n u ll,而原始类型实例变量的缺省值与它们的类型有关。9、&和&的区别?【基础】答:&是位运算符,表示按位与运算,&是逻辑运算符,表示逻辑与(and)o10、简述逻辑操作(&,/)与条件操作(&,|)的区别?【基础】答:区别主要有两点:a.条件操作只能操作布尔型的,而逻辑操作不仅可以操作布尔型,而且可以操作数值型b.逻辑操作不会产生短路。11、heap和 stack有什么区别?【基础】答:栈是一种线形集合,其添加和删除元素的操作应在同一段完成,栈按照后进先出的方式进行处理;堆是栈的一个组成元素。第 3 页共5 9 页12、Math.round(11.5)等于多少?Math.round(-11.5)等于多少?【基础】答:Math.round(11.5)=12 Math.round(-11.5)=-ll round 方法返回与参数最接近的长整数,参数加V 2 后求其floor。13、sw tich是否能作用在byte上,是否能作用在long上,是否能作用在String?【基础】答:switch(e x p rl)中,e x p rl是一个整数表达式。因此传递给switch和 case语句的参数应该是int、short char或者byte。long,string都不能作用于 swtich o14、编程题:用最有效率的方法算出2乘以8等於儿?【基础】答:2 abstract的 method是否可同时是static,是否可同时是native,是否可同时是synchronized?【基础】答:都不能。33、静态变量和实例变量的区别?【基础】答:静态变量也称为类变量,归全类共有,它不依赖于某个对象,可通过类名直接访问;而实例变量必须依存于某一实例,只能通过对象才能访问到它。34、是否可以从一个static方法内部发出对非static方法的调用?【基础】答:不可以,如果其中包含对象的m ethod(),不能保证对象初始化。35、写 clone。方法时,通常都有一行代码,是什么?【基础】答:Clone有缺省行为:super.clone(),他负责产生正确大小的空间,并逐位复制。36、G C 是什么?为什么要有G C?【基础】答:G C 是垃圾收集的意思(Gabage Collection),内存处理是编程人员容易出现问题的地方,忘记或者错误的内存回收会导致程序或系统的不稳定甚至崩溃,Java提 供 的 G C 功能可以自动监测对象是否超过作用域从而达到自动回收内存的目的,Java语言没有提供释放已分配内存的显示操作方法。Java程序员不用担心内存管理,因为垃圾收集器会自动进行管理。要请求垃圾收集,可以调用下面的方法之一:System.gc()或 Runtime.getRuntime().gc()。37、垃圾回收的优点和原理。并考虑2 种回收机制。【基础】答:Java语言中一个显著的特点就是引入了垃圾回收机制,使 C+程序员最头疼的内存管理的问题迎刃而解,它 使 得 Java程序员在编写程序的时候不再需要考虑内存管理。由于有个垃圾回收机制,Ja v a 中的对象不再有“作用域”的概念,只有对象的引用才有“作用域”。垃圾回收可以有效的防止内存泄露,有效的使用可以使用的内存。垃圾回收器通常是作为一个单独的低级别的线程运行,不可预知的情况下对内存堆中已经死亡的或者长时间没有使用的对象进行清楚和回收,程序员不能实时的调用垃圾回收器对某个对象或所有对象进行垃圾回收。回收机制有分代复制垃圾回收和标记垃圾回收,增量垃圾回收。38、垃圾回收器的基本原理是什么?垃圾回收器可以马上回收内存吗?有什么办法主动通知虚拟机进行垃圾回收?【基础】答:对 于 G C 来说,当程序员创建对象时,G C 就开始监控这个对象的地址、大小以及使用情况。通常,G C 采用有向图的方式记录和管理堆(heap)中的所有对象。通过这种方式确定哪些对象是 可达的,哪些对象是 不可达的。当G C 确定一第 7 页共5 9 页些对象为 不可达 时,G C 就有责任回收这些内存空间。可以。程序员可以手动执 行 System.gc(),通口 G C 运行,但是Java语言规范并不保证GC 一定会执行。39 String s=new String(x y z);创建了几个 String O b ject?【基础】答:两个对象,一个是,xyx,一个是指向xyx的引用对象s。40、接口是否可继承接口?抽象类是否可实现(implements)接口?抽象类是否可继承实体类(concrete class)?【基础】答:接口可以继承接口。抽象类可以实现(implements)接口,抽象类可继承实体类,但前提是实体类必须有明确的构造函数。41、Java的接口和C+的虚类的相同和不同处。【基础】答:由 于Java不支持多继承,而有可能某个类或对象要使用分别在几个类或对象里面的方法或属性,现有的单继承机制就不能满足要求。与继承相比,接口有更高的灵活性,因为接口中没有任何实现代码。当一个类实现了接口以后,该类要实现接口里面所有的方法和属性,并且接口里面的属性在默认状态下面都是public static,所有方法默认情况下是public.一个类可以实现多个接口。42、一 个.java”源文件中是否可以包含多个类(不是内部类)?有什么限制?【基础】答:可以;必须只有一个类名与文件名相同。43、说出一些常用的类,包,接口,请各举5个。【基础】答:常用的类:BufferedReader BufferedWriter FileReader FileWirterString Integer;常用 的包:java.lang java.awt java.io java.util java.sql;常用的接 口 :Remote List Map Document NodeList44 Anonymous Inner Class(匿名内部类)是否可以extends(继承)其它类?是否可以implements(实现)interface(接口)?【基础】答:可以继承其他类或实现其他接口,在 swing编程中常用此方式。45、内部类可以引用他包含类的成员吗?有没有什么限制?【基础】答:一个内部类对象可以访问创建它的外部类对象的内容。46、java中实现多态的机制是什么?【基础】答:方法的覆盖Overriding和重载Overloading是java多态性的不同表现;覆盖 Overriding是父类与子类之间多态性的一种表现,重载Overloading是一个类中多态性的一种表现。47、在java中一个类被声明为final类型,表示了什么意思?【基础】答:表示该类不能被继承,是顶级类。48、下面哪些类可以被继承?【基础】1)java.Iang.Thread(T)第 8 页共5 9 页2)java.lang.Number(T)3)java.lang.Double(F)4)java.Iang.Math(F)5)java.Iang.Void(F)6)java.Iang.Class(F)7)java.Iang.ClassLoader(T)答:1、2、7可以被继承。49、指出下面程序的运行结果:【基础】class AstaticSystem.out.print(l);)public A()System.out.print(2);)class B extends AstaticSystem.out.print(a);public B()System.out.print(b);public class Hellopublic static void main(String ars)A ab=new B();执行到此处,结果:la2bab=new B();执行到此处,结果:Ia2b2b答:输出结果为la2b2b;糊static代码段,可以看作是类首次加载(虚拟机加载)执行的代码,而对于类加载,首先要执行其基类的构造,再执行其本身的构造。50、继承时候类的执行顺序问题,一般都是选择题,问你将会打印出什么?【基础】父类:package test;public class FatherClass public FatherClass()System.out.println(FatherClass Create);)子类:package test;第 9 页共5 9 页import test.FatherClass;public class ChildClass extends FatherClass public ChildClass()System.out.println(ChildClass Create);public static void main(String args)FatherClass fc=new FatherClass();ChildClass cc=new ChildClass();)答:输出结果为:FatherClass CreateFatherClass CreateChildClass Create51、内部类的实现方式?【基础】答:示例代码如下:package test;public class OuterClass private class InterClass public lnterClass()System.out.println(lnterClass Create);public OuterClass()InterClass ic=new lnterClass();System.out.println(OuterClass Create);public static void main(String args)OuterClass oc=new OuterClass();)输出结果为:InterClass CreateOuterClass Create52、关于内部类:【基础】public class OuterClass private double dl=1.0;/insert code here)You need to insert an inner class declaration at line 3,Which twoinner class declarations are valid?(Choose two.)A.class lnnerOne第 1 0 页共5 9 页public static double methoda()return dl;B.public class lnnerOnestatic double methoda()return dl;)C.private class lnnerOnedouble methoda()return dl;D.static class lnnerOneprotected double methoda()return dl;)E.abstract class lnnerOnepublic abstract double methoda();)答:答案为C、E;说明如下:1)静态内部类可以有静态成员,而非静态内部类则不能有静态成员;故 A、B错;2)静态内部类的非静态成员可以访问外部类的静态变量,而不可访问外部类的非静态变量;故 D 错;3)非静态内部类的非静态成员可以访问外部类的非静态变量;故 C正确。53、数据类型之间的转换:1)如何将数值型字符转换为数字?2)如何将数字转换为字符?3)如何取小数点前两位并四舍五入?【基础】答:1)调 用 数 值 类 型 相 应 包 装 类 中 的 方 法parse*(String)或valueOf(String)即可返回相应基本类型或包装类型数值;2)将数字与空字符串相加即可获得其所对应的字符串;另外对于基本类型数字还可调用String类中的valueOf()方法返回相应字符串,而对于包装类型数字则可调用其toString。方法获得相应字符串;3)J用该数字构造一java.math.BigDecimal对象,再利用其round。方法进行四舍五入到保留小数点后两位,再将其转换为字符串截取最后两位。54、字符串操作:如何实现字符串的反转及替换?【基础】答:可用字符串构造一 StringBuffer对象,然后调用StringBuffer中的reverse方法即可实现字符串的反转,调 用replace方法即可实现字符串的替换。55、编码转换:怎样将GB2312编码的字符串转换为ISO-8859-1编码的字符串?【基础】答:示例代码如下:String si=你好;String s2=new String(sl.getBytes(GB2312)/ISO-8859-1);56、写一个函数,要求输入一个字符串和一个字符长度,对该字符串进行分隔。【基础】第1 1页共5 9页答:函数代码如下:public String split(String str,int chars)int n=(str.length()+chars-l)/chars;String ret=new Stringfn;for(int i=0;in;i+)if(i n-l)reti=str.substring(i*chars,(i+l)*chars);elsereti=str.substring(i*chars);)return ret;57、写一个函数,2个参数,1个字符串,1个字节数,返回截取的字符串,要求字符串中的中文不能出现乱码:如(“我ABC”,4)应该截为“我AB,输入(“我A B C汉DEF,6)应该输出为“我ABC”而不是“我ABC+汉的半个”。【基础】答:代码如下:public String subString(String str,int subBytes)int bytes=0;/用来存储字符串的总字节数for(int i=0;i str.length();i+)if(bytes=subBytes)return str.substring(O,i);char c=str.charAt(i);if(c java和 javasciprt的区别。【基础】答:JavaScript与 Java是两个公司开发的不同的两个产品。Java是SU N 公司推出的新一代面向对象的程序设计语言,特别适合于Internet应用程序开发;而JavaScript是 Netscape公司的产品,其目的是为了扩展NetscapeNavigator功能,而开发的一种可以嵌入W eb页面中的基于对象和事件驱动的解释性语言,它的前身是Live Script;而 Java的前身是Oak语言。下面对两种语言间的异同作如下比较:1)基于对象和面向对象:Java是一种真正的面向对象的语言,即使是开发简单的程序,必须设计对象;JavaScript是种脚本语言,它可以用来制作与网络无关的,与用户交互作用的复杂软件。它是一种基于对象(Object Based)和事件驱动(EventDriver)的编程语言。因而它本身提供了非常丰富的内部对象供设计人员使用;2)解释和编译:Java的源代码在执行之前,必须经过编译;JavaScript是一种解释性编程语言,其源代码不需经过编译,由浏览器解释执行;3)强类型变量和类型弱变量:Java采用强类型变量检查,即所有变量在编译之前必须作声明;JavaScript中变量声明,采用其弱类型。即变量在使用前不需作声明,而是解释器在运行时检查其数据类型;4)代码格式不一样。61、什么时候用assert?【中等难度】答:assertion(断言)在软件开发中是一种常用的调试方式,很多开发语言中都支持这种机制。一般来说,assertion用于保证程序最基本、关键的正确性。assertion检查通常在开发和测试时开启。为了提高性能,在软件发布后,第1 3页共5 9页assertion检查通常是关闭的。在实现中,断言是一个包含布尔表达式的语句,在执行这个语句时假定该表达式为true;如果表达式计算为false,那么系统会报告一个 Assertionerroro断言用于调试目的:assert(a 0);/throws an Assertionerror if a=0断言可以有两种形式:assert Expressionl;assert Expressionl:Expression2;Expressionl应该总是产生一个布尔值。Expression2可以是得出一个值的任意表达式;这个值用于生成显示更多调试信息的String消息。断言在默认情况下是禁用的,要在编译时启用断言,需使用source 1.4标记:javac-source 1.4 Test.java要在运行时启用断言,可使用-enableassertions或者-e a标记。要在运行时选择禁用断言,可使用-d a或者-disableassertions标记。要在系统类中启用断言,可使用-e sa或者-d sa标记。还可以在包的基础上启用或者禁用断言。可以在预计正常情况下不会到达的任何位置上放置断言。断言可以用于验证传递给私有方法的参数。不过,断言不应该用于验证传递给公有方法的参数,因为不管是否启用了断言,公有方法都必须检查其参数。不过,既可以在公有方法中,也可以在非公有方法中利用断言测试后置条件。另外,断言不应该以任何方式改变程序的状态。异常部分:(共 8 题:基 础 8 道)62、Ja va 中的异常处理机制的简单原理和应用?【基础】答:当 JAVA程序违反了 JA V A 的语义规则时,JAVA虚拟机就会将发生的错误表示为一个异常。违反语义规则包括2 种情况。一种是JAVA类库内置的语义检查。例如数组下标越界,会引发IndexOutOfBoundsException;访 问 n u ll的对象时会弓 I发 NullPointerException。另一种情况就是JAVA允许程序员扩展这种语义检查,程序员可以创建自己的异常,并自由选择在何时用throw 关键字引发异常。所有的异常都是java.Iang.Thowable的子类。63、error和 exception有什么区别?【基础】答:error表示系统级的错误和程序不必处理的异常,是恢复不是不可能但很困难的情况下的一种严重问题;比如内存溢出,不可能指望程序能处理这样的情况;exception表示需要捕捉或者需要程序进行处理的异常,是一种设计或实现问题;也就是说,它表示如果程序运行正常,从不会发生的情况。64、try 里有一个return语句,那么紧跟在这个tr y 后 的 finally 里的 code会不会被执行,什么时候被执行,在 return前还是后?【基础】答:会执行,在 return前执行。6 5、J A V A 语 言 如 何 进 行 异 常 处 理,关 键 字:throws,throw,try,catch,finally分别代表什么意义?在 try 块中可以抛出异常吗?【基础】答:Java 通过面向对象的方法进行异常处理,把各种不同的异常进行分类,并第 1 4 页 共 5 9 页提供了良好的接口。在 Ja v a 中,每个异常都是一个对 象,它是Throwable 类或其它子类的实例。当一个方法出现异常后便抛出一个异常对象,该对象中包含有异常信息,调用这个对象的方法可以捕获到这个异常并进行处理。Ja v a的异常处理是通过5个关键词来实现的:try、catch、throw、throws和finally。般情况下是用t r y来执行一段程序,如果出现异常,系统会抛出(throws)一个异常,这时候你可以通过它的类型来捕捉(catch)它,或最后(finally)由缺省处理器来处理;t r y用来指定一块预防所有“异常”的程序;catch子句紧跟在tr y块后面,用来指定你想要捕捉的“异常”的类型;throw语句用来明确地抛出一个“异常”;throw s用来标明一个成员函数可能抛出的各种“异常”;Finally为确保一段代码不管发生什么“异常”都被执行一段代码;可以在一个成员函数调用的外面写一个try语句,在这个成员函数内部写另一个t r y语句保护其他代码。每当遇到一个t r y语句,“异常”的框架就放到堆栈上面,直到所有的tr y语句都完成。如果下一级的t r y语句没有对某种“异常”进行处理,堆栈就会展开,直到遇到有处理这种“异常”的 tr y 语句。66、运行时异常与一般异常有何异同?【基础】答:异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误。ja va 编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。67、给我一个你最常见到的runtime exception?【基础】答:ArithmeticException,ArrayStoreException,BufferOverflowException,BufferllnderflowException,CannotRedoException,CannotUndoException,ClassCastException,CMMException,ConcurrentModificationException,DOMException,EmptyStackException,HlegalArgumentException,HlegalMonitorStateException,HlegalPathStateException,HlegalStateException,ImagingOpException,IndexOutOfBoundsException,MissingResourceException,NegativeArraySizeException,NoSuchElementException,NullPointerException,ProfileDataException,ProviderException,RasterFormatException,SecurityException,SystemException,UndeclaredThrowableException,UnmodifiableSetException,UnsupportedOperationException6 8 final,finally,finalize 的 区 别?【基础】答:final:修 饰 符(关键字);如果一个类被声明为fin al,意味着它不能再派生出新的子类,不能作为父类被继承,因此一个类不能既被声明为abstract的,又被声明为final的;将变量或方法声明为fin al,可以保证它们在使用中不被改变;被声明为final的变量必须在声明时给定初值,而在以后的引用中只能读取,不可修改;被声明为final的方法也同样只能使用,不能重载。finally:再异常处理时提供finally块来执行任何清除操作;如果抛出个异常,那么相匹配的catch子句就会执行,然后控制就会进入finally块(如果有的话)。第1 5页 共5 9页finalize:方法名;Java技术允许使用finalize。方法在垃圾收集器将对象从内存中清除出去之前做必要的清理工作。这个方法是由垃圾收集器在确定这个对象没有被引用时对这个对象调用的。它 是 在Object类中定义的,因此所有的类都继承了它。子类覆盖finalize()方法以整理系统资源或者执行其他清理工作。finalize。方法是在垃圾收集器删除对象之前对这个对象调用的。69、类 Example A 继承 Exception,类 ExampleB 继承 Example A;【基础】有如下代码片断:try(throw new ExampleB(ubv);catch(ExampleA e)System.out.printfln(ExampleA);catch(Exception e)System.out.printfln(Exception);输出的内容应该是:A:ExampleA B:Exception C:b D:无答:输出为A。集合部分:(共 1 1 题:基础1 1 道)70、介绍JAVA中的Collection Framework(及如何写自己的数据结构)【基础】答:Collection FrameWork 如下:CollectionpListI(-LinkedListI pArrayList|LVector|LStackLSetMap(-HashtablepHashMapLWeakHashMapCollection是最基本的集合接口,一个Collection代表一组Object,即Collection 的元素(Elements);Map 提供 key 到 value 的映射。71、List,Set,Map是否继承自Collection接 口?【基础】答:List,Set 是;Map 不是。72、你所知道的集合类都有哪些?主要方法?【基础】答:最常用的集合类是List和Map。L ist的具体实现包括ArrayList和V ector,它们是可变大小的列表,比较适合构建、存储和操作任何类型对象的元素列表。List适用于按数值索引访问元素的情形。M ap提供了一个更通用的第1 6页共5 9页元素存储方法。M ap集合类用于存储元素对(称 作“键”和“值”),其中每个键映射到一个值。73、说出ArrayList,Vector,LinkedList的存储性能和特性?【基础】答:ArrayList和 Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector 由于使用了 synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。74、Collection 和 Collections 的 区 别?【基础】答:Collection是 java.u til下的接口,它是各种集合的父接口,继承于它的接口主要有S e t和 List;Collections是个java.util下的类,是针对集合的帮助类,提供一系列静态方法实现对各种集合的搜索、排序、线程安全化等操作。75、HashMap和Hashtable的 区 别?【基础】答:二者都实现了 M ap接口,是将惟一键映射到特定的值上;主要区别在于:l)HashM ap没有排序,允许一个n u ll键和多个n u ll值,而Hashtable不允许;2)HashMap 把 Hashtable 的 contains 方法去掉了,改成 containsvalue和containsKey,因为contains方法容易让人引起误解;3)Hashtable 继承自 Dictionary 类,HashMap 是 Java 1.2 引进的 Map接口的实现;4)Hashtable的方法是Synchronize的,而HashMap不是,在多个线程访问Hashtable时,不需要自己为它的方法实现同步,而HashMap就必须为之提供外同步。Hashtable和HashMap采用的hash/rehash算法大致一样,所以性能不会有很大的差异。76、Arraylist与Vector区别?【基础】答:就ArrayList与Vector主要从二方面来说:1)同步性:Vector是线程安全的(同步),而ArrayList是线程序不安全的;2)数据增长:当需要增长时,Vector默认增长一倍,而ArrayList却是一半。77、List、Map、S e t三个接口,存取元素时,各有什么特点?【基础】答:L is t以特定次序来持有元素,可有重复元素。S e t无法拥有重复元素,内部排序。M ap保存key-value值,value可多值。78、S e t里的元素是不能重复的,那么用什么方法来区分重复与否呢?是用=还是equals。?它们有何区别?【基础】答:S e t里的元素是不能重复的,用equals()方法来区分重复与否。覆盖equals。方法用来判断对象的内容是否相同,而 =判断地址是否相等,用来决定引用值是否指向同一对象。79、用程序给出随便大小的1 0个数,序号为1-1 0,按从小到大顺序输出,并输出相应的序号。【基础】第1 7页共5 9页答:代码如下:package test;import java.util.ArrayList;import java.util.Collections;import java.util.Iterator;import java.util.List;import java.util.Random;public class RandomSort public static void printRandomBySort()Random random=new Random();/创建随机数生成器List list=new ArrayList();/生成1 0个随机数,并放在集合lis t中for(int i=0;i 10;i+)list.add(random.nextlnt(1000);)Collections.sort(list);/对集合中的元素进行排序Iterator it=list.iterator();int count=0;while(it.hasNext()/顺序输出排序后集合中的元素System.out.println(+count+:+it.next();)public static void main(String args)printRandomBySort();80、用 JAVA实现一种排序,JAVA类实现序列化的方法?在COLLECTION 框架中,实现比较要实现什么样的接口?【基础】答:用插入法进行排序代码如下:package test;import java.util.*;class InsertSort Ar ray Li st al;public lnsertSort(int numjnt mod)al=new ArrayList(num);Random rand=new Random();System.out.printlnfThe ArrayList Sort Before:);for(int i=0;inum;i+)al.add(new lnteger(Math.abs(rand.nextlnt()%mod+D);System.out.println(al+i+=+al.get(i);)第 1 8 页共5 9 页public void Sortlt()templnt;int MaxSize=l;for(int i=l;i=(lnteger)al.get(MaxSize-l).intValue()al.add(MaxSize,templnt);MaxSize+;System.out.println(al.toStringO);elsefor(int j=O;j=templnt.intValue()al.add(j,templnt);MaxSize+;System.out.println(al.toString();break;)System.out.println(The ArrayList Sort After:);for(int i=O;ial.size();i+)System.out.println(al+i+=+al.get(i

    注意事项

    本文(java软件工程面试题集锦.pdf)为本站会员(无***)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开