) var counter int
var lock sync.Mutex func increment() { lock."> ) var counter int
var lock sync.Mutex func increment() { lock.">
legongju.com
我们一直在努力
2025-01-14 18:03 | 星期二

Go语言并发编程怎样保证一致性

?Go???,????????????,??????????:

  1. ?????(Mutex):??????????,???????????????(goroutine)?????????Go?sync????Mutex???,????????????Lock()????,Unlock()?????
package main

import (
	"fmt"
	"sync"
)

var counter int
var lock sync.Mutex

func increment() {
	lock.Lock()
	counter++
	lock.Unlock()
}

func main() {
	wg := sync.WaitGroup{}
	for i := 0; i < 100; i++ {
		wg.Add(1)
		go func() {
			defer wg.Done()
			increment()
		}()
	}
	wg.Wait()
	fmt.Println("Counter:", counter)
}
  1. ?????(RWMutex):?????????????????,???????????????Go?sync????RWMutex???,????????????RLock()?????,RUnlock()?????,Lock()?????,Unlock()??????
package main

import (
	"fmt"
	"sync"
)

var data map[string]string
var rwLock sync.RWMutex

func readData(key string) {
	rwLock.RLock()
	value := data[key]
	rwLock.RUnlock()
	fmt.Println("Read:", value)
}

func writeData(key, value string) {
	rwLock.Lock()
	data[key] = value
	rwLock.Unlock()
}

func main() {
	data = https://www.yisu.com/ask/make(map[string]string)"hljs">func(i int) {
			defer wg.Done()
			key := fmt.Sprintf("key%d", i)
			value := fmt.Sprintf("value%d", i)
			writeData(key, value)
		}(i)
	}

	for i := 0; i < 100; i++ {
		wg.Add(1)
		go func(i int) {
			defer wg.Done()
			key := fmt.Sprintf("key%d", i)
			readData(key)
		}(i)
	}

	wg.Wait()
}
  1. ??????(atomic):???????????????,????????????????????Go?sync/atomic????????????,?AddInt32()?CompareAndSwapInt32()??
package main

import (
	"fmt"
	"sync"
	"sync/atomic"
)

var counter int32
var wg sync.WaitGroup

func increment() {
	atomic.AddInt32(&counter, 1)
}

func main() {
	for i := 0; i < 100; i++ {
		wg.Add(1)
		go func() {
			defer wg.Done()
			increment()
		}()
	}
	wg.Wait()
	fmt.Println("Counter:", counter)
}
  1. ????(channel):???Go????????????,??????????????????,??????????????????
package main

import (
	"fmt"
	"sync"
)

func worker(wg *sync.WaitGroup, ch chan int) {
	defer wg.Done()
	for i := range ch {
		fmt.Println("Received:", i)
	}
}

func main() {
	ch := make(chan int, 100)
	wg := sync.WaitGroup{}

	for i := 0; i < 10; i++ {
		wg.Add(1)
		go worker(&wg, ch)
	}

	for i := 0; i < 100; i++ {
		ch <- i
	}
	close(ch)

	wg.Wait()
}

??????????,???????,???????????????????,??????????????????

未经允许不得转载 » 本文链接:https://www.legongju.com/article/14988.html

相关推荐

  • go语言框架适合web吗

    go语言框架适合web吗

    Go语言框架确实适合用于Web开发,并且已经被许多公司和项目所采用。以下是Go语言框架在Web开发中的适用性分析:
    Go语言框架在Web开发中的适用性 并发性能:...

  • go语言框架能处理并发吗

    go语言框架能处理并发吗

    Go 语言本身是并发友好的,它内置了对并发的支持。Go 语言通过 goroutines 和 channels 提供了简洁的并发编程模型。goroutines 是轻量级的线程,它们在 Go 语言中...

  • go语言框架怎样选择合适

    go语言框架怎样选择合适

    在Go语言中,有许多优秀的Web框架可供选择。选择合适的框架取决于您的项目需求、个人喜好和团队经验。以下是一些流行的Go Web框架,以及它们的特点: Gin:Gin是...

  • go语言框架有哪些推荐

    go语言框架有哪些推荐

    在Go语言中,有许多优秀的框架可以帮助您更高效地开发应用程序。以下是一些建议的Go语言框架: Gin:Gin是一个高性能的HTTP Web框架,它提供了一个类似于Martini...

  • Go语言函数如何传递参数

    Go语言函数如何传递参数

    在Go语言中,函数参数的传递方式主要有两种:值传递和指针传递。 值传递(Pass by value):
    当你将一个变量作为参数传递给函数时,实际上是传递了这个变量...

  • Go语言函数怎样调用

    Go语言函数怎样调用

    在Go语言中,函数是一段具有特定功能的代码块。要调用一个函数,您需要遵循以下步骤: 首先,定义一个函数。函数定义包括函数名、参数列表和函数体。例如,我们定...

  • Go语言函数如何定义

    Go语言函数如何定义

    在Go语言中,函数是一种用于执行特定任务的代码块。要定义一个函数,您需要指定函数的名称、参数列表(如果有)以及返回值(如果有)。以下是Go语言中定义函数的...

  • Go语言通道如何进行文档编写

    Go语言通道如何进行文档编写

    在Go语言中,通道(channel)是一种用于在不同的goroutine之间传递数据的同步机制。为了编写关于通道的文档,你可以遵循以下步骤: 描述通道的基本概念和用途:<...