3.41.为什么要使用多线程?
参考答案:
多线程就像是人体一样,一直在并行的做许多工作,例如,人可以同时呼吸,血液循环,消化食物的.多线程可以将一个程序划分成多个任务,他们彼此独立的工作,以方便有效的使用处理器和用户的时间.
3.42.启动一个线程是用run()还是start()?
参考答案:
启动一个线程是调用start()方法,使线程所代表的虚拟处理机处于可运行的状态,这意味着它可以由JVM调度并执行.这并不意味着线程就会立即运行.run()方法可以产生必须退出的标志来停止一个线程.
3.43.sleep()和wait()有什么区别?
参考答案:
sleep方法是线程类(Thread)的方法,导致此线程暂停执行指定时间,把执行机会给其他线程,但是监控状态依然保持,到时后会自动回复.调用sleep不会释放对象锁.wait是Object类的方法,对象调用wait方法导致本线程放弃对象锁,进入等待此对象的等待锁定池,只有针对此对象发出notify方法(或notifyAll)后本线程才进入对象锁定池准备获得对象锁进入运行状态.
3.44.sleep和yield的区别?
参考答案:
yield方法只是让出分配给自己的CPU时间片,并且会立刻进入Runnable状态参与CPU时间的竞争,若程序中没有其它线程,那么该线程马上就会开始往下执行;sleep会进入Blocked状态,等待时间结束时间的发生,然后进入Runnable状态参与CPU时间的竞争.
3.45.当一个线程进入一个对象的一个synchronized方法后,其它线程是否可以进入此对象的其它方法?
参考答案:
其它线程只能访问该对象的其它非同步方法,同步方法则不能进入.
3.46.请说出你所知道的线程同步的方法
参考答案:
实现同步的方法为使用synchronized关键字,实现方式:
1)同步方法.可以是静态和非静态方法,不可以是抽象和接口方法.当一个线程调用这个对象的同步方法,则这个对象的其他所有同步方法将被锁定,不能调用,但可以调用非同步方法.非静态同步方法锁定的是方法所属的主体对象自身.静态同步方法锁定的是主体类对应的Class类型的对象,所以静态同步方法只跟所属类的其他静态同步方法相互制约.
2)同步块.锁定一个指定的对象,来对同步块中的代码进行同步.
3.47.同步和异步有何异同,在什么情况下分别使用它们?举例说明
参考答案:
如果数据将在线程间共享,使用同步编程.例如正在写的数据以后可能被另一个线程督导,或者正在读的数据可能已经被另一个线程写过了,那么这些数据就是共享数据,必须进行同步存取.当应用程序在对象上调用了一个需要花费很长时间来执行的方法,并且不希望让程序等待方法的返回时,则使用异步编程,在很多情况下采用异步途径往往更有效率,比如发送短信.
3.48.简述synchronized和java.util.concurrent.locks.Lock的异同
参考答案:
相同点:Lock和synchronized都可以实现了线程同步;
不同点:Lock有比synchronized更精确的线程语义和更好的性能.synchronized会自动释放锁,而Lock一定要求程序员手工释放,并且必须在finally从句中释放.
3.49.分别用Java中多线程的两种方法实现:输出字符串”Hello”,要求每间隔一秒输出一个字母
参考答案:
public class Test{
public static void main(String[] args{
TestThread1 tt1 = new TestThread1();
tt1.start();
Thread tt2 = new Thread(new Thread2());
tt2.start();
}
}
class TestThread1 extends Thread{
public void run(){
char[] str = {'H','e','l','l','o'};
try{
for(int i = 0; i < str.length; i++){
System.out.println(str[i]);
sleep(1000);
}
System.out.println();
} catch(Exception e) {
e.printStackTrace();
}
}
}
class TestThread2 implements Runnable{
public void run(){
char[] str = {'H','e','l','l','o'};
try{
for(int i = 0; i < str.length; i++){
System.out.println(str[i]);
sleep(1000);
}
System.out.println();
} catch(Exception e) {
e.printStackTrace();
}
}
}
3.50.线程池是什么?
参考答案:
当一个程序中若创建大量线程,并在任务结束后销毁,会给系统带来过度消耗资源,以及过度切换线程的危险,从而可能导致系统崩溃.为此我们应使用线程池来解决这个问题.
首先创建一些线程,它们的集合成为线程池,当服务器接收到一个客户请求后,就从线程池中取出一个空闲的线程位置服务,服务结束后不关闭该线程,而是将该线程还回到线程池中.当线程池的编程模式下,任务是提交给整个线程池,而不是直接交给某个线程,线程池在拿到任务后,它就在内部找有无空闲的线程,再把任务交给内部某个空闲的线程,一个线程同时只能执行一个任务,但可以同时向一个线程池提交多个任务.