会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 128778个问题
Python 全系列/第三阶段:Python 网络与并发编程/并发编程 46楼
Python 全系列/第三阶段:Python 网络与并发编程/并发编程 47楼
Python 全系列/第三阶段:Python 网络与并发编程/并发编程 48楼

from multiprocessing import Process, Queue

from time import sleep



class MyProcess(Process):

    def __init__(self,name,mq):

        Process.__init__(self)

        self.name = name

        self.mq = mq


    def run(self):

        print(f"Process:{self.name},start")

        print(f"get Data:{self.mq.get()}")

        sleep(3)

        print(f"Process:{self.name},end")


if __name__ == '__main__':

    mq = Queue()

    mq.put("1")

    mq.put("2")

    mq.put("3")


    p_list = []

    for i in range(3):

        p = MyProcess(f"p{i}",mq)

        p_list.append(p)


    for p in p_list:

        p.start()

        #p.join()


为什么要加join,不然会报错,mac

Traceback (most recent call last):

  File "<string>", line 1, in <module>

  File "/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/multiprocessing/spawn.py", line 116, in spawn_main

Traceback (most recent call last):

  File "<string>", line 1, in <module>

  File "/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/multiprocessing/spawn.py", line 116, in spawn_main

        exitcode = _main(fd, parent_sentinel)exitcode = _main(fd, parent_sentinel)

  File "/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/multiprocessing/spawn.py", line 126, in _main

  File "/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/multiprocessing/spawn.py", line 126, in _main

    self = reduction.pickle.load(from_parent)

      File "/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/multiprocessing/synchronize.py", line 110, in __setstate__

self = reduction.pickle.load(from_parent)

  File "/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/multiprocessing/synchronize.py", line 110, in __setstate__

    self._semlock = _multiprocessing.SemLock._rebuild(*state)

FileNotFoundError: [Errno 2] No such file or directory

    self._semlock = _multiprocessing.SemLock._rebuild(*state)

FileNotFoundError: [Errno 2] No such file or directory

Traceback (most recent call last):

  File "<string>", line 1, in <module>

  File "/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/multiprocessing/spawn.py", line 116, in spawn_main

    exitcode = _main(fd, parent_sentinel)

  File "/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/multiprocessing/spawn.py", line 126, in _main

    self = reduction.pickle.load(from_parent)

  File "/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/multiprocessing/synchronize.py", line 110, in __setstate__

    self._semlock = _multiprocessing.SemLock._rebuild(*state)

FileNotFoundError: [Errno 2] No such file or directory


Python 全系列/第三阶段:Python 网络与并发编程/并发编程 49楼
Python 全系列/第三阶段:Python 网络与并发编程/网络通信 50楼
Python 全系列/第三阶段:Python 网络与并发编程/网络通信 51楼
Python 全系列/第三阶段:Python 网络与并发编程/并发编程 52楼

#客户端
#coding-utf-8
from  socket import *
from  threading import Thread
def recv_data():
    while True:
        recv_date = s.recvfrom(1024)  # 1024表示本次接收的最大字节数
        recv_content = recv_date[0].decode('gbk')
        print(f"收到远程信息:{recv_content},from {recv_date[1]}")
        if recv_content == "88":
            print("聊天结束")
            break

def send_data():
    addr = ("127.0.0.1", 8989)
    while True:
        data = input("请输入:")
        s.sendto(data.encode("gbk"), addr)
        if data == '88':
            print('聊天结束!')
            break
    s.close()

if __name__ =='__main__':
    s= socket(AF_INET,SOCK_DGRAM) #创建UDP类型的套接字
    s.bind(('127.0.0.1',8080)) #绑定接口,ip可以不写
    #创建两个线程
    t1=Thread(target=recv_data)
    t2=Thread(target=send_data)
    t1.start()
    t2.start()
    t1.join()
    t2.join()



#服务端
#coding-utf-8
from  socket import *
from  threading import Thread
def recv_data():
    while True:
        recv_date = s.recvfrom(1024)  # 1024表示本次接收的最大字节数
        recv_content = recv_date[0].decode('gbk')
        print(f"收到远程信息:{recv_content},from {recv_date[1]}")
        if recv_content == "88":
            print("聊天结束")
            break

def send_data():
    addr = ("127.0.0.1", 8080)
    while True:
        data = input("请输入:")
        s.sendto(data.encode("gbk"), addr)
        if data == '88':
            print('聊天结束!')
            break
    s.close()

if __name__ =='__main__':
    s= socket(AF_INET,SOCK_DGRAM) #创建UDP类型的套接字
    s.bind(('127.0.0.1',8989)) #绑定接口,ip可以不写
    #创建两个线程
    t1=Thread(target=recv_data)
    t2=Thread(target=send_data)
    t1.start()
    t2.start()
    t1.join()
    t2.join()




#报错
C:\Users\LS\PycharmProjects\mypro001\venv\Scripts\python.exe C:\Users\LS\PycharmProjects\mypro001\mypro05.py 
请输入:1234
请输入:Exception in thread Thread-1 (recv_data):
Traceback (most recent call last):
  File "C:\Users\LS\AppData\Local\Programs\Python\Python312\Lib\threading.py", line 1052, in _bootstrap_inner
    self.run()
  File "C:\Users\LS\AppData\Local\Programs\Python\Python312\Lib\threading.py", line 989, in run
    self._target(*self._args, **self._kwargs)
  File "C:\Users\LS\PycharmProjects\mypro001\mypro05.py", line 6, in recv_data
    recv_date = s.recvfrom(1024)  # 1024表示本次接收的最大字节数
                ^^^^^^^^^^^^^^^^
ConnectionResetError: [WinError 10054] 远程主机强迫关闭了一个现有的连接。
Exception in thread Thread-2 (send_data):
Traceback (most recent call last):
  File "C:\Users\LS\AppData\Local\Programs\Python\Python312\Lib\threading.py", line 1052, in _bootstrap_inner
    self.run()
  File "C:\Users\LS\AppData\Local\Programs\Python\Python312\Lib\threading.py", line 989, in run
    self._target(*self._args, **self._kwargs)
  File "C:\Users\LS\PycharmProjects\mypro001\mypro05.py", line 16, in send_data
    data = input("请输入:")
           ^^^^^^^^^^^^^
  File "<frozen codecs>", line 322, in decode
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte
Traceback (most recent call last):
  File "C:\Users\LS\PycharmProjects\mypro001\mypro05.py", line 32, in <module>
    t2.join()
  File "C:\Users\LS\AppData\Local\Programs\Python\Python312\Lib\threading.py", line 1126, in join
    self._wait_for_tstate_lock()
  File "C:\Users\LS\AppData\Local\Programs\Python\Python312\Lib\threading.py", line 1146, in _wait_for_tstate_lock
    if lock.acquire(block, timeout):
       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
KeyboardInterrupt

Process finished with exit code -1073741510 (0xC000013A: interrupted by Ctrl+C)


#提示[WinError 10054] 远程主机强迫关闭了一个现有的连接。


Python 全系列/第三阶段:Python 网络与并发编程/网络通信 54楼
Python 全系列/第三阶段:Python 网络与并发编程/网络通信 55楼
Python 全系列/第三阶段:Python 网络与并发编程/并发编程 57楼
Python 全系列/第三阶段:Python 网络与并发编程/并发编程 58楼
Python 全系列/第三阶段:Python 网络与并发编程/网络通信 59楼
Python 全系列/第三阶段:Python 网络与并发编程/网络通信 60楼

百战程序员微信公众号

百战程序员微信小程序

©2014-2024 百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637