没有合适的资源?快使用搜索试试~ 我知道了~
资源详情
资源评论
资源推荐
Java 程序员面试题集(1-50)
一、Java 基础部分
1、面向对象的特征有哪些方面?
答:面向对象的特征主要有以下几个方面:
1)抽象:抽象是将一类对象的共同特征总结出来构造类的过程,包括数据抽象和行为抽象
两方面。抽象只关注对象有哪些属性和行为,并不关注这些行为的细节是什么。
2)继承:继承是从已有类得到继承信息创建新类的过程。提供继承信息的类被称为父类
(超类、基类);得到继承信息的类被称为子类(派生类)。继承让变化中的软件系统有
了一定的延续性,同时继承也是封装程序中可变因素的重要手段(如果不能理解请阅读阎
宏博士的《Java 与模式》或《设计模式精解》中关于桥梁模式的部分)。
3)封装:通常认为封装是把数据和操作数据的方法绑定起来,对数据的访问只能通过已定
义的接口。面向对象的本质就是将现实世界描绘成一系列完全自治、封闭的对象。我们在
类中编写的方法就是对实现细节的一种封装;我们编写一个类就是对数据和数据操作的封
装。可以说,封装就是隐藏一切可隐藏的东西,只向外界提供最简单的编程接口(可以想
想普通洗衣机和全自动洗衣机的差别,明显全自动洗衣机封装更好因此操作起来更简单;
我们现在使用的智能手机也是封装得足够好的,因为几个按键就搞定了所有的事情)。
4)多态性:多态性是指允许不同子类型的对象对同一消息作出不同的响应。简单的说就是
用同样的对象引用调用同样的方法但是做了不同的事情。多态性分为编译时的多态性和运
行时的多态性。如果将对象的方法视为对象向外界提供的服务,那么运行时的多态性可以
解释为:当 A 系统访问 B 系统提供的服务时,B 系统有多种提供服务的方式,但一切对 A
系统来说都是透明的(就像电动剃须刀是 A 系统,它的供电系统是 B 系统,B 系统可以使
用电池供电或者用交流电,甚至还有可能是太阳能,A 系统只会通过 B 类对象调用供电的
方法,但并不知道供电系统的底层实现是什么,究竟通过何种方式获得了动力)。方法重
载(overload)实现的是编译时的多态性(也称为前绑定),而方法重写(override)实现
的是运行时的多态性(也称为后绑定)。运行时的多态是面向对象最精髓的东西,要实现
多态需要做两件事:1. 方法重写(子类继承父类并重写父类中已有的或抽象的方法);2.
对象造型(用父类型引用引用子类型对象,这样同样的引用调用同样的方法就会根据子类
对象的不同而表现出不同的行为)。
2、访问修饰符 public,private,protected,以及不写(默认)时的区别?
答:区别如下:
作用域当前类同包子类其他
public √ √ √ √
protected √ √ √ ×
default √ √ × ×
private √ × × ×
类的成员不写访问修饰时默认为 default。默认对于同一个包中的其他类相当于公开
(public),对于不是同一个包中的其他类相当于私有(private)。受保护(protected)
对子类相当于公开,对不是同一包中的没有父子关系的类相当于私有。
3、String 是最基本的数据类型吗?
答:不是。Java 中的基本数据类型只有 8 个:
byte、short、int、long、float、double、char、boolean;除了基本类型(primitive type)
和枚举类型(enumeration type),剩下的都是引用类型(reference type)。
4、float f=3.4;是否正确?
答:不正确。3.4 是双精度数,将双精度型(double)赋值给浮点型(float)属于下转型
(down-casting,也称为窄化)会造成精度损失,因此需要强制类型转换 float f
=(float)3.4; 或者写成 float f =3.4F;。
5、short s1 = 1; s1 = s1 + 1;有错吗?short s1 = 1; s1 += 1;有错吗?
答:对于 short s1 = 1; s1 = s1 + 1;由于 1 是 int 类型,因此 s1+1 运算结果也是 int 型,需
要强制转换类型才能赋值给 short 型。而 short s1 = 1; s1 += 1;可以正确编译,因为 s1+=
1;相当于 s1 = (short)(s1 + 1);其中有隐含的强制类型转换。
6、Java 有没有 goto?
答:goto 是 Java 中的保留字,在目前版本的 Java 中没有使用。(根据 James
Gosling(Java 之父)编写的《The Java Programming Language》一书的附录中给出了
一个 Java 关键字列表,其中有 goto 和 const,但是这两个是目前无法使用的关键字,因此
有些地方将其称之为保留字,其实保留字这个词应该有更广泛的意义,因为熟悉 C 语言的
程序员都知道,在系统类库中使用过的有特殊意义的单词或单词的组合都被视为保留字)
7、int 和 Integer 有什么区别?
答:Java 是一个近乎纯洁的面向对象编程语言,但是为了编程的方便还是引入不是对象的
基本数据类型,但是为了能够将这些基本数据类型当成对象操作,Java 为每一个基本数据
类型都引入了对应的包装类型(wrapper class),int 的包装类就是 Integer,从 JDK 1.5
开始引入了自动装箱/拆箱机制,使得二者可以相互转换。
Java 为每个原始类型提供了包装类型:
原始类型: boolean,char,byte,short,int,long,float,double
包装类型:Boolean,Character,Byte,Short,Integer,Long,Float,Double
[java]view plaincopy
1. packagecom.lovo;
2.
3. publicclassAutoUnboxingTest{
4.
5. publicstaticvoidmain(String[]args){
6. Integera=newInteger(3);
7. Integerb=3;//将 3 自动装箱成 Integer 类型
8. intc=3;
9. System.out.println(a==b);//false两个引用没有引用同一对象
10. System.out.println(a==c);//truea 自动拆箱成 int 类型再和 c 比较
11. }
12. }
补充:最近还遇到一个面试题,也是和自动装箱和拆箱相关的,代码如下所示:
[java]view plaincopy
1. publicclassTest03{
2.
3. publicstaticvoidmain(String[]args){
4. Integerf1=100,f2=100,f3=150,f4=150;
5.
6. System.out.println(f1==f2);
7. System.out.println(f3==f4);
8. }
9. }
如果不明就里很容易认为两个输出要么都是 true 要么都是 false。首先需要注意的是
f1、f2、f3、f4 四个变量都是 Integer 对象,所以下面的==运算比较的不是值而是引用。装
箱的本质是什么呢?当我们给一个 Integer 对象赋一个 int 值的时候,会调用 Integer 类的静
态方法 valueOf,如果看看 valueOf 的源代码就知道发生了什么。
[java]view plaincopy
1. publicstaticIntegervalueOf(inti){
2. if(i>=IntegerCache.low&&i<=IntegerCache.high)
3. returnIntegerCache.cache[i+(-IntegerCache.low)];
4. returnnewInteger(i);
5. }
IntegerCache 是 Integer 的内部类,其代码如下所示:
[java]view plaincopy
1. /**
2. *Cachetosupporttheobjectidentitysemanticsofautoboxingfo
rvaluesbetween
3. *-128and127(inclusive)asrequiredbyJLS.
4. *
5. *Thecacheisinitializedonfirstusage.Thesizeofthecache
6. *maybecontrolledbythe{@code-XX:AutoBoxCacheMax=<size>}opt
ion.
7. *DuringVMinitialization,java.lang.Integer.IntegerCache.highp
roperty
8. *maybesetandsavedintheprivatesystempropertiesinthe
9. *sun.misc.VMclass.
10. */
11.
12. privatestaticclassIntegerCache{
13. staticfinalintlow=-128;
14. staticfinalinthigh;
15. staticfinalIntegercache[];
16.
17. static{
18. //highvaluemaybeconfiguredbyproperty
19. inth=127;
20. StringintegerCacheHighPropValue=
21. sun.misc.VM.getSavedProperty("java.lang.Integer.Intege
rCache.high");
22. if(integerCacheHighPropValue!=null){
23. try{
24. inti=parseInt(integerCacheHighPropValue);
25. i=Math.max(i,127);
26. //MaximumarraysizeisInteger.MAX_VALUE
27. h=Math.min(i,Integer.MAX_VALUE-(-low)-1);
28. }catch(NumberFormatExceptionnfe){
29. //Ifthepropertycannotbeparsedintoanint,i
gnoreit.
30. }
31. }
32. high=h;
33.
34. cache=newInteger[(high-low)+1];
35. intj=low;
36. for(intk=0;k<cache.length;k++)
37. cache[k]=newInteger(j++);
38.
39. //range[-128,127]mustbeinterned(JLS75.1.7)
40. assertIntegerCache.high>=127;
41. }
42.
43. privateIntegerCache(){}
44. }
简单的说,如果字面量的值在-128 到 127 之间,那么不会 new 新的 Integer 对象,而是直
接引用常量池中的 Integer 对象,所以上面的面试题中 f1==f2 的结果是 true,而 f3==f4 的
结果是 false。越是貌似简单的面试题其中的玄机就越多,需要面试者有相当深厚的功力。
8、&和&&的区别?
答:&运算符有两种用法:(1)按位与;(2)逻辑与。&&运算符是短路与运算。逻辑与跟短路
与的差别是非常巨大的,虽然二者都要求运算符左右两端的布尔值都是 true 整个表达式的
值才是 true。&&之所以称为短路运算是因为,如果&&左边的表达式的值是 false,右边的
表达式会被直接短路掉,不会进行运算。很多时候我们可能都需要用&&而不是&,例如在
验证用户登录时判定用户名不是 null 而且不是空字符串,应当写为:username != null &&!
username.equals(“”),二者的顺序不能交换,更不能用&运算符,因为第一个条件如果不
成立,根本不能进行字符串的 equals 比较,否则会产生 NullPointerException 异常。注意:
逻辑或运算符(|)和短路或运算符(||)的差别也是如此。
补充:如果你熟悉 JavaScript,那你可能更能感受到短路运算的强大,想成为 JavaScript
的高手就先从玩转短路运算开始吧。
剩余27页未读,继续阅读
北极光112
- 粉丝: 0
- 资源: 35
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
评论0