1.进程和线程的区别
进程是CPU分配资源的最小单元,线程是执行程序的最小单元。
内存:每个进程有自己独立的页表和虚拟地址,同一个进程内的多个线程共享同一份页表和虚拟地址。在进程间切换时,需要先进入内核态访问内核页表再进行切换,上下文切换的开销较大。而线程间的上下文切换消耗较小。
通信:进程间的通信需要使用信号量 信号 管道 命名管道 共享内存 消息队列。线程共享资源可以直接访问。
安全性:进程由于内存隔离,安全性更强。线程由于共享内存空间,一个线程的错误可能会影响整个进程的稳定性。
2.进程间的通信方式有哪些?
管道:单向通信 只存在于父子进程间
命名管道:单向通信 但可以存在于任意进程之间
信号:一般用于异常情况下的直接中断
信号量:计数器,一般用于锁。
消息队列:存储在内核态,两个进程交流可以把信息先放到消息队列,然后再返回正常运行。但切换会造成开销。
共享内存:两个进程的一部分虚拟地址 映射到同一块物理地址 这样就可以访问相同的数据。
Socket:用于客户端和服务器之间进程的通信
1.Linux查看文件的命令有哪些
2.多线程调度的实现方式,比如一个单核中有五个线程
3.什么时候会产生死锁?怎么解决死锁?刚刚说的四个条件,是不是只要有一个不满足,死锁就不能成立?