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. (KMP 水)Wow! Such Doge! -- hdu -- 4847

    http://acm.hdu.edu.cn/showproblem.php?pid=4847 Wow! Such Doge! Time Limit:1000MS     Memory Limit:32 ...

  2. string转换成char*

    string 是c++标准库里面其中一个,封装了对字符串的操作 把string转换为char* 有3中方法: 1.data 如: string str="abc"; char *p ...

  3. Android学习整理之Activity篇

    一.Activity概念介绍 activity属于android的四大组件之一(其他的三个: Content provider,Broadcast receiver,Service),它可以理解为一个 ...

  4. 【WinRT】TransitionDemo

    折腾了一晚,将 WinRT 里的所有 Transition 做了一个小 Demo,用于演示各个 Transition 的效果. PS:NavigationThemeTransition 请参考:htt ...

  5. Type conversions in C++类型转换

    ###Implicit conversions隐式转换* 可以在基本类型之间自由转换:* 可以把任何类型的pointer转换为void pointer:* 可以将子类pointer转换为基类point ...

  6. 【TFS 2017】使用浏览器上传文件(TFVC)或者编辑代码,错误提示TF14098,需要对文件有PendChange 权限

    从TFS 2015开始,微软在TFS系统中增加了一个非常吸引开发人员的功能,"快速代码编辑器" (Quick Code Editor).使用这个功能,你可以在任何安装了浏览器的设备 ...

  7. PLSQL(PL/SQL)集成Team Foundation Server (TFS),实现数据库代码的版本管理

    PL/SQL是面向Oralcle数据库的集成开发环境,是众多Oracle数据库开发人员的主要工具.由于PL/SQL(百度百科)不仅是一种SQL语言,更是一种过程编程语言,在项目实施过程中,会积累大量除 ...

  8. 关于CI/CD/CD (Continuous Integration/Continuous Delivery/Continuous Deployment)

    Continuous Integration (CI) Continuous integration (CI) is the process that ensures the stability of ...

  9. Angular6 学习笔记——组件详解之模板语法

    angular6.x系列的学习笔记记录,仍在不断完善中,学习地址: https://www.angular.cn/guide/template-syntax http://www.ngfans.net ...

  10. 缓存 - 内存数据库Redis

    客户端 Redis Desktop Manager 官网 新版的收费,或者要分享什么的.0.8.8的旧版才免费?:https://github.com/uglide/RedisDesktopManag ...