7

我有以下代码:

try:
    while 1:
        s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
        s.settimeout(5);
        s.connect((HOST,PORT))
        print("before send")
        #time.sleep(10);
        #s.sendall('GET / HTTP/1.1\r\nConnection: Keep-Alive\r\nHost: www.google.lt\r\n\r\n')
        data=s.recv(52)
        print("after send");
        s.close()
        if string.find(data,"HTTP/1.1 200 OK") == -1:
            print("Lost Connection")
        print(data)
        time.sleep(2)
except KeyboardInterrupt:
    print("CTRL C occured")
except socket.error:
    print("socket error occured: ")
except socket.timeout:
    print("timeout error")

我已经注释了 sendall 函数来测试 recv 如何生成超时异常。但问题是我得到了 socket.error 异常。如果我将最后几行代码更改为:

except socket.timeout:
    print("timeout error")
except socket.error:
     print("socket error occured: ")

然后我得到 socket.timeout 异常。那么真正产生了什么异常呢?

4

1 回答 1

20

socket.timeout是 的子类socket.error。真的是socket.timeout。当你抓住socket.error第一个时,你会抓住一个更普遍的情况。

>>> issubclass(socket.timeout, socket.error)
True

这段代码是正确的:

except socket.timeout:
 print("timeout error")
except socket.error:
 print("socket error occured: ")

试着抓一下socket.timeout,然后是其他socket.error的。

于 2013-02-16T18:56:17.257 回答