进程线程通信
Jogging-Snail
一只慢跑的蜗牛!
展开
-
共享内存和消息队列,FIFO,管道传递消息的区别
共享内存区是最快的可用IPC形式,一旦这样的内存区映射到共享它的进程的地址空间,这些进程间数据的传递就不再通过执行任何进入内核的系统调用来传递彼此的数据,节省了时间。 共享内存和消息队列,FIFO,管道传递消息的区别: 后者,消息队列,FIFO,管道的消息传递方式一般为 1:服务器得到输入 2:通过管道,消息队列写入数据,通常需要从进程拷贝到内核。转载 2015-06-27 11:25:53 · 1944 阅读 · 0 评论 -
linux fork()函数详解
一、fork入门知识 一个进程,包括代码、数据和分配给进程的资源。fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事,但如果初始参数或者传入的变量不同,两个进程也可以做不同的事。 一个进程调用fork()函数后,系统先给新的进程分配资源,例如存储数据和代码的空间。然后把原来的进程的所有值都复制到新的新进程中,只有少数转载 2015-07-02 09:20:55 · 430 阅读 · 0 评论 -
进程状态
三态模型:在多道程序系统中,进程在处理器上交替运行,状态也不断地发生变化。进程一般有3种基本状态:运行、就绪和阻塞。(1)运行:当一个进程在处理机上运行时,则称该进程处于运行状态。处于此状态的进程的数目小于等于处理器的数目,对于单处理机系统,处于运行状态的进程只有一个。在没有其他进程可以执行时(如所有进程都在阻塞状态),通常会自动执行系统的空闲进程。(2)就绪:当一个进程获得了除处理机以外转载 2015-07-11 16:21:29 · 535 阅读 · 0 评论 -
golang中并发sync和channel
golang中实现并发非常简单,只需在需要并发的函数前面添加关键字"go”,但是如何处理go并发机制中不同goroutine之间的同步与通信,golang 中提供了sync包和channel机制来解决这一问题.sync 包提供了互斥锁这类的基本的同步原语.除 Once 和 WaitGroup 之外的类型大多用于底层库的例程。更高级的同步操作通过信道与通信进行。type Cond func N转载 2016-10-27 14:17:55 · 2330 阅读 · 0 评论