1、String 和StringBuffer,StringBuilder的区别
String类提供了数值不可改变的字符串。
StringBuffer类提供的字符串进行修改。可以使用StringBuffers来动态构造字符数据。
StringBuilder相对StringBuffer是线程安全的.2、String是最基本的数据类型吗
基本数据类型包括byte、int、char、long、float、double、boolean和short。
java.lang.String类是final类型的,因此不可以继承这个类、不能修改这个类。对字符串的任何修改,都将生成一个新的字符串。
当进行大量的字符串连接时,为了提高效率节省空间,我们应该用StringBuffer类3、说出ArrayList,Vector, LinkedList的存储性能和特性 ?
ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。4、ArrayList和Vector的区别,HashMap和Hashtable的区别
答:就ArrayList与Vector主要从二方面来说.
一.同步性:Vector是线程安全的,也就是说是同步的,而ArrayList是线程序不安全的,不是同步的
二.数据增长:当需要增长时,Vector默认增长为原来一培,而ArrayList却是原来的一半
就HashMap与HashTable主要从三方面来说。
一.历史原因:Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现
二.同步性:Hashtable是线程安全的,也就是说是同步的,而HashMap是线程序不安全的,不是同步的
三.值:只有HashMap可以让你将空值作为一个表的条目的key或value5、介绍JAVA中的Collection FrameWork(包括如何写自己的数据结构)
答:Collection FrameWork如下:
Collection
├List
│├LinkedList
│├ArrayList
│└Vector
│ └Stack
└Set
Map
├Hashtable
├HashMap
└WeakHashMap
Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Elements)
Map提供key到value的映射6、Collection 和 Collections的区别。
Collections是个java.util下的类,它包含有各种有关集合操作的静态方法。
Collection是个java.util下的接口,它是各种集合结构的父接口。 7、int 和 Integer 有什么区别?
Java 提供两种不同的类型:引用类型和原始类型(或内置类型)。
int是java的原始数据类型,Integer是java为int提供的封装类。Java为每个原始类型提供了封装类。
原始类型 封装类
boolean Boolean
char Character
byte Byte
short Short
int Integer
long Long
float Float
double Double
所有的封装类都是不能改变的,任何变动都将生成一个新的类。
对于数字特殊,系统为了提高效率,对于小于128的数字进行了内部缓冲,所以2个120的数字Integer有可能地址相等。
引用类型和原始类型的行为完全不同,并且它们具有不同的语义。引用类型和原始类型具有不同的特征和用法,它们包括:大小和速度问题,这种类型以哪种类型的数据结构存储,当引用类型和原始类型用作某个类的实例数据时所指定的缺省值。对象引用实例变量的缺省值为 null,而原始类型实例变量的缺省值与它们的类型有关。
从JDK5.0开始,原始类和包装类可以自动进行转换,我们可以在绝大部分int的地方使用Integer了. 8、下面哪些类可以被继承
java.lang.Thread (T)
java.lang.Number (T)
java.lang.Double (F)
java.lang.Math (F)
java.lang.Void (F)
java.lang.Class (F)
java.lang.ClassLoader (T)
9、面向对象的特征有哪些方面
抽象:抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面。抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节。抽象包括两个方面,一是过程抽象,二是数据抽象。
继承:继承是一种联结类的层次模型,并且允许和鼓励类的重用,它提供了一种明确表述共性的方法。对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以修改或增加新的方法使之更适合特殊的需要。
封装:封装是把过程和数据包围起来,对数据的访问只能通过已定义的界面。面向对象计算始于这个基本概念,即现实世界可以被描绘成一系列完全自治、封装的对象,这些对象通过一个受保护的接口访问其他对象。10、String s = “a” + “b” + “c” + “d” + “e”; 问此语句共创建了几个对象?
1个。
编译器编译的时候就处理为”abcde”了 。
就创建了一个
String s = “a” + “b” + “c” + “d” + “e”;
赋值符号右边的”a”、”b”、”c”、”d”、”e”都是常量
对于常量,编译时就直接存储它们的字面值而不是它们的引用
在编译时就直接讲它们连接的结果提取出来变成了”abcde”
该语句在class文件中就相当于String s = “abcde”
然后当JVM执行到这一句的时候, 就在String pool里找
如果没有这个字符串,就会产生一个 11、String s = new String(“xyz”);创建了几个String Object
两个对象,一个是“xyx”,一个是指向“xyx”的引用对象s。 12、Math.round(11.5)等於多少 Math.round(-11.5)等於多少
Math.round(11.5)返回(long)12,Math.round(-11.5)返回(long)-11; 13、short s1 = 1; s1 = s1 + 1;有什么错 short s1 = 1; s1 += 1;有什么错
short s1 = 1; s1 = s1 + 1;有错,s1是short型,s1+1是int型,不能显式转化为short型。可修改为
s1 =(short)(s1 + 1) 。short s1 = 1; s1 += 1正确。
14、在使用interface声明一个接口时,只可以使用( D)修饰符修饰该接口。
A、private B、protected C、private protected D、public 15、有以下方法的定义,请选择该方法的返回类型(