java笔试题⼤全带答案2020_2020java最新⾯试题及答案
java最新⾯试题及答案2020 持续更新。。
本⽂收集了⼀些经典的Java⾯试题及其答案
答:⾯向对象的特征主要有以下⼏个⽅⾯:
抽象:抽象是将⼀类对象的共同特征总结出来构造类的过程,包括数据抽象和⾏为抽象两⽅⾯。抽象只关注对象有哪些属性和⾏为,并不关注这些⾏为的细节是什么。
继承:继承是从已有类得到继承信息创建新类的过程。提供继承信息的类被称为⽗类(超类、基类);得到继承信息的类被称为⼦类(派⽣类)。继承让变化中的软件系统有了⼀定的延续性,同时继承也是封装程序中可变因素的重要⼿段(如果不能理解请阅读阎宏博⼠的《Java与模式》或《设计模式精解》中关于桥梁模式的部分)。
封装:通常认为封装是把数据和操作数据的⽅法绑定起来,对数据的访问只能通过已定义的接⼝。⾯向对象的本质就是将现实世界描绘成⼀系列完全⾃治、封闭的对象。我们在类中编写的⽅法就是对实现细节的⼀种封装;我们编写⼀个类就是对数据和数据操作的封装。可以说,封装就是隐藏⼀切可隐藏的东西,只向外界提供最简单的编程接⼝(可以想想普通洗⾐机和全⾃动洗⾐机的差别,明显全⾃动洗⾐机封
装更好因此操作起来更简单;我们现在使⽤的智能⼿机也是封装得⾜够好的,因为⼏个按键就搞定了所有的事情)。
多态性:多态性是指允许不同⼦类型的对象对同⼀消息作出不同的响应。简单的说就是⽤同样的对象引⽤调⽤同样的⽅法但是做了不同的事情。多态性分为编译时的多态性和运⾏时的多态性。如果将对象的⽅法视为对象向外界提供的服务,那么运⾏时的多态性可以解释为:当A 系统访问B系统提供的服务时,B系统有多种提供服务的⽅式,但⼀切对A系统来说都是透明的(就像电动剃须⼑是A系统,它的供电系统是B 系统,B系统可以使⽤电池供电或者⽤交流电,甚⾄还有可能是太阳能,A系统只会通过B类对象调⽤供电的⽅法,但并不知道供电系统的底层实现是什么,究竟通过何种⽅式获得了动⼒)。⽅法重载(overload)实现的是编译时的多态性(也称为前绑定),⽽⽅法重写(override)实现的是运⾏时的多态性(也称为后绑定)。运⾏时的多态是⾯向对象最精髓的东西,要实现多态需要做两件事:1). ⽅法重写(⼦类继承⽗类并重写⽗类中已有的或抽象的⽅法);2). 对象造型(⽤⽗类型引⽤引⽤⼦类型对象,这样同样的引⽤调⽤同样的⽅法就会根据⼦类对象的不同⽽表现出不同的⾏为)。
访问修饰符public,private,protected,以及不写(默认)时的区别?
类的成员不写访问修饰时默认为default。默认对于同⼀个包中的其他类相当于公开(public),对于不是同⼀个包中的其他类相当于私有(private)。受保护(protected)对⼦类相当于公开,对不是同⼀包中的没
有⽗⼦关系的类相当于私有。Java中,外部类的修饰符只能是public或默认,类的成员(包括内部类)的修饰符可以是以上四种。
String 是最基本的数据类型吗?
答:不是。Java中的基本数据类型只有8个:byte、short、int、long、float、double、char、boolean;除了基本类型(primitive type),剩下的都是引⽤类型(reference type),Java 5以后引⼊的枚举类型也算是⼀种⽐较特殊的引⽤类型。
float f=3.4;是否正确?
答:不正确。3.4是双精度数,将双精度型(double)赋值给浮点型(float)属于下转型(down-casting,也称为窄化)会造成精度损失,因此需要强制类型转换float f =(float)3.4; 或者写成float f =3.4F;
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);其中有隐含的强制类型转换。
Java有没有goto?
答:goto 是Java中的保留字,在⽬前版本的Java中没有使⽤。(根据James Gosling(Java之⽗)编写的《The Java Programming Language》⼀书的附录中给出了⼀个Java关键字列表,其中有goto和const,但是这两个是⽬前⽆法使⽤的关键字,因此有些地⽅将其称之为保留字,其实保留字这个词应该有更⼴泛的意义,因为熟悉C语⾔的程序员都知道,在系统类库中使⽤过的有特殊意义的单词或单词的组合都被视为保留字)
int和Integer有什么区别?
答:Java是⼀个近乎纯洁的⾯向对象编程语⾔,但是为了编程的⽅便还是引⼊了基本数据类型,但是为了能够将这些基本数据类型当成对象操作,Java为每⼀个基本数据类型都引⼊了对应的包装类型(wrapper class),int的包装类就是Integer,从Java 5开始引⼊了⾃动装箱/拆箱机制,使得⼆者可以相互转换。
Java 为每个原始类型提供了包装类型:
原始类型: boolean,char,byte,short,int,long,float,double
包装类型:Boolean,Character,Byte,Short,Integer,Long,Float,Double
class AutoUnboxingTest {
public static void main(String[] args) {
Integer a = new Integer(3);
Integer b = 3; // 将3⾃动装箱成Integer类型
int c = 3;
System.out.println(a == b); // false 两个引⽤没有引⽤同⼀对象
System.out.println(a == c); // true a⾃动拆箱成int类型再和c⽐较
}
}
最近还遇到⼀个⾯试题,也是和⾃动装箱和拆箱有点关系的,代码如下所⽰:
public class Test03 {
public static void main(String[] args) {
Integer f1 = 100, f2 = 100, f3 = 150, f4 = 150;
System.out.println(f1 == f2);
System.out.println(f3 == f4);
}嘉兴粽子
}
如果不明就⾥很容易认为两个输出要么都是true要么都是false。⾸先需要注意的是f1、f2、f3、f4四个变量都是Integer对象引⽤,所以下⾯的==运算⽐较的不是值⽽是引⽤。装箱的本质是什么呢?当我们给⼀个Integer对象赋⼀个int值的时候,会调⽤Integer类的静态⽅法valueOf,如果看看valueOf的源代码就知道发⽣了什么。
public static Integer valueOf(int i) {
if (i >= IntegerCache.low && i <= IntegerCache.high)
return IntegerCache.cache[i + (-IntegerCache.low)];
return new Integer(i);
}
怎么连接wifi
IntegerCache是Integer的内部类,其代码如下所⽰:
/**
* Cache to support the object identity semantics of autoboxing for values between
* -128 and 127 (inclusive) as required by JLS.
*
* The cache is initialized on first usage. The size of the cache
* may be controlled by the {@code -XX:AutoBoxCacheMax=} option. * During VM initialization, java.lang.Integer.IntegerCache.high property * may be set and saved in the private system properties in the
* sun.misc.VM class.
*/
民间传说大全private static class IntegerCache {
static final int low = -128;
static final int high;
static final Integer cache[];
static {
// high value may be configured by property
int h = 127;
String integerCacheHighPropValue =
sun.SavedProperty("java.lang.Integer.IntegerCache.high"); if (integerCacheHighPropValue != null) {文件打开方式
try {
int i = parseInt(integerCacheHighPropValue);
i = Math.max(i, 127);
// Maximum array size is Integer.MAX_VALUE
h = Math.min(i, Integer.MAX_VALUE - (-low) -1);
} catch( NumberFormatException nfe) {
// If the property cannot be parsed into an int, ignore it.
}
}
high = h;
cache = new Integer[(high - low) + 1];
int j = low;
for(int k = 0; k < cache.length; k++)
cache[k] = new Integer(j++);
// range [-128, 127] must be interned (JLS7 5.1.7)
余文乐电影assert IntegerCache.high >= 127;
}
private IntegerCache() {}
}
简单的说,如果整型字⾯量的值在-128到127之间,那么不会new新的Integer对象,⽽是直接引⽤常量池中的Integer对象,所以上⾯的⾯试题中f1f2的结果是true,⽽f3f4的结果是false。
提醒:越是貌似简单的⾯试题其中的⽞机就越多,需要⾯试者有相当深厚的功⼒。
&和&&的区别?
答:&运算符有两种⽤法:(1)按位与;(2)逻辑与。&&运算符是短路与运算。逻辑与跟短路与的差别是⾮常巨⼤的,虽然⼆者都要求运算符左右两端的布尔值都是true整个表达式的值才是true。&&之所以称为短路运算是因为,如果&&左边的表达式的值是false,右边的表达式会被直接短路掉,不会进⾏运算。很多时候我们可能都需要⽤&&⽽不是&,例如在验证⽤户登录时判定⽤户名不是null⽽且不是空字符串,应当写为:username != null &&!username.equals(""),⼆者的顺序不能交换,更不能⽤&运算符,因为第⼀个条件如果不成⽴,根本不能进⾏字符串的equals⽐较,否则会产⽣NullPointerException异常。注意:逻辑或运算符(|)和短路或运算符(||)的差别也是如此。
补充:如果你熟悉JavaScript,那你可能更能感受到短路运算的强⼤,想成为JavaScript的⾼⼿就先从玩转短路运算开始吧。
解释内存中的栈(stack)、堆(heap)和⽅法区(method area)的⽤法。
答:通常我们定义⼀个基本数据类型的变量,⼀个对象的引⽤,还有就是函数调⽤的现场保存都使⽤JVM中的栈空间;⽽通过new关键字和构造器创建的对象则放在堆空间,堆是垃圾收集器管理的主要区域,由于现在的垃圾收集器都采⽤分代收集算法,所以堆空间还可以细分为新⽣代和⽼⽣代,再具体⼀点可以分为Eden、Survivor(⼜可分为From Survivor和To Survivor)、Tenured;⽅法区和堆都是各个线程共享的内存区域,⽤于存储已经被JVM加载的类信息、常量、静态变量、JIT编译器编译后的
代码等数据;程序中的字⾯量(literal)如直接书写的100、"hello"和常量都是放在常量池中,常量池是⽅法区的⼀部分,。栈空间操作起来最快但是栈很⼩,通常⼤量的对象都是放在堆空间,栈和堆的⼤⼩都可以通过JVM的启动参数来进⾏调整,栈空间⽤光了会引发StackOverflowError,⽽堆和常量池空间不⾜则会引发OutOfMemoryError。
String str = new String("hello");
上⾯的语句中变量str放在栈上,⽤new创建出来的字符串对象放在堆上,⽽"hello"这个字⾯量是放在⽅法区的。
补充1:较新版本的Java(从Java 6的某个更新开始)中,由于JIT编译器的发展和"逃逸分析"技术的逐渐成熟,栈上分配、标量替换等优化技术使得对象⼀定分配在堆上这件事情已经变得不那么绝对了。
补充2:运⾏时常量池相当于Class⽂件常量池具有动态性,Java语⾔并不要求常量⼀定只有编译期间才能产⽣,运⾏期间也可以将新的常量放⼊池中,String类的intern()⽅法就是这样的。
看看下⾯代码的执⾏结果是什么并且⽐较⼀下Java 7以前和以后的运⾏结果是否⼀致。
sekiro
String s1 = new StringBuilder("go")
.append("od").toString();
System.out.println(s1.intern() == s1);
String s2 = new StringBuilder("ja")
.append("va").toString();
System.out.println(s2.intern() == s2);
答:und(11.5)的返回值是12,und(-11.5)的返回值是-11。四舍五⼊的原理是在参数上加0.5然后进⾏下取整。
switch 是否能作⽤在byte 上,是否能作⽤在long 上,是否能作⽤在String上?
答:在Java 5以前,switch(expr)中,expr只能是byte、short、char、int。从Java 5开始,Java中引⼊了枚举类型,expr也可以是enum类型,从Java 7开始,expr还可以是字符串(String),但是长整型(long)在⽬前所有的版本中都是不可以的。