使用go语言及Python语言实战把多核CPU跑满

简介: 一直有个疑问,Python及go能不能把多核CPU跑满,实践一把吧

机器配置

4核CPU


单线程代码

Python代码

whileTrue:
print("test")

go代码

packagemainimport"fmt"funcmain(){
for {
fmt.Println("test")
    }
}

都是死循环,如何把机器的CPU跑满


Python程序运行,top监控


go程序运行,top监控


看进程都把CPU跑满了100%,但我总共有4个CPU呢


接下来该怎么做?,上文代码中,都只有一个主线程执行,一个线程是无论如何也无法跑满多核CPU的


多线程代码

go版本,使用的是协程,GMP(超多个协程对应多个线程)

packagemainimport (
"fmt""time")
funcmain() {
fori :=0; i<200; i++ {
gofunc() {
for {
fmt.Println("test")
            }
        }()
    }
time.Sleep(100*time.Hour)
}

go程序再次运行,top监控


Python版本

importthreadingdefsay():
whileTrue:
print("test")
foriinrange(200):
threading.Thread(target=say).start()

python程序运行,top监控


好难啊,还没跑满CPU,可能是print打印这个不消耗CPU,那么搞点复杂的计算任务吧


多线程版本2

go版本

packagemainimport (
"fmt""time")
funcmain() {
fori :=0; i<200; i++ {
gofunc() {
for {
sum:=0fori :=1; i<=10000000; i++ {
sum+=i                }
fmt.Println(sum)
            }
        }()
    }
time.Sleep(100*time.Hour)
}

go程序运行,top监控

可以看到CPU已经达到376%,多核CPU资源已经基本上跑满了


Python版本

importthreadingdefsay():
whileTrue:
sum=0foriinrange(10000000):
sum+=iprint(sum)
foriinrange(200):
threading.Thread(target=say).start()

python程序运行,top监控

可以看到CPU使用率119%,并没有利用多核资源


Python多线程不能利用多核的资源,网上查找了下是因为GIL全局锁的原因,只能使用多进程

Python多进程

frommultiprocessingimportProcessdefsay():
whileTrue:
sum=0foriinrange(10000000):
sum+=iprint(sum)
foriinrange(4):
Process(target=say).start()


python程序运行,top监控

可以看到有4个Python进程,每个Python进程CPU都达到90%左右


结论: go可以充分利用多核资源,Python因为GIL锁的原因多线程并不能利用多核资源,需要用到多进程方式

目录
相关文章
|
8天前
|
存储 监控 算法
员工上网行为监控中的Go语言算法:布隆过滤器的应用
在信息化高速发展的时代,企业上网行为监管至关重要。布隆过滤器作为一种高效、节省空间的概率性数据结构,适用于大规模URL查询与匹配,是实现精准上网行为管理的理想选择。本文探讨了布隆过滤器的原理及其优缺点,并展示了如何使用Go语言实现该算法,以提升企业网络管理效率和安全性。尽管存在误报等局限性,但合理配置下,布隆过滤器为企业提供了经济有效的解决方案。
44 8
员工上网行为监控中的Go语言算法:布隆过滤器的应用
|
28天前
|
Go 开发工具
百炼-千问模型通过openai接口构建assistant 等 go语言
由于阿里百炼平台通义千问大模型没有完善的go语言兼容openapi示例,并且官方答复assistant是不兼容openapi sdk的。 实际使用中发现是能够支持的,所以自己写了一个demo test示例,给大家做一个参考。
|
27天前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
28天前
|
程序员 Go
go语言中结构体(Struct)
go语言中结构体(Struct)
100 71
|
27天前
|
存储 Go 索引
go语言中的数组(Array)
go语言中的数组(Array)
104 67
|
3天前
|
算法 安全 Go
Go 语言中实现 RSA 加解密、签名验证算法
随着互联网的发展,安全需求日益增长。非对称加密算法RSA成为密码学中的重要代表。本文介绍如何使用Go语言和[forgoer/openssl](https://github.com/forgoer/openssl)库简化RSA加解密操作,包括秘钥生成、加解密及签名验证。该库还支持AES、DES等常用算法,安装简便,代码示例清晰易懂。
28 16
|
28天前
|
存储 Go
go语言中映射
go语言中映射
36 11
|
27天前
|
小程序 开发者 Python
探索Python编程:从基础到实战
本文将引导你走进Python编程的世界,从基础语法开始,逐步深入到实战项目。我们将一起探讨如何在编程中发挥创意,解决问题,并分享一些实用的技巧和心得。无论你是编程新手还是有一定经验的开发者,这篇文章都将为你提供有价值的参考。让我们一起开启Python编程的探索之旅吧!
46 10
|
6天前
|
监控 算法 安全
解锁企业计算机监控的关键:基于 Go 语言的精准洞察算法
企业计算机监控在数字化浪潮下至关重要,旨在保障信息资产安全与高效运营。利用Go语言的并发编程和系统交互能力,通过进程监控、网络行为分析及应用程序使用记录等手段,实时掌握计算机运行状态。具体实现包括获取进程信息、解析网络数据包、记录应用使用时长等,确保企业信息安全合规,提升工作效率。本文转载自:[VIPShare](https://www.vipshare.com)。
19 0
|
20天前
|
Go 数据安全/隐私保护 UED
优化Go语言中的网络连接:设置代理超时参数
优化Go语言中的网络连接:设置代理超时参数