每天进步一点~
01、问:空字符串的作用
package com.neuedu.nineteen;
public class Test {
public static void main(String[] args) {
String s="";
for (char i = 'a'; i < 'd'; i++) {
s=s+i;//输出abc
s=i+s;//输出cba
}
System.out.println(s);
}
}
答:如题所示,当进行s=s+i的时候,s在前和s在后输出的结果是相反的。空字符串在前时是正着输出,空字符串在后是逆着输出
02、问:short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
答:第一种情况,s1是short类型,在计算s1=s1+1时,前边是short型,后边是int型,不能自动转换。由于没有强转,要报类型错误。
第二种情况,使用了+=这个java自带的运算符,java内部会对其进行处理,所以编译通过,不会报错。
03、问:说说&和&&的区别。
答:&和&&都表示与的意思,既表达式俩边都成立,结果才成立。
&&是逻辑运算符,&&有短路作用,既当表达式左边为假时,不需要计算右边,整个的结果直接为假;&没有
&是位运算符,&的左右俩边可以是布尔类型,也可以是数值;&&俩边只能是布尔类型
04、问:Integer与int的区别
答:int是八大基本数据类型之一,Integer是int的封装类。
int的默认值是0,Integer的默认值是null,此时的0代表这个数赋值0,而null代表没接收到这个值
Integer提供了与整数相关的操作,int没有
05、问:==与equals的区别
答:对于基本数据类型==是判断的值是否相等;对于引用数据类型是判断是否为同一个对象
equals是判断值是否相等
06、问:override (重写) 和 overload (重载) 的区别
答:
- 重载是在一个类中,方法名相同,参数列表不同(参数类型和参数个数)的一种现象
- 重载与返回值类型无关
- 不能通过访问修饰符进行重载
- 重写是在父子类中,子类重写父类的方法,要求方法名与参数列表,返回值类型完全相同。子类重写父类规范要在子类的方法前加注解@Override
- 重写的返回值类型可以改,但只能是父子类
- 重写的访问修饰符得大于等于原来的
- 不能重写私有方法
- 参数列表的顺序与类型必须一样,变量名可不同
07、问:接口与抽象类的区别
答:
- 抽象类是用abstract修饰的类,抽象类不能new对象。
- 接口是比抽象类还抽象的“类”
区别:
- 抽象类中可以有抽象方法也可以有非抽象方法,接口中只能有抽象方法
- 抽象类中可以有成员变量,接口中只能有常量,用public static final修饰,默认可不写
- 抽象类有构造方法,接口没有构造方法
- 抽象类中的方法的访问修饰符可以是public,protected,默认;接口中方法的访问修饰符只能是public,并且默认值是public abstract
- 抽象类中可以有静态方法,接口中不能有静态方法(JDK1.8之后接口中增加了静态方法和默认方法)。(static是类名直接调用,abstract是子类实现创建对象调用,如果一起修饰,自相矛盾了)
- 一个类可以实现多个接口,只能继承一个抽象类
08、问:JDK,JRE,JVM的联系与区别
答:
- JDK是java开发工具包,JDK包括JRE,类库,java工具
- JRE是java运行环境,JRE包括JVM,JRE里有运行.class的java.exe
- JVM是java虚拟机,java虚拟机在执行字节码时,把字节码解释成具体平台的机器指令执行,这也是java语言跨平台的根源,是“一次编译,到处运行”的原
- 联系:
- JDK下的jre文件夹下有俩个文件夹lib和bin;在这里可以理解为bin就是jvm,lib就是类库;所以JRE=JVM+类库
- 我们利用JDK开发属于自己的java程序,javac编译成字节码,在JRE上运行这些字节码,JVM解析这些字节码,最终映射到CPU指令集或OS的系统调用
- 区别:
- JDK与JRE的区别:
- JDK有javac.exe;JRE没有
- JDK是开发环境,JRE是运行环境
- JRE与JVM的区别:
- 1.JVM执行.class需要JRE下lib类库的支持(尤其是rt.jar
09、问:在java中如何跳出多层循环
答:可以利用“打标签”的形式,举个栗子:
ok: for (int i = 0; i < 3 ; i++) {
for (int j = 0; j < 4; j++) {
for (int k = 0; k < 5; k++) {
break ok;
}
}
}
10、问:String s = new String("xyz");创建了几个String Object
答:创建了俩个对象或一个对象,如果常量池中没有“xyz”第一次=在常量池中创建了一个字符串对象,第二次new又创建了一个字符串引用对象;如果常量池中有“xyz”,那就只是new的时候创建了一个对象。
11、问:Java有没有goto?
答:java中的保留字,现在在java中没有使用。
12、问:String等三者的区别?
答:
- String是不可变字符串,StringBuilder和StringBuffer是可变字符串
- 从运行效率看,StringBuilder>StringBuffer>String
- StringBuilder非线程安全,StringBuffer线程安全
总结:String适合少量字符串的操作、StringBuilder适合单线程大量数据的操作、StringBuffer适合多线程大量数据的操作
13、问:静态和实例的区别?
答:
- 静态变量用static修饰,实例变量不需要
- 静态变量是属于类的,实例变量是属于对象的
- 当一个对象把静态变量的值改了,其他对象调用时它的值也跟着变了;实例变量是独立的,一个对象修改它的值不会影响另一个对象调用它的值
14、问:switch语句能否作用在byte上,能否作用在long上,能否作用在String上?
答:可以作用在byte上,因为byte能自动转为int;不能作用在long上,long转int不能自动转,需要强转;在jdk1.7以后可以作用在String上
15、问:使用final关键字修饰一个变量时,是引用不能变,还是引用的对象不能变?
答:是引用不能变,即对象的指向不能变,但引用的对象即引用里的值是可以变得,因为它又没有用final修饰。
基本数据类型的值是不能更改的 比如 final int a=1;a=2;那肯定编译也过不了。因为a是final修饰的不可改变;a原来指向1,后来指向2;a的指向变了。final int[] arr= {1,2,3}; arr[0]=2;这种是可以的。因为arr的指向并没有变 只不过它里边的值可以变。
16、问:请说出作用域public,private,protected,以及不写时的区别
答:
17、问:构造器Constructor是否可被override?
答:构造器不能被重写,因为构造器不能被继承,但它可以重载
18、问:try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,什么时候被执行,在return前还是后?
答:会执行,首先明确一点是“finally块中的代码始终要执行”,也就是说不管怎样,它都会执行。并且在return前执行,执行finally后通过return退出。看下边的例子:
public class Test {
public static String output="";
public static void foo(int i){
try{
if(i==1){
throw new Exception();
}
output+="1";
}catch(Exception e){
output+="2";
return;
}finally{
output+="3";
}
output+="4";
}
public static void main(String[] args) {
foo(0);
foo(1);
System.out.println(output);//13423
}
}
19、问:final, finally, finalize的区别
答:
- final修饰属性,方法,类;分别表示属性不可变,方法不可覆盖,类不可继承
- finally是异常中的关键字,始终要执行的代码放在finally块中
- finalize是Object的一个方法,是垃圾回收机制,重写此方法可以回收其他资源,如文件关闭。JVM不保证此方法总被调用
20、问:启动一个线程是用run()还是start()
答:用 start() 方法,start方法内调用了run方法,如果直接调用run方法,那么就相当于没有开启线程而直接调用的run方法。
21、问:Vector和ArrayList的区别
答:
- ArrayList和Vector是基于数组的,有下标,有序,元素可重复。
- Vector就是把ArrayList中的所有方法加了synchronized
所以,Vector是线程安全的,ArrayList是线程不安全的,但Collections下有静态方法,synchronizedList来代替Vector,Vector在日常中很少使用。
22、问:System.out.println()分别代表什么?
答:System.out.println()是我们日常使用最多的输出语句,其中System是一个类,out是这个类中的一个静态常量对象,是PrintStream类型的,println()是PrintStream类的方法,用于输出。
23、问:比较throw和throws
答:
- throws是声明异常的关键字,其后是一个异常类,比如throws IOException
- throw是抛出异常的关键字,其后跟着一个异常对象,比如throw new IOException()
24、问:垃圾回收的原理和优点
答:垃圾回收是一个低级别的线程运行,在不知情的情况下对堆内存中的闲置的或者长期没使用的对象进行回收。
优点:
1)不需要考虑内存管理;
2)防止内存泄漏,有效的管理内存;
3)对象不再有作用域的问题,只有对象的引用存在作用域;
4)程序员不能实时的对某个对象或所有对象调用垃圾回收器
25、问:super.getClass()方法调用
import java.util.Date;
public class Test extends Date {
public static void main(String[] args) {
new Test().test();
}
public void test() {
System.out.println(super.getClass().getName());
}
}
答:输出的结果是Test
原因:由于getClass()在Object类中定义成了final,子类不能覆盖该方法,所以,在 test方法中调用super.getClass().getName()方法,等效于调用getClass().getName()方法,所以,super.getClass().getName()方法返回的也应该是Test。
如果想得到父类的名称,应该用如下代码:
getClass().getSuperClass().getName();
26、问:sleep() 和 wait() 有什么区别?
答:
- 1.sleep是Thread类下的方法;wait是Object下的方法
- sleep是使线程休眠,不释放锁;wait是使线程等待,释放锁
- sleep让出的是cpu,如果此时代码是加锁的,那么即使让出了CPU,其他线程也无法运行,因为没有得到锁;wait是让自己暂时等待,让出同步锁,等待其他线程执行完了,再来执行自己
- 调用sleep进入阻塞状态;调用wait进入就绪状态
27、问:线程的基本概念、线程的基本状态以及状态之间的关系
答:线程是执行和调度的基本单位,是进程中一个执行过程,一个进程有多个线程,线程间共享内存,如果是单核CPU,那么CPU一会访问a线程,一会访问b线程,线程之间切换很快,给人的感觉是他们在同步执行。
线程的基本状态分为:新生状态,就绪状态,运行状态,阻塞状态,死亡状态
关系:
- 调用start()方法线程转为就绪状态
- 调用wait()方法线程转为就绪状态
- 调用sleep()方法线程转为阻塞状态
- 就绪,运行之间是相互转换的
28、问:Collection 和 Collections的区别
答:
- Collection是集合的最顶层接口,这个接口下有List和Set俩个子接口
- Collections是针对集合的一个帮助类,里边有很多静态方法,用于集合的搜索排序等
29、问:两个对象值相同(x.equals(y) == true),但却可有不同的hash code,这句话对不对?
答:
- 如果是在hashMap中不对,反之这句话是对的。
- 如果对象保存在hashMap或hashSet中,那么她们的值相等,hashCode也一定相等
- 如果没有保存在hashMap或hashSet中,那么与hashCode没什么关系了,她们的hashCode值可以不等
30、问:说出一些常用的类,包,接口,请各举5个
答:
- 常用的类:String, Arrays, Collections, System, Integer, BufferedReader, BufferedWriter
- 常用的包:util, io, sql, awt, list, lang
- 常用的接口:List, Map, Set, Serializable, Comparable, Runnable
Thanks~
..