我有以下代码:
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异常。 那么真正产生的异常是什么呢?
socket.timeout
是socket.error
的一个子类。真的是socket.timeout
。当您首先捕获一个socket.error
时,您将捕获一个更一般的情况。此代码正确:
试着特别捕捉
socket.timeout
,然后捕捉其他socket.error
相关问题 更多 >
编程相关推荐