进程与线程与进程通信BLABLA
2016-05-10 20:46
274 查看
进程,简单来说,运行中的程序,他享有OS相应资源分配,什么叫资源分配呢,呵呵,就是给你相应的CPU和内存让你完成你自己的事。当然,资源分配必然会有资源的竞争和共享,这是必须的嘛,因为我们从小学就知道大自然的资源是有限的,当然要好好爱护资源。怎么好好爱护资源,这之中当然要说说进行的3个状态,阻塞,运行,就绪了。
当然,这3个状态的转换相应太简单了,我不太想说,我这里主要想说说进程的通信。
1.管道
看到管道这个词我第一反应就是水管,呵呵,在现实生活中水管谁不见过,水管嘛,总的来说就是一个端口出水一个端口进水。进程中的管道也是类似,他之中一端是用来读的,一端是用来写的,就是有两个进程,一个进程持有读端口,另一个进程持有写端口,一个进程只能读,而另一个进程只能写。就这样。
2.信号
信号在我看来,他的方式很像TCP/IP协议的通信,当然这里我还不太清楚TCP/IP协议是用什么做的,我只能说他很像。他是在两个进程之间我们可以叫他服务端和客户端建立一个长连接,连接好之后对相应的服务端和客户端进行相应的通信。我这么说是不是觉得很像啊,可能也是我理解错了,欢迎指正。他跟管程相比就是他连接的两个进程都可以进行读或者写操作。
3.信号量
呵呵,上面两个都是需要连接。下面我说这个是不需要连接的,这下你懂了吧,他只适合传递一些比较小的数据,例如管理线程程同步。
4.共享内存
上面几个可以满足相应的进程通信了,但是,当两个线程的关系比较密切,例如两个线程都是一个进程里面的,这时候我们就需要用到共享内存了,共享内存相对于前面一些通信方法的优点是效率高,呵呵,读写都是一个内存,效率当然高了。但是也带来了一些缺点,如,不安全。
5.消息队列
开始听起来消息队列挺像管道的。后面看了他的区别,消息队列可以同时支持多个进程通信,而管道只是两个进程间的通信。
说完了,不知道对大家有没有用,另外,欢迎指正我的理解上的错误。
当然,这3个状态的转换相应太简单了,我不太想说,我这里主要想说说进程的通信。
1.管道
看到管道这个词我第一反应就是水管,呵呵,在现实生活中水管谁不见过,水管嘛,总的来说就是一个端口出水一个端口进水。进程中的管道也是类似,他之中一端是用来读的,一端是用来写的,就是有两个进程,一个进程持有读端口,另一个进程持有写端口,一个进程只能读,而另一个进程只能写。就这样。
2.信号
信号在我看来,他的方式很像TCP/IP协议的通信,当然这里我还不太清楚TCP/IP协议是用什么做的,我只能说他很像。他是在两个进程之间我们可以叫他服务端和客户端建立一个长连接,连接好之后对相应的服务端和客户端进行相应的通信。我这么说是不是觉得很像啊,可能也是我理解错了,欢迎指正。他跟管程相比就是他连接的两个进程都可以进行读或者写操作。
3.信号量
呵呵,上面两个都是需要连接。下面我说这个是不需要连接的,这下你懂了吧,他只适合传递一些比较小的数据,例如管理线程程同步。
4.共享内存
上面几个可以满足相应的进程通信了,但是,当两个线程的关系比较密切,例如两个线程都是一个进程里面的,这时候我们就需要用到共享内存了,共享内存相对于前面一些通信方法的优点是效率高,呵呵,读写都是一个内存,效率当然高了。但是也带来了一些缺点,如,不安全。
5.消息队列
开始听起来消息队列挺像管道的。后面看了他的区别,消息队列可以同时支持多个进程通信,而管道只是两个进程间的通信。
说完了,不知道对大家有没有用,另外,欢迎指正我的理解上的错误。
相关文章推荐
- c++构造json数组
- 通过interface的Runnable实现线程合并(join),涉及setName,getName,sleep
- Codeforces Round #169 (Div. 2) E. Little Girl and Problem on Trees(给出一棵树,对距离某个点d范围之内的所有点+x,查询某个点的值)
- 本地组策略的一些安全属性
- 345. Reverse Vowels of a String
- 深刻理解Python中的元类(metaclass)
- 学习总结
- 2016/05/10 thinkphp 3.2.2 ①系统常量信息 ②跨控制器调用 ③连接数据库配置及Model数据模型层 ④数据查询
- POJ 3414 Pots
- leetcode : Counting Bits
- lvs+keepalived实现高可用群集配置详解
- python re.findall 遇到的小问题
- HTTP获取部分内容的范围请求
- DataTable某一列的最大值
- JAVA之路003--if和switch的区别
- <Unity-UGUI>使用Mask, 正确的裁减非默认材质UI对象
- for循环和switch语句—5.10学习总结
- 约瑟夫问题
- Hibernate投影查询
- 关联分析-FP树法python注解