Java高级面试-多线程
一、多线程创建
1.thread/runnable
1)继承Thread类
2)实现Runnable接口
2.两种启动线程方法的区别
Thread类实现了Runable接口。
都需要重写里面Run方法。
区别
实现Runnable的类更具有健壮性,避免了单继承的局限。
Runnable更容易实现资源共享,能多个线程同时处理一个资源。
3.star方法和run方法的区别
区别:调用start方法实现多线程,而调用run方法没有实现多线程
Start:
用start方法来启动线程,真正实现了多线程运行,这时无需等待run方法体代码执行完毕而直接继续执行下面的代码。通过调用Thread类的start()方法来启动一个线程,这时此线程处于就绪(可运行)状态,并没有运行,一旦得到spu时间片,就开始执行run()方法,这里方法run()称为线程体,它包含了要执行的这个线程的内容,Run方法运行结束,此线程随即终止。
Run:
run()方法只是类的一个普通方法而已,如果直接调用Run方法,程序中依然只有主线程这一个线程,其程序执行路径还是只有一条,还是要顺序执行,还是要等待run方法体执行完毕后才可继续执行下面的代码,这样就没有达到写线程的目的。
总结:调用start方法方可启动线程,而run方法只是thread的一个普通方法调用,还是在主线程里执行。
二、线程间通信
1.synchronized关键字
1)synchronized对象锁
2)synchronized来实现线程间通信
不同线程去共享同一个变量来进行锁的管理
3)synchronized/volatile
使用volatile声明的变量,只能从主内存中获取,不复制到线程中,当该变量改变后,所有线程中该变量都发生改变
4)synchronized/lock
悲观锁、乐观锁
2.sleep/wait
3.wait/notify机制
三、线程池
1.好处
1)降低资源消耗
2)提高响应速度
3)提高线程的可管理性
2.ThreadPoolExecutor
new ThreadPoolExecutor(corePoolSize,maximumPoolSize,
keepAliveTime,milliseconds,runnableTaskQueue,handler);
创建线程池->提交任务
3.线程池的工作流程
1)首先线程池判断基本线程池是否已满
2)其次线程池判断工作队列是否已满
3)最后线程池判断整个线程池是否已满