GoLang并发示例代码1(关于逻辑处理器运行顺序)

文章目录

    • [一开始我也不知道为什么多次go run都是先运行第二个goroutine](#一开始我也不知道为什么多次go run都是先运行第二个goroutine)
go 复制代码
// This sample program demonstrates how to create goroutines and
// how the scheduler behaves.
package main

import (
	"fmt"
	"runtime"
	"sync"
)

// main is the entry point for all Go programs.
func main() {
	// Allocate 1 logical processor for the scheduler to use.
	// 在多核机器上,如果不指定 GOMAXPROCS,默认会使用所有可用的处理器核。这里显式地将其设置为 1,使得所有的 goroutines 都在一个逻辑处理器上执行(即单线程调度)。
	// 限制调度器只使用一个 CPU 核心,即模拟单线程执行环境
	runtime.GOMAXPROCS(1)

	// wg is used to wait for the program to finish.
	// Add a count of two, one for each goroutine.
	// sync.WaitGroup 是用来等待一组 goroutine 完成的同步工具
	// WaitGroup 是一个计数器,在每个 goroutine 完成时调用 Done 方法,将计数器减少。调用 Wait() 会阻塞,直到计数器减到 0 为止。
	var wg sync.WaitGroup
	wg.Add(2)

	fmt.Println("Start Goroutines")

	// Declare an anonymous function and create a goroutine.
	go func() {
		// Schedule the call to Done to tell main we are done.
		defer wg.Done()

		// Display the alphabet three times
		for count := 0; count < 3; count++ {
			for char := 'a'; char < 'a' + 26; char++ {
				fmt.Printf("%c ", char)
			}
			fmt.Println()
		}
	}()

	// Declare an anonymous function and create a goroutine.
	go func() {
		// Schedule the call to Done to tell main we are done.
		defer wg.Done()

		// Display the alphabet three times
		for count := 0; count < 3; count++ {
			for char := 'A'; char < 'A'+26; char++ {
				fmt.Printf("%c ", char)
			}
			fmt.Println()
		}
	}()

	// Wait for the goroutines to finish.
	fmt.Println("Waiting To Finish")

	// wg.Wait() 会阻塞主线程,直到 WaitGroup 计数器归零(即所有 goroutines 都调用了 Done)
	wg.Wait()

	fmt.Println("\nTerminating Program")
}
bash 复制代码
root@GoLang:~/proj1/GoDistributeCache# go run /root/proj1/GoDistributeCache/example/test.go
Start Goroutines
Waiting To Finish
A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 
A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 
A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 
a b c d e f g h i j k l m n o p q r s t u v w x y z 
a b c d e f g h i j k l m n o p q r s t u v w x y z 
a b c d e f g h i j k l m n o p q r s t u v w x y z 

Terminating Program
root@GoLang:~/proj1/GoDistributeCache# 

一开始我也不知道为什么多次go run都是先运行第二个goroutine


当改成runtime.GOMAXPROCS(2)每次运行结果就不一定相同顺序了

之后我会持续更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗感谢支持!

相关推荐
MATLAB代码顾问11 分钟前
多种群协同进化算法(MPCE)求解大规模作业车间调度问题——附MATLAB代码
开发语言·算法·matlab
Nicander13 分钟前
理解 mybatis 源码:vibe-coding一个mini-mybatis
后端·mybatis
LaughingZhu24 分钟前
Product Hunt 每日热榜 | 2026-04-30
人工智能·经验分享·深度学习·神经网络·产品运营
代码小书生41 分钟前
statistics,一个统计的 Python 库!
开发语言·python
小呆呆66643 分钟前
Codex 穷鬼大救星
前端·人工智能·后端
摇滚侠1 小时前
整洁的桌面和任务栏 Java 开发工程师提效方法
java·开发语言
知识分享小能手1 小时前
R语言入门学习教程,从入门到精通,R语言数据计算与分组统计(9)
开发语言·学习·r语言
2501_943205051 小时前
【186期】游戏玩家专用精简版系统,Windows11_24H2游戏版详解
经验分享
山居秋暝LS1 小时前
安装C++版opencv和opencv_contrib
开发语言·c++·opencv
FelixBitSoul1 小时前
缓存淘汰策略全解:从原理到手写实现(Java / Go / Python)
后端·面试