以下代码侦听2端口,当有消息修改全局dict对象时。还有一个计时器也会修改dict。
d = {}
class x(Protocol):
def dataReceived(self, data):
# according to data call x's function
self.f()
def f(self):
global d
d['x'] = 'x'
class y(Protocol):
def dataReceived(self, data):
# according to data call y's function
self.f()
def f(self):
global d
d['y'] = 'y'
def modify_d():
global d
for k in d.keys():
if d[k] == 'whatever':
del d[k]
reactor.listenTCP(8880, x())
reactor.listenTCP(8881, y())
lc = task.LoopingCall(modify_d)
lc.start(300)
reactor.run()
访问时我是否需要在d周围添加锁定?
答案 0 :(得分:0)
这不是线程安全的,但这无关紧要。你不需要锁。 Twisted在同一个主要I / O线程中运行所有回调(除了那些涉及专门提到线程的API),因此您不必担心同时运行多个事务。