- 1、解决死锁?
- 鸵鸟策略:装看不见
- 死锁预防:破坏互斥、不剥夺、环路等待、请求和保持四个条件
- 死锁的避免:
- 线程启动拒绝:如果请求可能引起死锁,拒绝
- 资源分配拒绝:如果增加线程可能引起死锁,不允许启动
- 死锁的检测和恢复:
- 进程同步?
- 临界区:最多允许一个进程进入,本质为代码片段。故进程进入之前,需检查临界区。
- 互斥量:一个互斥量制约多个进程。
- 信号量:整型变量。自减为P自加为V。
- P操作:执行后<0,进入阻塞。
- V操作:操作后≤0,会唤醒进程。
- 6、进程和线程、协程
- 进程:资源分配的基本单位。是程序的一个执行、实例
- 线程:资源调度的基本单位,最小的操作单元
- 协程:协程不是由操作系统管理,而是应用程序。可以提升性能,省去了线程的上下文切换。也是“伪多线程”。
- 优点: 跨平台,跨结构,相比线程省资源
- 缺点: 无法利用多核资源,阻塞操作时会阻塞掉整个程序。
- 适用于IO密集型任务。
- 7、可重定位目标文件
- 可重定位目标文件:二进制代码和数据,由各个数据节(section)构成,从地址0开始。
- 可执行目标文件:可运行的二进制代码和数据。
- 共享目标文件:一种特殊类型的可重定位目标文件,动态加载链接。
- 8、统调用和库函数
- 系统调用:程序向系统内核请求服务,范围包括硬件相关、进程相关,他是程序和操作系统之间的接口,开销较大(用户和内核间来回切换),移植方面兼容性差。
- 库函数:将常用的文件写入同一个文件中,发生在用户地址空间。移植性较好,开销较小。
- 8、四种引用
- 强引用: 对象和引用强关联。永远不会被自动回收。只可使用
o=null
回收。Object o = new Object();
- 弱引用: 和软引用类似,关键字从
weakrefrence
变成softrefrence
.只要出发GC就回收。SoftReference<Student>studentSoftReference=new SoftReference<Student>(new Student());
- 软引用: 软引用就是把对象用SoftReference包裹一下,当我们需要从软引用对象获得包裹的对象,只要get一下就可以了。内存不足时触发GC,GC后还不足,就会回收软引用包裹的对象。
- 虚引用: ¥%&……&())————