15.Python网络编程:进程池、进程间通信、多线程、进程和线程区别、网络通信、端口、IP地址、socket、UDP、TCP、http

news2025/2/18 14:19:21

1. 进程池(Process Pool)

进程池是通过将多个进程放入池中管理来避免频繁地创建和销毁进程,提高效率。Python 提供了 multiprocessing.Pool 类来实现进程池,它可以用于并行计算任务。

示例:使用进程池
from multiprocessing import Pool

def square(x):
    return x * x

if __name__ == "__main__":
    with Pool(4) as pool:  # 创建一个包含 4 个进程的进程池
        results = pool.map(square, [1, 2, 3, 4, 5])
    print(results)  # 输出 [1, 4, 9, 16, 25]

2. 进程间通信(IPC)

进程间通信是指不同进程之间交换数据或信号。Python 中的 multiprocessing 模块提供了 QueuePipe 等方式来实现进程间的通信。

示例:使用 Queue 进行进程间通信
from multiprocessing import Process, Queue

def put_data(q):
    q.put("Hello from Process!")

def get_data(q):
    print(q.get())

if __name__ == "__main__":
    q = Queue()
    p1 = Process(target=put_data, args=(q,))
    p2 = Process(target=get_data, args=(q,))
    
    p1.start()
    p2.start()
    
    p1.join()
    p2.join()

3. 多线程(Multithreading)

Python 中的多线程通过 threading 模块来实现。多线程适合 I/O 密集型任务(如网络请求、文件操作等),因为 Python 的全局解释器锁(GIL)会限制线程并行执行 CPU 密集型任务。

示例:使用多线程
import threading

def print_numbers():
    for i in range(5):
        print(i)

def print_letters():
    for letter in "ABCDE":
        print(letter)

if __name__ == "__main__":
    t1 = threading.Thread(target=print_numbers)
    t2 = threading.Thread(target=print_letters)
    
    t1.start()
    t2.start()
    
    t1.join()
    t2.join()

4. 进程与线程的区别

  • 进程:每个进程都有独立的内存空间和资源,适合 CPU 密集型任务。进程间的数据共享复杂,需要通过进程间通信来实现。
  • 线程:线程是进程中的一个执行单元,多个线程共享进程的内存空间。线程更适合 I/O 密集型任务。由于全局解释器锁(GIL),Python 线程不能在同一时刻并行执行 CPU 密集型任务。

5. 网络通信

网络通信包括客户端和服务器之间的数据交换。Python 提供了 socket 模块来支持低级别的网络通信。网络通信使用端口和 IP 地址来进行定位和数据传输。

关键概念:
  • IP 地址:每台连接到网络的设备都有一个唯一的 IP 地址。
  • 端口:用于区分同一主机上不同服务的编号。
  • 协议:数据传输遵循的规则,常见的有 TCP、UDP、HTTP 等。

6. Socket 编程

socket 是 Python 中进行网络编程的基础库,支持 TCP 和 UDP 协议。通过 socket,我们可以创建客户端和服务器。

示例:TCP Socket 服务器和客户端
  • TCP 服务器
import socket

def tcp_server():
    server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    server_socket.bind(('localhost', 8080))  # 绑定 IP 和端口
    server_socket.listen(5)  # 监听连接

    print("Server started, waiting for connection...")
    client_socket, addr = server_socket.accept()
    print(f"Connection from {addr}")
    
    data = client_socket.recv(1024)  # 接收数据
    print(f"Received: {data.decode('utf-8')}")
    
    client_socket.send(b'Hello from server')  # 发送数据
    client_socket.close()

if __name__ == "__main__":
    tcp_server()
  • TCP 客户端
import socket

def tcp_client():
    client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    client_socket.connect(('localhost', 8080))  # 连接服务器
    
    client_socket.send(b'Hello, server')  # 发送数据
    data = client_socket.recv(1024)  # 接收数据
    print(f"Received: {data.decode('utf-8')}")
    
    client_socket.close()

if __name__ == "__main__":
    tcp_client()

7. UDP 编程

UDP 是无连接的协议,不保证数据的可靠传输,适用于对实时性要求高的应用,如视频流、在线游戏等。

示例:UDP 服务器和客户端
  • UDP 服务器
import socket

def udp_server():
    server_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
    server_socket.bind(('localhost', 8080))  # 绑定 IP 和端口

    while True:
        data, addr = server_socket.recvfrom(1024)  # 接收数据
        print(f"Received message: {data.decode('utf-8')} from {addr}")
        server_socket.sendto(b'Hello from UDP server', addr)  # 发送数据

