多进程访问文件的同步

一般面对的都是同一进程中的多线程同步问题,可以用synchroniezed(lockObject) 同步就可以了,因为lockObject对进程中线程是公共的。

不同进程之间同步怎么办?答曰,必须依赖一个公共的中介,就是操作系统提供的不同进程之间同步的机制了。有4种:1)critical section, 2)mutex, 3)信号量,4)event。临界区没有名字,一般用于亲属进程之间的同步;mutex可以命名,这样完全没有关系的进程都可以引用这个mutex 做同步,相当于一个系统全局的lock object。

其实还有一种,就是文件锁,相当于一种persistent 化的lock object,操作系统也支持,java的channel.lock()就是利用系统的文件锁机制。


另外,IPC是指进程间通信、传递数据,常见方式有管道(亲属进程间),FIFO(命名管道,完全独立进程间),socket(和FIFO管道类似),共享内存。前三个都是一个进程往stream里写,另一个进程从stream里读。最后一个双方都可以写,而且是随机访问的。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值