处理python套接字中的超时错误

处理python套接字中的超时错误,第1张

处理python套接字中的超时错误
from foo import *

将所有不带下划线的名称(或仅在modules

__all__
属性中定义的名称)添加
foo
到当前模块中。

在上面的代码中,

from socket import *
您只是想抓住
timeout
timeout
进入当前名称空间的时间。

from socket import *
提取内部所有内容的定义,
socket
但不添加
socket
自身。

try:    # socketstuffexcept timeout:    print 'caught a timeout'

许多人认为

import *
有问题,并设法避免它。这是因为在以这种方式导入的2个或更多模块中的公用变量名称将相互破坏。

例如,考虑以下三个python文件:

# a.pydef foo():    print "this is a's foo function"# b.pydef foo():    print "this is b's foo function"# yourpre.pyfrom a import *from b import *foo()

如果运行,

yourpre.py
您将只看到输出“ this is b’s foo function”。

因此,我建议要么导入并使用模块,要么从模块中导入特定名称:

例如,带有显式导入的代码如下所示:

import socketfrom socket import AF_INET, SOCK_DGRAMdef main():    client_socket = socket.socket(AF_INET, SOCK_DGRAM)    client_socket.settimeout(1)    server_host = 'localhost'    server_port = 1234    while(True):        client_socket.sendto('Message', (server_host, server_port))        try: reply, server_address_info = client_socket.recvfrom(1024) print reply        except socket.timeout: #more pre

只是增加了一点点输入,但所有内容都是明确的,并且对于所有来源的读者来说都是显而易见的。



欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5647562.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存