使用Ruby的fork
方法和几个工作人员增加一个计数器
Thread
类的使用不允许fork
这里有一个小共享内存模拟
class Memory
def self.address= value
@value = value
end
def self.address
@value
end
end
这是我的工作人员
class Worker
def initialize mutex
@mutex = mutex
end
def work
@mutex.synchronize do
print "begin: %d " % (tmp=Memory.address)
sleep 0.05
print "end: %d \n" % (Memory.address = tmp + 1)
end
end
end
让我们运行它
# init
Memory.address = 0
mutex = Mutex.new
# create workers
workers = []
10.times do
workers << fork do
Worker.new(mutex).work
end
end
# wait for workers to finish
Process.waitall
begin: 0 begin: 0 begin: 0 begin: 0 begin: 0 begin: 0 begin: 0 begin: 0 begin: 0 begin: 0 end: 1
end: 1
end: 1
end: 1
end: 1
end: 1
end: 1
end: 1
end: 1
end: 1
begin: 0 end: 1
begin: 1 end: 2
begin: 2 end: 3
begin: 3 end: 4
begin: 4 end: 5
begin: 5 end: 6
begin: 6 end: 7
begin: 7 end: 8
begin: 8 end: 9
begin: 9 end: 10
附带问题:
答案 0 :(得分:2)
分叉进程继承其父资源,但内存是副本(或写入时的副本):在一个进程中进行的更改对其他进程没有影响。
同样,每个进程都有自己的互斥锁副本,因此同步调用不会实现任何效果。
如果您需要与子进程通信,一种方法是使用管道(请参阅IO文档)。每个进程都继承管道的副本,并在另一个进程中显示来自一个进程的写入。
child_in, parent_out = IO.pipe
parent_in, child_out = IO.pipe
Process.fork do
parent_out.close
parent_in.close
#data written to child_out appears on parent_in in the parent process
#reading from child_in returns data the parent has written to parent_out
end
child_out.close
child_in.close
#write data to parent_out here to have it appear on child_in in the child
#reading from parent_in to get data the child has written to child_out
据我所知,ruby中没有内置的跨进程并发原语。
答案 1 :(得分:0)
File类有flock
,可以锁定文件。这是进行进程间锁定的一种方法。
如果你想远程存储它,甚至还有一个名为remote_lock
的宝石。