进程
是具有一定独立功能的程序,它是系统进行资源分配和调度的一个单位,重点在系统调度和单独的单位。也就是说,进程是可以独立运行的一段程序。
线程
是进程的一个实体,是CPU调度和分派的基本单位,是比进程更小的能独立运行的基本单位。线程基本上不拥有系统资源,在运行时只是暂用一些计数器、寄存器和栈。
进程间的通信方式
1.无名管道(pipe):管道是一种半双工通信方式,数据只能单向流动,而且只能在具有亲缘关系(通常指父子进程关系)的进程间使用。
2.高级管道(popen):将另一个程序当作一个新的进程在当前程序进程中启动,算作是当前程序的子进程。
3.有名管道(named pipe):也是半双工的通信方式,但是允许无亲缘关系进程间的通信。
4.消息列队(message queue):是由消息的链表,存放在内核中并由消息队列标识符标识。
5.信号量(semophore):是一个计数器,可以控制多个进程对共享资源的访问。常作为一种锁机制,防止某进程正在访问共享资源时其他进程也访问该资源。
6.信号(sinal):是一种比较复杂的通信方式,用于通知接收进程某个事件已经发生。
7.共享内存(shared memory):映射一段能被其他进程所访问的内存,这段共享内存由一个进程创建,但多个进程都可以访问。
8.套接字(socket):可用于不同机器间的进程通信。
线程间的通信方式
1.全局变量:进程中的线程间内存共享。
2.Message消息机制:常用的Message通信的接口主要有两个:PostMessage(线程向主窗口发送消息)和PostThreadMessage(任意两个线程间的通信接口)。
3.CEvent对象:CEvent为MFC中的一个对象,可以通过对CEvent的触发状态进行改变,从而实现线程间的通信和同步。