if __name__ == "__main__":
    udp_server()
  • UDP 客户端
import socket

def udp_client():
    client_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
    client_socket.sendto(b'Hello, UDP server', ('localhost', 8080))  # 发送数据
    data, addr = client_socket.recvfrom(1024)  # 接收数据
    print(f"Received from server: {data.decode('utf-8')}")
    client_socket.close()

if __name__ == "__main__":
    udp_client()

8. HTTP 编程

HTTP 协议是客户端与服务器通信的标准协议。Python 提供了 http.serverrequests 等库来实现 HTTP 服务器和客户端功能。

  • HTTP 服务器
from http.server import SimpleHTTPRequestHandler, HTTPServer

def run_http_server():
    server = HTTPServer(('localhost', 8080), SimpleHTTPRequestHandler)
    print("HTTP server started on port 8080")
    server.serve_forever()

if __name__ == "__main__":
    run_http_server()
  • HTTP 客户端
import requests

def http_client():
    response = requests.get('http://localhost:8080')
    print(f"Response: {response.text}")

if __name__ == "__main__":
    http_client()

总结

  • 进程池multiprocessing.Pool 用于管理和复用多个进程,适合并行计算。
  • 进程间通信:通过 QueuePipe 进行数据交换。
  • 多线程:通过 threading 模块实现多线程编程,适用于 I/O 密集型任务。
  • 进程与线程区别:进程有独立的内存空间,线程共享内存,进程适合 CPU 密集型任务,线程适合 I/O 密集型任务。
  • 网络通信:通过 socket 实现客户端和服务器通信,支持 TCP、UDP、HTTP 协议。
  • TCP:面向连接的协议,保证数据传输的可靠性。
  • UDP:无连接协议,适用于实时性要求高的应用。
  • HTTP:标准的网络通信协议,广泛应用于 Web 开发中。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2297818.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ThinkPHP8视图赋值与渲染

【图书介绍】《ThinkPHP 8高效构建Web应用》-CSDN博客 《2025新书 ThinkPHP 8高效构建Web应用 编程与应用开发丛书 夏磊 清华大学出版社教材书籍 9787302678236 ThinkPHP 8高效构建Web应用》【摘要 书评 试读】- 京东图书 在控制器操作中,使用view函数可以传入视图…

微信小程序网络请求封装

微信小程序的网络请求为什么要封装?封装使用有什么好处? 封装的目的是为了偷懒,试想一下每次都要wx.request,巴拉巴拉传一堆参数,是不是很麻烦,有些公共的参数例如header,baseUrl是不是可以封装…

瑞芯微烧写工具

文章目录 前言一、安装驱动二、安装烧写工具1.直接解压压缩包2. 如何使用 三、MASKROM 裸机必备四、LOADER 烧写,前提是搞过第三步没问题五、Update.img包的烧录六、linux下烧写总结 前言 提示:这里可以添加本文要记录的大概内容: 项目需要…

抖音SEO短视频矩阵系统源码:短视频流量密码揭秘

在开发短视频SEO优化排名技术时,仅通过get和set这两个代理无法完全实现目标。实际上,还需要实现has、ownKeys以及getOwnPropertyDescriptor等代理,以更全面地控制私有属性的访问权限。这些代理对于限制对私有属性的访问至关重要。 该技术主要…

【工业安全】-CVE-2022-35561- Tenda W6路由器 栈溢出漏洞

文章目录 1.漏洞描述 2.环境搭建 3.漏洞复现 4.漏洞分析 4.1:代码分析 4.2:流量分析 5.poc代码: 1.漏洞描述 漏洞编号:CVE-2022-35561 漏洞名称:Tenda W6 栈溢出漏洞 威胁等级:高危 漏洞详情&#xff1…

【GRPO】GRPO原理原文翻译

论文:DeepSeekMath: Pushing the Limits of Mathematical Reasoning in Open Language Models 注!这里我仅仅翻译GRPO部分供学习使用。其他部分请去看原文。 4. 强化学习(Reinforcement Learning) 4.1. 群组相对策略优化&#xf…

侯捷 C++ 课程学习笔记:C++ 新标准 11/14 的革新与实战应用

在侯捷老师的 C 系列课程中,《C 新标准 11/14》这门课程让我对现代 C 编程有了全新的认识。C11 和 C14 是 C 语言发展史上的重要里程碑,它们引入了大量新特性,极大地提升了语言的表达能力和开发效率。侯捷老师通过深入浅出的讲解和丰富的实战…

拉取Openwrt官方源码 编译固件速通

