针对twisted--Defered的单线程多任务的理解

从网上找了不少关于twisted的Defered的文章来看,大致了解了异步机制的概念,但是看别人的东西难免有那么一点疑问,虽然别人讲的也很清楚了,可有时候就是跟自己原有的想法有出入,于是问题出来了,怎么去验证到底这种出入谁的是正确的?比如defer当中的回调,我的疑问可以简单的归纳为:

回调函数的执行是在一个任务当中的体现,还是在不同任务间的体现呢?

下面有段代码是我改进后测试我的想法用的:

from twisted.internet import reactor,defer,protocol,posixbase
import time

class CallbackAndDisconnectProtocol(protocol.Protocol):
    def connectionMade(self):
        print "server start"
    
    def dataReceived(self, data):
        defer = self.factory.dataConsole()
        defer.addCallback(handleSuccess,5001)
        defer.addErrback(handleFailure,5001)

class ConnectionTestFactory(protocol.ServerFactory):
    protocol=CallbackAndDisconnectProtocol
    def dataConsole(self):
        time.sleep(6)
        print "**********************"
        return defer.succeed("sdfdsfsdf")

def testConnect():
    testFactory=ConnectionTestFactory()
    reactor.listenTCP(5001,testFactory)

def handleSuccess(result,port):
    print "Connect to port %i"%port
    

def handleFailure(failure,port):
    print "Error connecting to port %i: %s"%(port,failure.getErrorMessage())
    
    
if __name__=="__main__":
    connecting=testConnect()
    reactor.run()

 ConnectionTestFactory当中的dataConsole方法最终返回了defer对象,随后在protocal当中为这个defer定义了回调方法,那么这个回调方法是在dataConsole方法返回后执行呢?还是在dataConsole方法执行的过程中,回调机制就会执行呢?

为了验证这一点,我特定让dataConsole方法延迟了6秒执行,然后通过cmd下telnet这个服务端,我同时开了两个telnet,这样就可以非常明白的观察出来了。

结论:callback是在dataConsole方法返回defer后才会执行的。也就是回调函数的执行体现在多个任务之间,而不是在一个任务当中先于返回defer而去执行。

结论和网上看到的牛人写的东西一致,哈哈,也许是自己的想法有点弱智,但是我自己验证了一下,更能让自己心安理得。

你可能感兴趣的:(线程)