当前位置: 首页 > article >正文

Golang 设置运行的cpu数与channel管道

介绍:为了充分了利用多cpu的优势,在Golang程序中,设置运行的cpu数目。

func main() {
	//获取系统当前cpu的数量
	num := runtime.NumCPU()
	//这里根据需求来设置整个go程序去使用几个cpu
	runtime.GOMAXPROCS(num)
	fmt.Println("num =", num)
}

比如你有逻辑的4个cpu,但是在程序里面只想使用3个。另外一个我要保留下来给其他程序使用,因为你占满了cpu导致其他程序可能跑不起来了。

(1)go1.8后,默认让程序运行在多个核上,可以不用设置了
(2)go1.8前,还是要设置一下,可以更高效的利益cpu
 

 

 

channel(管道)-看个需求


需求:现在要计算1-200的各个数的阶乘,并且把各个数的阶乘放入到map中。最后显示出来。要求使用goroutine完成

分析思路:
1)使用goroutine来完成,效率高,但是会出现并发/并行安全问题.
2)这里就提出了不同goroutine如何通信的问题
代码实现
1)使用goroutine来完成(看看使用gorotine并发完成会出现什么问题?然后我们会去解决)
2)在运行某个程序时,如何知道是否存在资源竞争问题。方法很简单,在编译该程序时,增加一个参数-race即可[示意图]

package main

import (
	"fmt"
	"time"
)

var (
	m = make(map[int]int, 10)
)

// test函数就是计算n的阶乘
func test(n int) {
	res := 1
	for i := 1; i <= n; i++ {
		res = res * i
	}
	//将计算结果放到map当中
	m[n] = res
}

func main() {
	//这里开启多协程完成任务
	for i := 1; i <= 100; i++ {
		go test(i)
	}

	time.Sleep(time.Second * 10)
	for k, v := range m {
		fmt.Println(k, v)
	}
}

fatal error: concurrent map writes                           

多个协程在同时操作同一块的map空间。

==================
WARNING: DATA RACE
Write at 0x00c00013e480 by goroutine 8:
  runtime.mapassign_fast64()
      D:/Go/src/runtime/map_fast64.go:93 +0x0
  main.test()
      C:/Users/W10/GolandProjects/goroutine/channel.go:19 +0x70
  main.main.func1()
      C:/Users/W10/GolandProjects/goroutine/channel.go:25 +0x39

Previous write at 0x00c00013e480 by goroutine 7:
  main.main()
      C:/Users/W10/GolandProjects/goroutine/channel.go:25 +0x84

Goroutine 7 (finished) created at:
  main.main()
      C:/Users/W10/GolandProjects/goroutine/channel.go:25 +0x84

Found 2 data race(s)

可以看到有几个数据发生竞争关系。

 

 


http://www.kler.cn/a/146627.html

相关文章:

  • candb++ windows11运行报错,找不到mfc140.dll
  • 使用docker-compose安装Redis的主从+哨兵模式
  • 【AIGC-ChatGPT进阶提示词指令】智慧母婴:打造基于成长树的儿童发展引导系统
  • ISP各模块功能介绍
  • IDEA的Git界面(ALT+9)log选项不显示问题小记
  • Kylin: `GLIBC_2.34‘ not found
  • python生成邀请码,手机验证码
  • uniapp (vue3)生成二维码
  • 这回稳了,4G低功耗摄像头实现全景拍照解决方案来了
  • Linux shell编程学习笔记30:打造彩色的选项菜单
  • 【Proteus仿真】【STM32单片机】感应水龙头设计
  • 枚举 组合数 P3799 妖梦拼木棒
  • MySQL--锁
  • NSGA-II求解微电网多目标优化调度(MATLAB)
  • 鼠标拖拽问题,不选中文本不触发单击事件
  • linux 搭建Nginx网页(编译安装)
  • OJ练习第186题——统计子串中的唯一字符
  • Python 进阶(十一):高精度计算(decimal 模块)
  • FTP服务器搭建
  • springBoot常见的问题
  • C++const指针的两种用法
  • 【SpringBoot3+Vue3】五【完】【实战篇】-前端(配合后端)
  • 学习课题:逐步构建开发播放器【QT5 + FFmpeg6 + SDL2】
  • springboot函数式web
  • 亚马逊云科技re:Invent大会:云计算与生成式AI共筑科技新局面,携手构建未来
  • ubuntu 安装 jetbrains-toolbox