一、String、StringBuffer、StringBuilder的区别
1.String类是字符串的首选类,其最大的特点是内容不允许修改。
2.StringBuffer和StringBuilder都是可修改的。
3.StringBuffer是在JDK1.0时提出的,属于线程安全的操作;StringBuilder是在JDK1.5时提出的,属于非线程安全的操作。
二、CharSequence接口
1.String: public final class String implements java.io.Serializable, Comparable, CharSequence;
2.StringBuffer: public final class StringBuffer extends AbstractStringBuilder implements java.io.Serializable, CharSequence;
3.StringBuilder: public final class StringBuilder extends AbstractStringBuilder implements java.io.Serializable, CharSequence ;
以后只要看到CharSequence描述的就是一个字符串。
三、AutoCloseable接口
在日后资源开发的处理上,以实现资源的自动关闭(释放资源),例如:在进行文件、网络、数据库开发的过程中,由于服务器的资源有限,所以使用之后才会关闭资源,这样才能被更多的使用者所使用。
范例:手工实现
interface IMssage extends AutoCloseable {
public void send();
}
class Message1 implements IMssage{
public boolean open() {
System.out.println("获取消息链接资源");
return true;
}
@Override
public void send() {
if(this.open()) {
System.out.println("发送消息");
}
}
public void close(){
System.out.println("资源关闭");
}
}
public class Demo1 {
public static void main(String[] args) {
try(Message1 message1 = new Message1();){
message1.send();
}catch(Exception e){
}
}
}
要跟异常一起捆绑使用,才能正常使用。
四、Runtime类
Runtime类是唯一一个与JVM运行状态有关的类,并且都会默认提供一个该类的实例化对象。
Runtime类的构造方法被私有化,所以一定会用到单例模式。
范例:获取cup的的内核数
public class RunTimeDemo {
public static void main(String[] args) {
Runtime run = Runtime.getRuntime();
System.out.println(run.availableProcessors());
}
}
除了以上方法之外,在Runtime里面还提供了以下四种方法:
1.获取最大可用内存空间:public long maxMemory();默认为本机内存的4分之一;
2.获取可用内存空间:public long totalMemory();默认为本机内存的64分之一;
3.获取空闲内存空间:public long freeMemory();
4.手工GC处理:public void gc();
范例:四种方法的应用
public class RunTimeDemo {
public static void main(String[] args) throws Exception {
Runtime run = Runtime.getRuntime();
System.out.println(run.maxMemory());
System.out.println(run.totalMemory());
System.out.println(run.freeMemory());
for(int i = 0; i < 30000; i++){
}
System.out.println(run.maxMemory());
System.out.println(run.totalMemory());
System.out.println(run.freeMemory());
Thread.sleep(1000);
run.gc();
System.out.println(run.maxMemory());
System.out.println(run.totalMemory());
System.out.println(run.freeMemory());
}
}
面试题:什么是GC?如何处理?
GC(Carbage Collector) 垃圾收集器,是可以由系统调用的垃圾释放功能,或者使用Runtime里面的gc()手工调用。
五、System类
System类中定义了许多常用的方法:
1.数组的拷贝:public static void arraycopy(Object src, int srcPos, Object dest, int destPos, int length)
2.获取当前日期时间数值:public static long currentTimeMillis();
3.进行垃圾回收:public static void gc();这里的gc()相当于Runtime.getRuntime().gc(),系统中只有一个gc()方法那就是 Runtime.getRuntime().gc()
六、Cleaner类
这是在jdk1.9提供的,主要是提供的是一个对象清理操作,其主要功能是进行finialize()方法的替代,在C++里面有两种特殊的函数:构造函数、析构函数(对象手工回收),在java里面垃圾空间都是通过gc()完成的,所以很多情况下是不需要使用这类析构函数的,也正是因为如此,java没有提供这方面的支持。
但是java本身也提供了给用户收尾的操作,每一个实例化对象在回收之前,给他一个喘息的机会,最初实现对象收尾的方法是Object中的finialize()方法,但是此方法在JDK1.9后不建议使用。建议开发者使用AutoCloseable或者使用java.lang.ref.Cleaner类进行回收处理。
七、对象克隆
克隆就是指对象的复制,需要使用Object中的clone()方法,protected native Object clone() throws CloneNotSupportedException;这里抛出了CloneNotSupportedException异常,虽然所有的类都会继承Object方法,但是不是所有的类都希望被克隆,所以要想实现对象克隆,要实现一个Cloneable接口,此接口没有任何方法,是因为此接口表现的是一种能力。
范例:clone实现对象克隆
class Member implements Cloneable{
private String name;
private int age;
public Member(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return "Member{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
@Override
protected Object clone() throws CloneNotSupportedException{
return super.clone();
}
}
public class ClearDemo {
public static void main(String[] args) throws Exception{
Member memberA = new Member("chenzhou",23);
Member memberB = (Member)memberA.clone();
System.out.println(memberA);
System.out.println(memberB);
}
}