Java笔试面试总结——基础篇
Java基础篇
一、 接口
传送点:深入浅出,理解Java接口
二、 反射
三、 String
1.Java的String类型为什么是不可变的(百度)
String类中的成员变量:
private final char value[];
private final int offset;
private final int count;
执行完String s="ABCabc"这句代码之后,真正的内存布局应该是这样的:
value,offset和count这三个变量都是private的,并且没有提供setValue,setOffset和setCount等公共方法来修改这些值,所以在String类的外部无法修改String。
因为字符串是不可变的,所以多线程是安全的,同一个字符串实例可以被多个线程共享。这样便不用因为线程安全问题而使用同步。字符串自己便是线程安全的,在大量使用字符串的情况下,可以节省内存空间,提高效率。
2.获取www.baidu.com最后一个点的内容“com”(蘑菇街)
String str="www.baidu.com";
int i=str.lastIndexOf('.');//返回指定字符在此字符串中最后一次出现处的索引
String str1=str.substring(i+1,str.length());//返回一个str的子字符串。
System.out.println(str1);
3.String a=“abc” ;String b=“a”+“bc”;a==b?(网易)
String a="abc";String b="a"+"bc";
if(a==b){
System.out.println("true");
}
else{
System.out.println("false");
}//输出为:true 只生成一个字符串,保存在字符串常量池中
四、 String和byte[]之间的转化
Java如何把byte类型转换成字符串
- 常规的String转byte[]
public static byte[] strToByteArray(String str){
if(str==null){
return null;
}
byte[] byteArray=str.getBytes();
return byteArray;
}
- 常规的byte[]转String
public static String byteArrayToStr(byte[] byteArray){
if(byteArray==null){
return null;
}
String str=new String(byteArray);
return str;
}
- byte[]转化为十六进制的String
private static final String hexDigits[]={"0", "1", "2", "3", "4", "5","6", "7", "8", "9", "a", "b", "c", "d", "e", "f"};//单个字节转换成16进制的字符串
private static String byteToHexString(byte b){
int n=b;
if(n<0) n+=256;
int d1=n/16;//取出高4位
int d2=n%16;//取出低4位
return hexDigits[d1]+hexDigits[d2];
}//将字节数组转换成16进制的字符串
private static String byteArrayToHexString(byte b[]){
StringBuffer resultSb=new StringBuffer();
for(int i=0;i<b.length;i++)
resultSb.append(byteToHexString(b[i]));
return resultSb.toString();
}//测试代码
public static void main(String[] args){
byte[] b={10,11};
String s=MD5Util.byteArrayToHexString(b);
System.out.println(s);
}//运行结果:0a0b
- MD5工具类
public class MD5Util{
private static String byteArrayToHexString(byte b[]){
StringBuffer resultSb=new StringBuffer();
for(int i=0;i<b.lenth;i++)
resultSb.append(byteToHexString(b[i]));
return resultSb.toString();
}
private static String byteToHexString(byte b){
int n=b;
if(n<0)
n+=256;
int d1=n/16;
int d2=n%16;
return hexDigits[d1]+hexDigits[d2];
}
public static void main(String[] args){
byte[] b={10,11};
String s=MD5Util.byteArrayToHexString(b);
String s1=MD5Util.MD5EncodeUtf8("101112a");
System.out.println(s1.length());
}//返回大写MD5
private static String MD5Encode(String origin,String charsetname){
String resultString=null;
try{
resultString =new String(origin);
MessageDigest md=MessageDigest.getInstance("MD5");
if(charsetname==null||" ".equals(charsetname))
resultString=byteArrayToHexString(md.digest(resultString.getBytes()));
else
resultString=byteArrayToHexString(md.digest(resultString.getBytes(charsetname)));
}catch(Exception exception){}
return resultString.toUpperCase();
}
public static String MD5EncodeUtf8(String origin){
origin=origin+ProperiesUtil.getProperty("password.salt"," ");
return MD5Encode(origin,"utf-8");
}
private static final String hexDigits[]={"0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "a", "b", "c", "d", "e", "f"};
}
五、 ClassNotFoundException
意思就是找不到指定的class,遇到的场景:
- 调用class的forName方法时,找不到指定的类。
- ClassLoader中的findSystemClass()方法时,找不到指定的类。
- ClassLoader中的loadClass()方法时,找不到指定的类
package test;
public class test{
public static void main(String[] args){
try{
Class.forName("test666.hello");
}catch(ClassNotFoundException e){
e.printStackTrace();
}
}
}
解决办法:检查类名是否正确、或是否存在该类。
补充:NoClassDefFoundError 常见的场景就是:
- 类依赖的class或者jar不存在。
- 类文件存在,但是存在不同的域中
- 大小写问题,Javac编译的时候是无视大小的,很有可能你编译出来的class文件就与想要的不一样!这个没有做验证。
六、 HashCode
面试题:
hashCode的作用是什么?如果要重写需要注意哪些点?(腾讯面试)
使用HashMap时重写哪两个方法,为什么要重写?(百度面试)
hashCode简介
public int hashCode():hashCode是根类Object中的方法。默认情况下,Object中的hashCode()返回对象的32位jvm内存地址。也就是说如果对象不重写该方法,则返回相应对象的32位JVM内存地址。
hashCode注意点
关于hashCode方法,一致的约定:
- 重写了equals方法的对象必须同时重写hashCode()方法。
- 如果两个对象equals相等,那么这两个对象的HashCode一定也相同。
- 如果两个对象的HashCode相同,不代表两个对象就相同,只能说明这两个对象在散列存储结构中,存放于同一个位置。
hashCode作用
从Object角度看,JVM每new一个Object,它都会将这个Object丢到一个Hash表中去,这样的话,下次做Object的比较或者取这个对象的时候(读取过程),它会根据对象的HashCode再从Hash表中取出这个对象。这样做的目的是提高取对象的效率,若HashCode相同再去调用equals。
为什么重写hashCode
实际开发中在HashMap或者HashSet中如果不重写hashCode和equals方法的话会导致我们存对象的时候,把对象存进去了,取的时候却取不到想要的对象。重写了hashCode和equals方法可以迅速的在HashMap中找到键的位置。
- 重写hashCode是为了保证相同的对象会有相同的hashCode。
- 重写equals是为了保证在发生冲突的情况下取得到Entry对象(也可以理解是key或是元素)
一、 接口
一、 接口
一、 接口
一、 接口
一、 接口
一、 接口
上一篇: Android面试题及其答案
下一篇: 垃圾回收机制