go语言面试题:goroutine、waitgroup、mutex

本文通过一道Go语言面试题,探讨了goroutine、waitgroup和mutex在并发编程中的应用。分析了并发写入map时可能出现的问题,强调了在并发环境下对非线程安全数据结构的操作需要同步机制。通过示例展示了不加锁和加锁情况下map的执行结果,解释了加锁的意义以及如何正确地向map中写入N对键值对。
摘要由CSDN通过智能技术生成

点击个人博客,查看更多文章https://elonjelinek.github.io

判断程序的执行结果,并解释原因

package main

import (
	"fmt"
	"sync"
)

const N = 20

func main() {
   
	wg := sync.WaitGroup{
   }
	mu := sync.Mutex{
   }
	m := make(map[int]int)

	wg.Add(N)

	for i := 0; i < N; i++ {
   
		go func() {
   
			mu.Lock()
			defer wg.Done()
			m[i] = i
			mu.Unlock()
		}()
	}
	wg.Wait()
	fmt.Println(len(m))
	fmt.Println(m)
}

运行结果

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值