对java和c语言之中进程间通信的理解

来源:互联网 发布:淘宝服装拍摄后期处理 编辑:程序博客网 时间:2024/06/03 13:52

进程间通信:
1 管道:
java里是读写管道文件即可。c语言利用mkfifo创建两个管道文 件,java读写管道文件即可。
c语言就是pipe。例子:linux 命令:ps -ef | grep ‘XXX’.解释:ps和grep命令都是一个进程,ps进程的标准输出给了greo进程的标准输入。
2 信号量:
java里是wait/notify。使用synchronized关键字。
c语言就是siginal。(p,v操作)
3 队列:
java里就是使用消息中间件。(activemq)
c语言就是申请一块内存,手动编写代码使该内存的数据结构形式为队列FIFo
4 共享内存:
java里就是一些nosql数据库,比如redis,memcached。
c语言就是一大块内存地址,用于存放数据。
5 socket通信:
java里是封装好的socket类。用就行。
c语言也是使用socket进行通信。

1 0