RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1410545
Accepted
Quester
Quester
Asked:2022-07-16 22:59:35 +0000 UTC2022-07-16 22:59:35 +0000 UTC 2022-07-16 22:59:35 +0000 UTC

竞争环境下的柜台结构

  • 772

大家好。任务是开发一个在竞争环境中工作的计数器结构。我不确定我是否正确理解了“结构计数器”一词。也许有人知道计数器结构是什么意思?我是这么理解的

package main

import (
    "sync"

    "github.com/udonetsm/help/helper"
)

type Counter struct {
    num int
    sync.RWMutex
}

func (c *Counter) Count(wg *sync.WaitGroup, finish, start int) int {
    defer helper.PanicCapture("Count")
    wg.Add(finish - start)
    for c.num < finish {
        go func() {
            c.Lock()
            c.num += 1
            c.Unlock()
            wg.Done()
        }()
    }
    return c.num
}

func New(start int) *Counter {
    defer helper.PanicCapture("INIT")
    return &Counter{
        num: start,
    }
}

func Counting(start, finish int) {
    defer helper.PanicCapture("Counting")
    c := New(start)
    wg := sync.WaitGroup{}
    c.Count(&wg, finish, start)
    wg.Wait()
}

不断地给人一种恐慌 panic: sync: negative WaitGroup counter

package main

import (
    "log"
    "sync"
    "time"

    "github.com/udonetsm/help/helper"
)

type Counter struct {
    num int
    sync.RWMutex
}

func (c *Counter) Count(wg *sync.WaitGroup, finish, start int) int {
    defer helper.PanicCapture("Count")
    wg.Add(1)
    go func() {
        for i := start; i <= finish; i++ {
            c.Lock()
            c.num += 1
            c.Unlock()
            log.Println(c.num)
            time.Sleep(time.Second)
        }
        wg.Done()
    }()
    wg.Wait()
    return c.num
}

func New(start int) *Counter {
    defer helper.PanicCapture("INIT")
    return &Counter{
        num: -1,
    }
}

func Counting(start, finish int) {
    defer helper.PanicCapture("Counting")
    c := New(start)
    wg := sync.WaitGroup{}
    log.Println(c.Count(&wg, finish, start))
}

所以他并不恐慌,他没有正确使用 Wait 。但是不知道有没有看懂counter的结构

golang
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Maksim Fedorov
    2022-07-17T02:25:03Z2022-07-17T02:25:03Z

    首先 - 你正确地制作了计数器的结构

    但是你让柜台工作变得非常困难 - 出于某种原因输入了一些 finsih 和 start 。它有一个简单的界面:

    Inc()用于增量和Value()获取当前值

    剩下的只是一个竞争环境:有些东西是通过努力工作的,有些东西会考虑这项工作的结果……主要是结果是正确的,也就是说,goroutines 不会在竞争的同时读取状态不要增加(例如,一对/三个 goroutine 没有一次增加计数器5状态6)

    package main
    
    import (
        "fmt"
        "log"
        "sync"
    )
    
    type Counter struct {
        num int
        sync.Mutex
    }
    
    func (c *Counter) Inc() {
        c.Lock()
        defer c.Unlock()
    
        c.num += 1
    }
    
    func (c *Counter) Value() int {
        return c.num
    }
    
    func main() {
        cnt := &Counter{
            num: 0,
        }
    
        finish := make(chan struct{})
    
        go Do(cnt, finish)
    
        select {
        case <-finish:
            log.Printf("Work done with count: %d", cnt.Value())
        }
    }
    
    func Do(cnt *Counter, finish chan struct{}) {
        wg := sync.WaitGroup{}
    
        // Hard work in goroutine and finish work
        for i := 0; i < 20; i++ {
            wg.Add(1)
    
            // Тяжелая работа
            go func(num int, cnt *Counter, wg *sync.WaitGroup) {
                defer wg.Done()
    
                fmt.Printf("Worker %d starting\n", num)
                cnt.Inc()
                fmt.Printf("Worker %d done\n", num)
            }(i, cnt, &wg)
        }
    
        wg.Wait()
        finish <- struct{}{}
        close(finish)
    }
    

    https://go.dev/play/p/mb9NGCVBC-K

    • 2

相关问题

  • windows上的protoc编译错误

  • 递归打印包依赖

  • Golang 算法 XTEA ECB 库“golang.org/x/crypto/xtea”

  • 如何将 IMEI 转换为字节并返回 golang

  • 如何创建文件并将其移动到新目录?

  • go中的函数参数中是否有cv-qualifier的类似物?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5