我正在研究使代码具有多线程的功能,以便更快地进行数据分析。为了避免多线程数据库连接的问题,我使用Mutex对其进行锁定。
lock = Mutex.new()
thread_num.times do |i|
threads << Thread.new do
lock.synchronize{
records = db_proxy.query(account_id)
result = process_records(records)
}
end
end
process_records
也很耗时,但是作为常规方法,它支持多线程调用。它需要来自mdb_proxy.query
的输出,如何将process_records
从lock.synchronize
中取出,同时让它等待mdb_proxy.query
的结果,我尝试遵循但得到了局部变量异常< / p>
lock = Mutex.new()
thread_num.times do |i|
threads << Thread.new do
lock.synchronize{
records = mdb_proxy.query(account_id)
}
result = process_records(records)
end
end
答案 0 :(得分:3)
将记录分配给什么块返回:
records = lock.synchronize { mdb_proxy.query(account_id) }