- 什么是进程?
在内存中运行的应用程序,有自己独立的内存空间,一个进程可以拥有多个线程。
·
·
·
- 什么是线程?
进程中的一个执行单元,负责进程中程序的运行。
·
·
·
- 进程和线程的区别?
1.一个进程可以有多个线程。
2.进程之间的数据很难共享,因为每个进程是独立运行在自己的内存空间。
3.线程直接的数据共享就比较容易。
4.进程要比线程消耗的资源更多。
·
·
·
- 什么是死锁?
多个线程对同一资源进行竞争锁造成的一种阻塞现象,如果没有外力干涉程序就无法运行下去,这就是死锁。
·
·
·
- 怎么避免死锁?
首先死锁的形成需要四个条件,分别是
互斥条件:一个资源只允许一个线程访问,已经被访问的资源再被其他线程访问就会等待。
占有且等待:就是一个线程已经占有了一个或多个资源,但是它还需要占有被其他线程占有资源。
不可抢占条件:一个资源已经被其他线程占有,其他的线程不能因为需要这个资源就去尝试占有它。
循环等待:存在一个进程链,每一个进程都要占有下一个进程的资源才能正常推进。
·
·
·
- 只要打破这四个条件中的一个就可以避免死锁。
·
·
·
- 打破互斥条件:基本不可能打破,因为线程本身就是互斥的。
- 打破占有且等待条件:一个进程正常推进过程中如果拥有全部的资源才允许推进,否则就进入等待,等满足全部资源条件再执行。
- 打破不可抢占条件:当进程去尝试占有其他进程的资源得不到满足时,退出所占有的资源进行等待。
- 循环等待:使资源访问设定一个有序策略。
·
·
·
- 线程池的理解:
线程池是一种池化技术,也是一种多线程处理形式,任务的执行交由线程池来管理,
在执行结束之后可以将线程重新放回线程池,避免了线程的频繁创建,提高资源的使用率。