以下知识收集于老师的教学,网上的知识。若有不妥之处和不便之处,请通知本人修改。谢谢大家。
这篇文章相当于自己理解知识后,再重新通过自己输出出来,加深自己对知识和概念的印象。
所以会陆续更新......
系统编程篇
什么是进程,什么是线程?
进程,是系统资源分配的最小单位,拥有独立的地址内存。每启动一条进程,系统都会建立数据表来维护其代码段,堆栈段,数据段。进程的创建和开销较大。进程间的通信较复杂,进程程序相对较安全,进程间互不影响。
线程,是系统执行的最小单位,没有独立的地址内存,线程创建和删除开销小,线程间通信较方便,多线程不易维护,线程间互相影响。
多进程与多线程的区别?
多进程的进程间各自拥有独立的地址内存,多线程线程间共享地址内存。
速度。多线程产生的速度快,通信快,切换快。
资源利用率。多线程资源利用率高,因为在共享地址内存上。
同步问题。线程使用公共资源时需要同步机制。
进程间的通信方式有哪些?
匿名管道(pipe),半双工的通信方式,字节只能单方向流动,并且只能在亲缘关系的进程间使用。
有名管道(name pipe),与匿名管道相似,但不需要亲缘关系也可以通信。
异步通信,用发送信号的方式通知进程中事件的发生。
IPC通信机制的以下三种,
消息队列(message queue)。消息链表,存放在内核中并由消息队列标识符进行标识,克服了信号传递信息少,管道只能承载无格式字节流和缓冲区大小受限等缺陷。
共享内存。映射一段能被其他进程访问的共享内存,一般与信号量配合使用。
信号量。相当计数器。用来控制多个进程对于共享资源的访问。常作用为锁机制,用于不同进程间或同一进程不同线程之间的同步。