常见java应聘笔试题_第1页
常见java应聘笔试题_第2页
常见java应聘笔试题_第3页
常见java应聘笔试题_第4页
常见java应聘笔试题_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第 第 页常见java应聘笔试题常见java应聘笔试题1. Java中sleep和wait的区分 这两个方法来自不同的类分别是,sleep来自Thread类,和wait来自Object类。sleep是Thread的静态类方法,谁调用的谁去睡觉,即使在a线程里调用b的sleep方法,事实上还是a去睡觉,要让b线程睡觉要在b的代码中调用sleep。 锁: 最主要是sleep方法没有释放锁,而wait方法释放了锁,使得其他线程可以运用同步掌握块或者方法。sleep不出让系统资源;wait是进入线程等待池等待,出让系统资源,其他线程可以占用CPU。一般wait不会加时间限制,由于假如wait线程的运行

2、资源不够,再出来也没用,要等待其他线程调用notify/notifyAll唤醒等待池中的全部线程,才会进入就绪队列等待OS安排系统资源。sleep(milliseconds)可以用时间指定使它自动唤醒过来,假如时间不到只能调用interrupt()强行打断。Thread.sleep(0)的作用是“触发操作系统立即重新进行一次CPU竞争”。 运用范围:wait,notify和notifyAll只能在同步掌握方法或者同步掌握块里面运用,而sleep可以在任何地方运用。synchronized(*) *.notify() /或者wait() 2. Java中HashMap和HashTable的区分

3、历史缘由: Hashtable是予以陈旧的Dictonary类的, HashMap是Java1.2引进的Map接口的一个实现 HashMap允许空的键值对, 而HashTable不允许 HashTable同步,而HashMap非同步,效率上比HashTable要高3. 请简述在异样当中,throw和throws有什么区分 throw代表动作,表示抛出一个异样的动作;throws代表一种状态,代表方法可能有异样抛出 throw用在方法实现中,而throws用在方法声明中 throw只能用于抛出一种异样,而throws可以抛出多个异样4. 内存溢出和内存泄露的区分内存溢出 out of memor

4、y,是指程序在申请内存时,没有足够的内存空间供其运用,涌现out of memory;比如申请了一个integer,但给它存了long才能存下的数,那就是内存溢出。内存泄露 memory leak,是指程序在申请内存后,无法释放已申请的内存空间,一次内存泄露危害可以忽视,但内存泄露堆集后果很严峻,无论多少内存,迟早会被占光。memory leak会最终会导致out of memory!内存溢出就是你要求安排的内存超出了系统能给你的,系统不能满意需求,于是产生溢出。内存泄漏是指你向系统申请安排内存进行运用(new),可是运用完了以后却不归还(),结果你申请到的那块内存你自己也不能再访问或许你把它

5、的地址给弄丢了,而系统也不能再次将它安排给需要的程序。一个盘子用完各种方法只能装4个果子,你装了5个,结果掉倒地上不能吃了。这就是溢出!比方说栈,栈满时再做进栈必定产生空间溢出,叫上溢,栈空时再做退栈也产生空间溢出,称为下溢。就是安排的内存不足以放下数据项序列,称为内存溢出。以发生的方式来分类,内存泄漏可以分为4类: 常发性内存泄漏。发生内存泄漏的代码会被多次执行到,每次被执行的时候都会导致一块内存泄漏。 偶发性内存泄漏。发生内存泄漏的代码只有在某些特定环境或操作过程下才会发生。常发性和偶发性是相对的。对于特定的环境,偶发性的或许就变成了常发性的。所以测试环境和测试方法对检测内存泄漏至关重要。

6、 一次性内存泄漏。发生内存泄漏的代码只会被执行一次,或者由于算法上的缺陷,导致总会有一块仅且一块内存发生泄漏。比如,在类的构造函数中安排内存,在析构函数中却没有释放该内存,所以内存泄漏只会发生一次。 隐式内存泄漏。程序在运行过程中不停的安排内存,但是直到结束的时候才释放内存。严格的说这里并没有发生内存泄漏,由于最终程序释放了全部申请的内存。但是对于一个服务器程序,需要运行几天,几周甚至几个月,不实时释放内存也可能导致最终耗尽系统的全部内存。所以,我们称这类内存泄漏为隐式内存泄漏。从用户运用程序的角度来看,内存泄漏本身不会产生什么危害,作为一般的用户,根本感觉不到内存泄漏的存在。真正有危害的是内

7、存泄漏的堆集,这会最终消耗尽系统全部的内存。从这个角度来说,一次性内存泄漏并没有什么危害,由于它不会堆集,而隐式内存泄漏危害性那么特别大,由于较之于常发性和偶发性内存泄漏它更难被检测到。5. String,StringBuffer 和 StringBuilder的区分可变与不可变String类中运用字符数组保存字符串,如下就是,由于有“final”修饰符,所以可以知道string对象是不可变的。private final char value;StringBuilder与StringBuffer都继承自AbstractStringBuilder类,在AbstractStringBuilder中

8、也是运用字符数组保存字符串,如下就是,可知这两种对象都是可变的。char value;是否多线程安全String中的对象是不可变的,也就可以理解为常量,显着线程安全。AbstractStringBuilder是StringBuilder与StringBuffer的公共父类,定义了一些字符串的基本操作,如e*pandCapacity、append、inde*Of等公共方法。StringBuffer对方法加了同步锁或者对调用的方法加了同步锁,所以是线程安全的。看如下源码:public synchronized StringBuffer reverse() super.reverse(); retu

9、rn this; public int inde*Of(String str) return inde*Of(str, 0); /存在 public synchronized int inde*Of(String str, int fromInde*) 方法 StringBuilder并没有对方法进行加同步锁,所以是非线程安全的。StringBuilder与StringBuffer共同点StringBuilder与StringBuffer有公共父类AbstractStringBuilder(抽象类)。抽象类与接口的其中一个区分是:抽象类中可以定义一些子类的公共方法,子类只需要增加新的功能,不需

10、要重复写已经存在的方法;而接口中只是对方法的申明和常量的定义。StringBuilder、StringBuffer的方法都会调用AbstractStringBuilder中的公共方法,如super.append(.)。只是StringBuffer会在方法上加synchronized关键字,进行同步。最末,假如程序不是多线程的,那么运用StringBuilder效率高于StringBuffer。6. 数组和链表的区分二者都属于一种数据结构从规律结构来看: 数组需要事先定义固定的长度元素个数,不能适应数据动态地增减的状况。当数据增加时,可能超出原先定义的元素个数;当数据减削时,造成内存糜费;数组可以依据下标径直存取。 链表动态地进行存储安排,可以适应数据动态地增减的状况,且可以方便地插入、删除数据项。数组中插入、删除数据项时,需要移动其它数据项,特别繁琐链表需要依据ne*t指针找到下一个元素。从内存存储来看:(静态)数组从栈中安排空间,对于程序员方便快速,但是自由度小。链表从堆中安排空间,自由度大但是申请管理比较麻烦。从上面的比较可以看出,假如需要快速访问数据,很少或不插入和删除元素,就应当用数组;相反,假如需要常常插入和删除元素就需要用链表数据结构了。7. ArrayL

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论