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)每次运行结果就不一定相同顺序了

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

相关推荐
05候补工程师1 分钟前
【英语学习笔记】基于“底层逻辑转换”与“去动词化”的英汉互译核心方法论及写作高分公式
经验分享·笔记·学习·考研
凯瑟琳.奥古斯特5 分钟前
10道数据库原理精选题
开发语言·数据库·职场和发展·数据库开发
z落落6 分钟前
C# Stack栈 / Queue队列+所有集合 终极一页汇总(全覆盖、零遗漏)
java·开发语言·c#
2501_943205056 分钟前
【210期】U盘修复写保护解除工具V1.0
经验分享
skywalk81637 分钟前
设计和实现一门中文编程语言,有什么工具可以使用吗?是不是ANTLR 和LLVM都可以使用?Racket恐怕不适用吧
开发语言·编程
磊 子16 分钟前
STL之set以及set和map区别
开发语言·c++·算法
huangdong_20 分钟前
爬虫与浏览器的本质区别:从HTTP协议层到渲染引擎的完整对比
经验分享
Halo_tjn21 分钟前
NIO 技术的使用
java·开发语言·nio
砍材农夫21 分钟前
物联网 基于netty核心实战-安全tls
java·开发语言·前端·物联网·安全
SEO_juper21 分钟前
JavaScript 渲染:AI 智能体无法读取,直接影响收录
开发语言·前端·javascript·aigc·seo·跨境电商·geo