欢迎来到天天文库
浏览记录
ID:56749273
大小:220.00 KB
页数:39页
时间:2020-07-07
《应聘Java程序员笔试时出现问题.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、应聘Java笔试时可能出现问题Java基础方面:1、作用域public,private,protected,以及不写时的区别Public、Protected、Private是成员访问修饰符;final、abstract、transient、synchronized、native、strictfp是非访问成员修饰符。可见性PublicProtectedDefaultPrivate同一个类是是是是同一个包中的类是是是否同一个包中的子类是是是否同一包外的子类是是否否同一包外的非子类是否否否Java的基本包java.lang其中包含有:接口:Com
2、parable、Cloneable、Runable等类:八个基本数据类型封装类、Math、Runtime、Object、String、StringBuffer、Thread、Exception等集合框架集合是将多个元素组成一个单元的对象。集合用于存储、检索和操纵数据。集合框架提供管理对象集合的接口和类。它包含几个组件,接口是表示集合的抽象数据类型,用于操纵集合;类是用于存储集合的实际数据对象;算法是用于操纵集合的。2、ArrayList和Vector的区别,HashMap和Hashtable的区别答:就ArrayList与Vector主要从
3、二方面来说.一.同步性:Vector是线程安全的,也就是说是同步的,而ArrayList是线程序不安全的,不是同步的二.数据增长:当需要增长时,Vector默认增长为原来一培,而ArrayList却是原来的一半ArrayList,Vector,LinkedList的存储性能和特性ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安
4、全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。就HashMap与HashTable主要从三方面来说.一.历史原因:Hashtable是基于陈旧的Dictionary类的,HashMap是Java1.2引进的Map接口的一实现二.同步性:Hashtable是线程安全的,也就是说是同步的,而HashMap是线程序不安全的,不是同步的三.值:只有HashMap允许在一个集合中有一个null键和在一个集合中有多个n
5、ull值Hashtable是HashMap的同步版本;HashMap允许有null值和一个null键,但是,Hashtable不允许有任何内容为nullHashtable类的对象必须覆盖Object类的hashCode()和equals()方法关于其他集合类型:一.ArrayList提供快速遍历和快速访问。现在设计了新的RandomAccess接口,它指出这种列表支持快速随机访问。Vector也实现了RandomAccess接口。二.遍历HashSet与HashMap时,其顺序是未知的(但添加删除快)。LinkedHashSet和Linke
6、dHashSet是按照元素的插入的顺序遍历的(遍历快)。三.TreeSet和TreeMap将保证元素按照元素的自然顺序进行排列。也可以使用一个用户自己实现的比较规则。四、HashSet有一个散列表支持它。它为基本操作提供固定时间性能。TreeSet它确保了排序集将按元素升序,根据自然顺序排序。Dictionary类主要用于将关键字转换成值,该类接收一个关键字并返回一个值。Dictionary是一个抽象类,它是HHashtable的超类。Properties类扩展了Hashtable类,但Properties对象的关键字和值必须是String
7、类型,并能将对象写入一个输出流并保存在一个文件中,然后可以把它读回一个输入流。如果需要维护和搜索一个部件列表,它们由唯一的字母数字序列号标示,其中的部件是Part类型,这时应该使用哪种集合?如果我们改变需求,你也需要能够按顺序、按它们的序列号打印出部件?1、应该选择HashMap2、应该选择TreeMap3、char型变量中能不能存贮一个中文汉字?为什么?答:是能够定义成为一个中文的,因为java中以unicode编码,一个char占16个字节,所以放一个中文是没问题的4、多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么?答:多
8、线程有两种实现方法,分别是继承Thread类与实现Runnable接口同步的实现方面有两种,分别是synchronized,wait与notifyGC是什么?为什么要有GC?GC
此文档下载收益归作者所有