Qt如果多线程的话,似乎会出BUG

1.服务端(server.py)

 import sys, socket, threading
 import binascii
 from PyQt4 import QtCore, QtGui

 class ListenThread(threading.Thread):
     def __init__(self, txt, server):
         threading.Thread.__init__(self)
         self.txt = txt
         self.server = server
     def run(self):
         self.txt.append('来嘛来嘛\n')
         while 1:
             try:
                 client, addr = self.server.accept()
                 self.txt.append('连接来自:{}:{}\n'.format(addr[0], addr[1]))
                 data = client.recv(1024)
                 self.txt.append('收到数据:{}\n'.format(data.decode('utf-8')))
                 client.send('I Got:'.encode('utf-8') + data)
                 client.close()
                 self.txt.append('关闭客户端\n')
             except:
                 self.txt.append('关闭连接\n')
                 break
 class ControlThread(threading.Thread):
     def __init__(self, txt):
         threading.Thread.__init__(self)
         self.txt = txt
         self.event = threading.Event()
         self.event.clear()
     def run(self):
         self.server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
         self.server.bind(('', 1051))
         self.server.listen(1)
         self.txt.append('正在等待连接\n')
         self.lsn = ListenThread(self.txt, self.server)
         self.lsn.setDaemon(True)
         self.lsn.start()
         self.event.wait()
         self.server.close()
     def stop(self):
         self.event.set()

 class MyWindow(QtGui.QWidget):
     def __init__(self):
         QtGui.QWidget.__init__(self)
         self.setWindowTitle('服务端')
         self.resize(485, 300)

         self.btn1 = QtGui.QPushButton('开始监听')
         self.btn2 = QtGui.QPushButton('停止监听')
         self.txt = QtGui.QTextEdit()

         self.grid = QtGui.QGridLayout()
         self.grid.addWidget(self.btn1, 0, 0)
         self.grid.addWidget(self.btn2, 0, 1)
         self.grid.addWidget(self.txt, 1, 0, 1, 2)
         self.setLayout(self.grid)

         self.connect(self.btn1, QtCore.SIGNAL('clicked()'), self.onBtn1)
         self.connect(self.btn2, QtCore.SIGNAL('clicked()'), self.onBtn2)
     def onBtn1(self):
         self.ctrl = ControlThread(self.txt)
         self.ctrl.setDaemon(True)
         self.ctrl.start()
     def onBtn2(self):
         self.ctrl.stop()

 app = QtGui.QApplication(sys.argv)
 mywindow = MyWindow()
 mywindow.show()
 app.exec_()

2.客户端(client.py)

 import sys, socket, threading
 import binascii
 from PyQt4 import QtCore, QtGui

 class ListenThread(threading.Thread):
     def __init__(self, txt, server):
         threading.Thread.__init__(self)
         self.txt = txt
         self.server = server
     def run(self):
         self.txt.append('来嘛来嘛\n')
         while 1:
             try:
                 client, addr = self.server.accept()
                 self.txt.append('连接来自:{}:{}\n'.format(addr[0], addr[1]))
                 data = client.recv(1024)
                 self.txt.append('收到数据:{}\n'.format(data.decode('utf-8')))
                 client.send('I Got:'.encode('utf-8') + data)
                 client.close()
                 self.txt.append('关闭客户端\n')
             except:
                 self.txt.append('关闭连接\n')
                 break
 class ControlThread(threading.Thread):
     def __init__(self, txt):
         threading.Thread.__init__(self)
         self.txt = txt
         self.event = threading.Event()
         self.event.clear()
     def run(self):
         self.server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
         self.server.bind(('', 1051))
         self.server.listen(1)
         self.txt.append('正在等待连接\n')
         self.lsn = ListenThread(self.txt, self.server)
         self.lsn.setDaemon(True)
         self.lsn.start()
         self.event.wait()
         self.server.close()
     def stop(self):
         self.event.set()

 class MyWindow(QtGui.QWidget):
     def __init__(self):
         QtGui.QWidget.__init__(self)
         self.setWindowTitle('服务端')
         self.resize(485, 300)

         self.btn1 = QtGui.QPushButton('开始监听')
         self.btn2 = QtGui.QPushButton('停止监听')
         self.txt = QtGui.QTextEdit()

         self.grid = QtGui.QGridLayout()
         self.grid.addWidget(self.btn1, 0, 0)
         self.grid.addWidget(self.btn2, 0, 1)
         self.grid.addWidget(self.txt, 1, 0, 1, 2)
         self.setLayout(self.grid)

         self.connect(self.btn1, QtCore.SIGNAL('clicked()'), self.onBtn1)
         self.connect(self.btn2, QtCore.SIGNAL('clicked()'), self.onBtn2)
     def onBtn1(self):
         self.ctrl = ControlThread(self.txt)
         self.ctrl.setDaemon(True)
         self.ctrl.start()
     def onBtn2(self):
         self.ctrl.stop()

 app = QtGui.QApplication(sys.argv)
 mywindow = MyWindow()
 mywindow.show()
 app.exec_()