Openwrt 24.10上星期出了,但是恩山没几个人更新,自己编译一个,记录一下方法。 一切从简,不添加任何插件,资源扔恩山了。 【   】红米AX6000 openwrt V24.10.0 uboot大分区固件-小米无线路由器及小米网络设备-恩山无…

大模型Deepseek的使用_基于阿里云百炼和Chatbox

目录 前言1. 云服务商2. ChatBox参考 前言 上篇博文中探索了(本地)部署大语言模型,适合微调、数据高隐私性等场景。随着Deepseek-R1的发布,大语言模型的可及性得到极大提升,应用场景不断增加,对高可用的方…

DeepSeek 本地部署(电脑安装)

1.先安装Ollama 开源框架 网址链接为:Ollama 2.点中间的下载 3.选系统 4.下载好就安装 5.输入命令ollama -v 6.点击Model 7.选如下 8.选版本 9.复杂对应命令 10.控制台粘贴下载 11.就可以问问题啦 12.配置UI界面(在扩展里面输入) 13.配置完即可打开 14.选择刚才安装的就好啦…

【论文笔记】ZeroGS:扩展Spann3R+GS+pose估计

spann3r是利用dust3r做了增量式的点云重建,这里zeroGS在前者的基础上,进行了增量式的GS重建以及进行了pose的联合优化,这是一篇dust3r与GS结合的具有启发意义的工作。 abstract NeRF和3DGS是重建和渲染逼真图像的流行技术。然而,…

《Python 中 JSON 的魔法秘籍:从入门到精通的进阶指南》

在当今数字化时代,网络编程无处不在,数据的高效传输与交互是其核心。JSON 作为一种轻量级的数据交换格式,凭借其简洁、易读、跨语言的特性,成为网络编程中数据传输与存储的关键技术。无论是前后端数据交互,还是不同系统…

【漫话机器学习系列】091.置信区间(Confidence Intervals)

置信区间(Confidence Intervals)详解 1. 引言 在统计学和数据分析中,我们通常希望通过样本数据来估计总体参数。然而,由于抽样的随机性,我们不可能得到精确的总体参数,而只能通过估计值(如均值…

回归预测 | Matlab实现PSO-HKELM粒子群算法优化混合核极限学习机多变量回归预测

回归预测 | Matlab实现PSO-HKELM粒子群算法优化混合核极限学习机多变量回归预测 目录 回归预测 | Matlab实现PSO-HKELM粒子群算法优化混合核极限学习机多变量回归预测效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.回归预测 | Matlab实现PSO-HKELM粒子群算法优化混合核…

QTreeView添加网格线

一.效果 二.实现 网格线虽然可以用样式表添加,但效果不好。这里重写QTreeView的drawRow函数来实现网格线的绘制。 void QHTreeView::drawRow(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const {QTreeView::drawRow(painter…

Golang的多团队协作编程模式与实践经验

Golang的多团队协作编程模式与实践经验 一、多团队协作编程模式概述 在软件开发领域,多团队协作编程是一种常见的工作模式。特别是对于大型项目来说,不同团队间需要协同合作,共同完成复杂的任务。Golang作为一种高效、并发性强的编程语言&…

AI前端开发的学习成本与回报——效率革命的曙光

近年来,人工智能技术飞速发展,深刻地改变着各行各业。在软件开发领域,AI写代码工具的出现更是掀起了一场效率革命。AI前端开发,作为人工智能技术与前端开发技术的完美结合,正展现出巨大的发展潜力,为开发者…

[创业之路-297]:经济周期与股市、行业的关系

目录 一、经济周期的种类 1、短周期(基钦周期) 2、中周期(朱格拉周期) 3、长周期(康德拉季耶夫周期) 当下处于康波周期的哪个阶段? 4、建筑周期(库涅茨周期) 二、…

Dav_笔记14:优化程序提示 HINTs -3

查询转换的提示 以下每个提示都指示优化程序使用特定的SQL查询转换: ■NO_QUERY_TRANSFORMATION ■USE_CONCAT ■NO_EXPAND ■REWRITE和NO_REWRITE ■MERGE和NO_MERGE ■STAR_TRANSFORMATION和NO_STAR_TRANSFORMATION ■事实和NO_FACT ■UNNEST和NO_UNNEST…

递归乘法算法

文章目录 递归乘法题目链接题目详解解题思路:代码实现: 结语 欢迎大家阅读我的博客,给生活加点impetus!! 让我们进入《题海探骊》,感受算法之美!! 递归乘法 题目链接 在线OJ 题目…