多核心利用

简介: 版权声明:本文可能为博主原创文章,若标明出处可随便转载。 https://blog.csdn.net/Jailman/article/details/78552518 没有比较用时,有兴趣的同学可以自己试试。
版权声明:本文可能为博主原创文章,若标明出处可随便转载。 https://blog.csdn.net/Jailman/article/details/78552518

没有比较用时,有兴趣的同学可以自己试试。

下边的例子可以看到gevent是单线程下的高并发,在没有DMA异步IO(比如网络通信)的情况下,实际效果和同步的效率一样,甚至可能会更低。

#!/usr/bin/python

from gevent import monkey; monkey.patch_all()
import multiprocessing
import gevent as g


def calc():
    x = 0
    for i in xrange(2300000000):
        x += i
    print x


def coroutine():
    g.joinall([g.spawn(calc) for x in xrange(24)])


coroutine()


配合多进程将CPU全都跑到100%

#!/usr/bin/python

import multiprocessing
import gevent as g


def calc():
    x = 0
    for i in xrange(2300000000):
        x += i
    print x


def coroutine():
    g.joinall([g.spawn(calc) for x in xrange(24)])


pool = multiprocessing.Pool(processes = 24)

for h in xrange(24):
    pool.apply_async(coroutine)

pool.close()
pool.join()

golang明显更简单,因为go在底层封装了一些异步的函数,所以用起来十分方便,不使用runtime就会单进程在一颗CPU上跑,使用和逻辑CPU相同数目的进程就会把全部CPU跑满,基本上可以说和上边python的协程一样。

package main

import "fmt"
import "runtime"

var ch chan int = make(chan int, 50)

func calc() {
    x := 0
    for a := 0; a < 2300000000; a++ {
      x += a
    }
    ch <- x
}

func main() {
    runtime.GOMAXPROCS(24)
    for i := 0; i < 24; i++ {
        go calc()
    }
    for v := range ch {
        fmt.Println(v)
        if len(ch) <= 0 {
            break
        }
    }
    fmt.Println("Done!")
}


目录
相关文章
|
2月前
|
编译器 C++
【C++核心】函数的应用和提高详解
这篇文章详细讲解了C++函数的定义、调用、值传递、常见样式、声明、分文件编写以及函数提高的内容,包括函数默认参数、占位参数、重载等高级用法。
23 3
|
6月前
|
开发框架 安全 .NET
C#的核心知识总结
【5月更文挑战第17天】C#是面向对象的编程语言,用于Windows、Web及跨平台应用开发。关键概念包括:基础语法(变量、控制语句、函数)、类与对象(封装、继承、多态)、接口和委托(抽象类型与类型安全的方法引用)、LINQ查询(集成查询语言)以及异步编程(async/await、Task)。此外,还有泛型、反射和特性等进阶主题。
48 1
|
Linux Go 开发工具
为什么开源是现代开发的核心?
为什么开源是现代开发的核心?
287 0
|
6月前
|
UED
产品服务的核心功能
产品服务的核心功能
124 1
|
6月前
|
资源调度 供应链 监控
深入探究:ERP系统的核心模块解析
深入探究:ERP系统的核心模块解析
324 0
|
6月前
|
开发框架 网络安全 数据库
典型应用集成技术
【1月更文挑战第11天】典型应用集成技术。
39 0
|
XML 开发框架 安全
C#学习核心知识总结
C#学习核心知识总结
53 1
电子游戏的核心原理
你小时候有没有玩过这样一种玩具:一块硬纸,一面画着一只鸟,一面画着一个笼子。硬纸下粘上一根细棒。用手来回转动细棒,让硬纸的两面快速交替出现,就会看见鸟被关在了笼子里。
|
存储 运维 Kubernetes
【K8S 核心架构原理】
K8S 是属于主从设备模型(Master-Slave 架构),即有 Master 节点负责核心的调度、管理和运维,Slave 节点则执行用户的程序。
221 0
|
Oracle Java 关系型数据库
Spring+Mybatis整合核心知识
Spring+Mybatis整合核心知识点
129 0
Spring+Mybatis整合核心知识
下一篇
无影云桌面