Python -- 网络编程 -- Socket简单网络通信的更多相关文章

  1. Python网络编程-Socket简单通信(及python实现远程文件发送)

    学习python中使用python进行网络编程,编写简单的客户端和服务器端进行通信,大部分内容来源于网络教程,这里进行总结供以后查阅. 先介绍下TCP的三次握手: 1,简单的发送消息: 服务器端: i ...

  2. Python网络编程socket

    网络编程之socket 看到本篇文章的题目是不是很疑惑,what is this?,不要着急,但是记住一说网络编程,你就想socket,socket是实现网络编程的工具,那么什么是socket,什么是 ...

  3. Day07 - Python 网络编程 Socket

    1. Python 网络编程 Python 提供了两个级别访问网络服务: 低级别的网络服务支持基本的 Socket,它提供了标准的 BSD Sockets API,可以访问底层操作系统Socket接口 ...

  4. python网络编程-socket编程

     一.服务端和客户端 BS架构 (腾讯通软件:server+client) CS架构 (web网站) C/S架构与socket的关系: 我们学习socket就是为了完成C/S架构的开发 二.OSI七层 ...

  5. python网络编程socket /socketserver

    提起网络编程,不同于web编程,它主要是C/S架构,也就是服务器.客户端结构的.对于初学者而言,最需要理解的不是网络的概念,而是python对于网络编程都提供了些什么模块和功能.不同于计算机发展的初级 ...

  6. python --- 网络编程Socket

    网络编程 定义:所为网络编程即是对信息的发送和接收. 主要工作: (1)发送端:将信息以规定的协议组装成数据包. (2)接收端:对收到的数据包解析,以提取所需要的信息. Socket:两个在网络上的程 ...

  7. python网络编程——socket基础篇

    python的网络编程比c语言简单许多, 封装许多底层的实现细节, 方便程序员使用的同时, 也使程序员比较难了解一些底层的东西. 1 TCP/IP 要想理解socket,首先得熟悉一下TCP/IP协议 ...

  8. Python 网络编程——socket

    一 客户端/服务器架构 客户端(Client)服务器(Server)架构,即C/S架构,包括 1.硬件C/S架构(打印机) 2.软件C/S架构(web服务) 理想/目标状态—— 最常用的软件服务器是 ...

  9. Day10 Python网络编程 Socket编程

    一.客户端/服务器架构 1.C/S架构,包括: 1.硬件C/S架构(打印机) 2.软件C/S架构(web服务)[QQ,SSH,MySQL,FTP] 2.C/S架构与socket的关系: 我们学习soc ...

随机推荐

  1. [转自知乎] 从github上下载单个文件夹

    原文地址: 如何从 GitHub 上下载单个文件夹?  注意:如果是在公司网络环境的话需要配置可以访问外网的代理,否则 svn checkout 时会出错.

  2. 关于Windbg Local kernel debugging for Win7

    在使用Windbg的时候,如果在Win7上使用Kernel Debug时候会弹出下面的对话框: 在这个对话框中所描述的信息中我们可以看到这么一段话: “Local kernel debugging i ...

  3. [IOS] 详解图片局部拉伸 + 实现图片局部收缩

    (图为微信首页右上角『+』效果) 当初还在开发WP7的时候,从IOS同事那边了解到类似微信以上功能的实现. Item条数不同,总高度也不同,这就需要将背景图片进行局部拉伸到响应的高度,并且保持上方的三 ...

  4. PHP编译安装完成之后没有'php.ini'文件的处理方法

    在我们编译安装PHP的时候,编译安装完成是不会自动生成php.ini文件的,所以需要我们手动生成. 1.通过命令行确定php.ini文件的位置 php -r "phpinfo();" ...

  5. .net core signalR 忽略https 证书

    var connection = new HubConnectionBuilder().WithUrl(serverUrl, option => { option.HttpMessageHand ...

  6. .net core Swagger

    Startup中的  ConfigureServices //注册 Swagger services.AddSwaggerGen(sg => { sg.SwaggerDoc("refu ...

  7. wpf datagrid 隔行变色

    <DataGrid AlternationCount="2"> <DataGrid.RowStyle> <Style TargetType=" ...

  8. Java中的String,StringBuilder,StringBuffer的区别

    这三个类之间的区别主要是在两个方面,即运行速度和线程安全这两方面. 首先说运行速度,或者说是执行速度,在这方面运行速度快慢为:StringBuilder > StringBuffer > ...

  9. RxJS入门之函数响应式编程

    一.函数式编程 1.声明式(Declarativ) 和声明式相对应的编程⽅式叫做命令式编程(ImperativeProgramming),命令式编程也是最常见的⼀种编程⽅式. //命令式编程: fun ...

  10. super函数的用法

    1.创建一个类. # .创建一个类 class Bird: def __init__(self): self.hungry =True def eat(self): if self.hungry: p ...