java⾯试会问什么问题_初级java⾯试时经常会问到的问题!java作为⽬前⽕的计算机语⾔之⼀,⼀直都是程序员喜爱的计算机语⾔,java更是蝉联连续⼏年的计算机语⾔榜⾸,因此每年⼊职的java程序员都居⾼不下。当然,在⼊职之前,都是要经过⾯试的,那么java⾯试题是怎么出来的呢?为此我们列出了⼀下常见的java⾯试题。⼊职必备!
1.个可能会问你⾯向对象的特征
抽象:抽象是将⼀类对象的共同特征总结出来构造类的过程,包括数据抽象和⾏为抽象两⽅⾯。抽象只关注对象有哪些属性和⾏为,并不关注这些⾏为的细节是什么。
继承:继承是从已有类得到继承信息创建新类的过程。提供继承信息的类被称为⽗类(超类、基类);得到继承信息的类被称为⼦类(派⽣类)。继承让变化中的软件系统有了⼀定的延续性,同时继承也是封装程序中可变因素的重要⼿段(如果不能理解请阅读阎宏博⼠的《Java与模式》或《设计模式精解》中关于桥梁模式的部分)。
封装:通常认为封装是把数据和操作数据的⽅法绑定起来,对数据的访问只能通过已定义的接⼝。⾯向对象的本质就是将现实世界描绘成⼀系列完全⾃治、封闭的对象。我们在类中编写的⽅法就是对实现细节的⼀种封装;我们编写⼀个类就是对数据和数据操作的封装。可以说,封装就是隐藏⼀切可隐藏的东西,只向外界提供简单的编程接⼝(可以想想普通洗⾐机和全⾃动洗⾐机的差别,明显全⾃动洗⾐机封装
更好因此操作起来更简单;我们现在使⽤的智能⼿机也是封装得⾜够好的,因为⼏个按键就搞定了所有的事情)。
多态性:多态性是指允许不同⼦类型的对象对同⼀消息作出不同的响应。简单的说就是⽤同样的对象引⽤调⽤同样的⽅法但是做了不同的事情。多态性分为编译时的多态性和运⾏时的多态性。如果将对象的⽅法视为对象向外界提供的服务,那么运⾏时的多态性可以解释为:当A 系统访问B系统提供的服务时,B系统有多种提供服务的⽅式,但⼀切对A系统来说都是透明的(就像电动剃须⼑是A系统,它的供电系统是B 系统,B系统可以使⽤电池供电或者⽤交流电,甚⾄还有可能是太阳能,A系统只会通过B类对象调⽤供电的⽅法,但并不知道供电系统的底层实现是什么,究竟通过何种⽅式获得了动⼒)。⽅法重载(overload)实现的是编译时的多态性(也称为前绑定),⽽⽅法重写(override)实现的是运⾏时的多态性(也称为后绑定)。运⾏时的多态是⾯向对象精髓的东西,要实现多态需要做两件事:1).⽅法重写(⼦类继承⽗类并重写⽗类中已有的或抽象的⽅法);2).对象造型(⽤⽗类型引⽤引⽤⼦类型对象,这样同样的引⽤调⽤同样的⽅法就会根据⼦类对象的不同⽽表现出不同的⾏为)。
2.String是基本的数据类型吗?
不是。Java中的基本数据类型只有8个:byte、short、int、long、float、double、char、boolean;除了基本类型(primitive type)和枚举类型(enumeration type),剩下的都是引⽤类型(referencetype)。
3.int和Integer有什么区别?
Java提供两种不同的类型:引⽤类型和原始类型(或内置类型)。Int是java的原始数据类
型,Integer是java为int提供的封装类。Java为每个原始类型提供了封装类。
java面向对象的特征有哪些方面原始类型封装类
booleanBoolean
charCharacter
byteByte
shortShort
intInteger
longLong
floatFloat
doubleDouble
引⽤类型和原始类型的⾏为完全不同,并且它们具有不同的语义。引⽤类型和原始类型具有
不同的特征和⽤法,它们包括:⼤⼩和速度问题,这种类型以哪种类型的数据结构存储,当
引⽤类型和原始类型⽤作某个类的实例数据时所的缺省值。对象引⽤实例变量的缺省值
为 null,⽽原始类型实例变量的缺省值与它们的类型有关。
4.抽象类(abstract class)和接⼝(interface)有什么异同?
抽象类和接⼝都不能够实例化,但可以定义抽象类和接⼝类型的引⽤。⼀个类如果继承了某个抽象类或者实现了某个接⼝都需要对其中的抽象⽅法全部进⾏实现,否则该类仍然需要被声明为抽象类。接⼝⽐抽象类更加抽象,因为抽象类中可以定义构造器,可以有抽象⽅法和具体⽅法,⽽接⼝中不能定义构造器⽽且其中的⽅法全部都是抽象⽅法。抽象类中的成员可以是private、默认、protected、public的,⽽接⼝中的成员全都是public的。抽象类中可以定义成员变量,⽽接⼝中定义的成员变量实际上都是常量。有抽象⽅法的类必须被声明为抽象类,⽽抽象类未必要有抽象⽅法。
5.Java有没有goto?
goto是Java中的保留字,也就是说,现在还没有在Java中使⽤goto,但是在将来的jdk版本中有可能使⽤goto。
6.阐述ArrayList、Vector、LinkedList的存储性能和特性。
ArrayList和Vector都是使⽤数组⽅式存储数据,此数组元素数⼤于实际存储的数据以便增加和插⼊元素,它们都允许直接按序号索引元素,但是插⼊元素要涉及数组元素移动等内存操作,所以索引数据快⽽插⼊数据慢,Vector由于使⽤了synchronized⽅法,通常性能上较ArrayList差,⽽LinkedList使⽤双向链表实现存储,按序号索引数据需要进⾏前向或后向遍历,但是插⼊数据时只需要记录本项的前后项即可,所以插⼊速度较快。
淮安北⼤青鸟,淮安Java培训,淮安it培训
⽂中图⽚素材来源⽹络,如有侵权请联系删除

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。