没有合适的资源?快使用搜索试试~ 我知道了~
这些面试体汇集了多场软通面试题,来之不易。花了我很多关系的哦
资源推荐
资源详情
资源评论
一 基 础 部 分
1、面向对象的特征有哪些方面
1.抽象:
抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目
标有关的方面。抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用
部分细节。抽象包括两个方面,一是过程抽象,二是数据抽象。
2.继承:
继承是一种联结类的层次模型,并且允许和鼓励类的重用,它提供了一种明确表述
共性的方法。对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类
继承了原始类的特性, 新类称为原始类的派生类(子类),而原始类称为新类的基
类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以修改或
增加新的方法使之更适合特殊的需要。
3.封装:
封装是把过程和数据包围起来,对数据的访问只能通过已定义的界面。面向对象计
算始于这个基本概念,即现实世界可以被描绘成一系列完全自治、封装的对象,这
些对象通过一个受保护的接口访问其他对象。
4. 多态性:
多态性是指允许不同类的对象对同一消息作出响应。多态性包括参数化多态性和包
含多态性。多态性语言具有灵活、抽象、行为共享、代码共享的优势,很好的解决
了应用程序函数同名问题。
2、String 是最基本的数据类型吗?
基本数据类型包括 byte、short、char、 int、oat、long、double、boolean
和。
java.lang.String 类是 nal 类型的,因此不可以继承这个类、不能修改这个类。
为了提高效率节省空间,我们应该用 StringBuer 类
3、int 和 Integer 有什么区别
Java 提供两种不同的类型:引用类型和原始类型(或内置类型)。Int 是 java 的原
始数据类型,Integer 是 java 为 int 提供的封装类。Java 为每个原始类型提供了封
装类。
原始类型封装类
booleanBoolean
charCharacter
byteByte
shortShort
intInteger
longLong
oatFloat
doubleDouble
引用类型和原始类型的行为完全不同,并且它们具有不同的语义。引用类型和原始
类型具有不同的特征和用法,它们包括:大小和速度问题,这种类型以哪种类型的
数据结构存储,当引用类型和原始类型用作某个类的实例数据时所指定的缺省值。
对象引用实例变量的缺省值为 null,而原始类型实例变量的缺省值与它们的类型有
关。
4、String 和 StringBuer 的区别
JAVA 平台提供了两个类:String 和 StringBuer,它们可以储存和操作字符串,
即包含多个字符的字符数据。这个 String 类提供了数值不可改变的字符串。而这个
StringBuer 类提供的字符串进行修改。当你知道字符数据要改变的时候你就可以
使用 StringBuer。典型地,你可以使用 StringBuers 来动态构造字符数据。
5、运行时异常与一般异常有何异同?
异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操
作中可能遇到的异常,是一种常见运行错误。java 编译器要求方法必须声明抛出可
能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。
6、说出 Servlet 的生命周期,并说出 Servlet 和 CGI 的区别。
Servlet 被服务器实例化后,容器运行其 init 方法,请求到达时运行其 service 方
法,service 方法自动派遣运行与请求对应的 doXXX 方法(doGet,doPost)等,
当服务器决定将实例销毁的时候调用其 destroy 方法。
与 cgi 的区别在于 servlet 处于服务器进程中,它通过多线程方式运行其 service
方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而 CGI 对每个请
求都产生新的进程,服务完成后就销毁,所以效率上低于 servlet。
7、说出 ArrayList,Vector, LinkedList 的存储性能和特性
ArrayList 和 Vector 都是使用数组方式存储数据,此数组元素数大于实际存储的数
据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数
组元素移动等内存操作,所以索引数据快而插入数据慢, Vector 由于使用了
synchronized 方法(线程安全),通常性能上较 ArrayList 差,而 LinkedList 使
用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时
只需要记录本项的前后项即可,所以插入速度较快。
9、Collection 和 Collections 的区别。
Collection 是集合类的上级接口,继承与他的接口主要有 Set 和 List.
Collections 是针对集合类的一个帮助类,他提供一系列静态方法实现对各种集合
的搜索、排序、线程安全化等操作。
10、&和&&的区别。
&是位运算符,表示按位与运算,&&是逻辑运算符,表示逻辑与(and)。
11、HashMap 和 Hashtable 的区别。
HashMap 是 Hashtable 的轻量级实现(非线程安全的实现),他们都完成了
Map 接口,主要区别在于 HashMap 允许空(null)键值(key),由于非线程安全,
效率上可能高于 Hashtable。
HashMap 允许将 null 作为一个 entry 的 key 或者 value,而 Hashtable 不允许。
HashMap 把 Hashtable 的 contains 方 法 去 掉 了 , 改 成 containsvalue 和
containsKey。因为 contains 方法容易让人引起误解。
Hashtable 继 承 自 Dictionary 类 , 而 HashMap 是 Java1.2 引 进 的 Map
interface 的一个实现。
最大的不同是,Hashtable 的方法是 Synchronize 的,而 HashMap 不是,在多
个线程访问 Hashtable 时,不需要自己为它的方法实现同步,而 HashMap 就必
须为之提供外同步。
Hashtable 和 HashMap 采用的 hash/rehash 算法都大概一样,所以性能不会有
很大的差异。
12、nal, nally, nalize 的区别。
nal 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可
继承。
nally 是异常处理语句结构的一部分,表示总是执行。
nalize 是 Object 类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此
方法,可以覆盖此方法提供垃圾收集时的其他资源回收,例如关闭文件等。
13、sleep() 和 wait() 有什么区别?
sleep 是线程类(Thread)的方法,导致此线程暂停执行指定时间,把执行机会给
其他线程,但是监控状态依然保持,到时后会自动恢复。调用 sleep 不会释放对象
锁。
wait 是 Object 类的方法,对此对象调用 wait 方法导致本线程放弃对象锁,进入等
待此对象的等待锁定池,只有针对此对象发出 notify 方法(或 notifyAll)后本线程
才进入对象锁定池准备获得对象锁进入运行状态。
14、Overload 和 Override 的区别。Overloaded 的方法是否可以改变返回值的
类型?
方法的重写 Overriding 和重载 Overloading 是 Java 多态性的不同表现。重写
Overriding 是父类与子类之间多态性的一种表现,重载 Overloading 是一个类中
多态性的一种表现。如果在子类中定义某方法与其父类有相同的名称和参数,我们
说该方法被重写 (Overriding)。子类的对象使用这个方法时,将调用子类中的定义,
对它而言,父类中的定义如同被"屏蔽"了。如果在一个类中定义了多个同名的方法,
它 们 或 有 不 同 的 参 数 个 数 或 有 不 同 的 参 数 类 型 , 则 称 为 方 法 的 重 载
(Overloading)。Overloaded 的方法是可以改变返回值的类型。
15、error 和 exception 有什么区别?
error 表示恢复不是不可能但很困难的情况下的一种严重问题。比如说内存溢出。
不可能指望程序能处理这样的情况。
exception 表示一种设计或实现问题。也就是说,它表示如果程序运行正常,从不
会发生的情况。
16、同步和异步有何异同,在什么情况下分别使用他们?举例说明。
如果数据将在线程间共享。例如正在写的数据以后可能被另一个线程读到,或者正
在读的数据可能已经被另一个线程写过了,那么这些数据就是共享数据,必须进行
同步存取。
当应用程序在对象上调用了一个需要花费很长时间来执行的方法,并且不希望让程
序等待方法的返回时,就应该使用异步编程,在很多情况下采用异步途径往往更有
效率。
17、abstract class 和 interface 有什么区别?
声明方法的存在而不去实现它的类被叫做抽象类(abstract class),它用于要创
建一个体现某些基本行为的类,并为该类声明方法,但不能在该类中实现该类的情
况。不能创建 abstract 类的实例。然而可以创建一个变量,其类型是一个抽象类 ,
并让它指向具体子类的一个实例。不能有抽象构造函数或抽象静态方法。Abstract
类的子类为它们父类中的所有抽象方法提供实现,否则它们也是抽象类为。取而代
之,在子类中实现该方法。知道其行为的其它类可以在类中实现这些方法。
接口(interface)是抽象类的变体。在接口中,所有方法都是抽象的。多继承性可
通过实现这样的接口而获得。接口中的所有方法都是抽象的,没有一个有程序体。
接口只可以定义 static nal 成员变量。接口的实现与子类相似,除了该实现类不
能从接口定义中继承行为。当类实现特殊接口时,它定义(即将程序体给予)所有
这种接口的方法。然后,它可以在实现了该接口的类的任何对象上调用接口的方法。
由于有抽象类,它允许使用接口名作为引用变量的类型。通常的动态联编将生效。
引用可以转换到接口类型或从接口类型转换,instanceof 运算符可以用来决定某对
象的类是否实现了接口。
18、heap 和 stack 有什么区别。
栈是一种线形集合,其添加和删除元素的操作应在同一段完成。栈按照后进先出的
方式进行处理。
堆是栈的一个组成元素
19、forward 和 redirect 的区别
forward 是服务器请求资源,服务器直接访问目标地址的 URL,把那个 URL 的响
应内容读取过来,然后把这些内容再发给浏览器,浏览器根本不知道服务器发送的
内容是从哪儿来的,所以它的地址栏中还是原来的地址。
redirect 就是服务端根据逻辑,发送一个状态码,告诉浏览器重新去请求那个地址,
一般来说浏览器会用刚才请求的所有参数重新请求,所以 session,request 参数都
可以获取。
21、Static Nested Class 和 Inner Class 的不同。
Static Nested Class 是被声明为静态(static)的内部类,它可以不依赖于外部
类实例被实例化。而通常的内部类需要在外部类实例化后才能实例化。
22、JSP 中动态 INCLUDE 与静态 INCLUDE 的区别?
动 态 INCLUDE 用 jsp:include 动 作 实 现 <jsp:include page="included.jsp"
ush="true" />它总是会检查所含文件中的变化,适合用于包含动态页面,并且
可以带参数。
静态 INCLUDE 用 include 伪码实现,定不会检查所含文件的变化,适用于包含静态
页面<%@ include le="included.htm" %>
23、什么时候用 assert。
assertion(断言)在软件开发中是一种常用的调试方式,很多开发语言中都支持这种
机制。在实现中,assertion 就是在程序中的一条语句,它对一个 boolean 表达式
进行检查,一个正确程序必须保证这个 boolean 表达式的值为 true;如果该值为
false,说明程序已经处于不正确的状态下,系统将给出警告或退出。一般来说 ,
assertion 用于保证程序最基本、关键的正确性。assertion 检查通常在开发和测
试时开启。为了提高性能,在软件发布后,assertion 检查通常是关闭的。
24、GC 是什么? 为什么要有 GC?
GC 是垃圾收集的意思(Gabage Collection),内存处理是编程人员容易出现
问题的地方,忘记或者错误的内存回收会导致程序或系统的不稳定甚至崩溃, Java
提供的 GC 功能可以自动监测对象是否超过作用域从而达到自动回收内存的目的 ,
Java 语言没有提供释放已分配内存的显示操作方法。
25、short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
short s1 = 1; s1 = s1 + 1; (s1+1 运算结果是 int 型,需要强制转换类型)
short s1 = 1; s1 += 1;(可以正确编译)
26、Math.round(11.5)等於多少? Math.round(-11.5)等於多少?
Math.round(11.5)==12
Math.round(-11.5)==-11
round 方法返回与参数最接近的长整数,参数加 1/2 后求其 oor.
27、String s = new String("xyz");创建了几个 String Object?
两个
28、设计 4 个线程,其中两个线程每次对 j 增加 1,另外两个线程对 j 每次减少 1。
写出程序。
以下程序使用内部类实现线程,对 j 增减的时候没有考虑顺序问题。
public class ThreadTest1{
private int j;
public static void main(String args[]){
ThreadTest1 tt=new ThreadTest1();
Inc inc=tt.new Inc();
Dec dec=tt.new Dec();
for(int i=0;i<2;i++){
Thread t=new Thread(inc);
t.start();
t=new Thread(dec);
t.start();
}
}
private synchronized void inc(){
j++;
System.out.println(Thread.currentThread().getName()+"-inc:"+j);
}
private synchronized void dec(){
j--;
System.out.println(Thread.currentThread().getName()+"-dec:"+j);
}
class Inc implements Runnable{
public void run(){
for(int i=0;i<100;i++){
inc();
}
}
}
剩余63页未读,继续阅读
资源评论
duguzhushen
- 粉丝: 0
- 资源: 3
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功