首页  >  文章  >  后端开发  >  如何在 Go 中创建唯一整数的通道?

如何在 Go 中创建唯一整数的通道?

Linda Hamilton
Linda Hamilton原创
2024-10-26 18:50:30304浏览

How to Create a Channel of Unique Integers in Go?

在 Go 中创建不同的通道

在此编程问题中,Go 初学者寻求一种有效的方法来定义输出唯一值的通道。具体要求是创建一个接受整数值并且仅传输不同整数的通道。目标是避免输出中出现重复的整数。

其中一个响应建议使用映射来存储先前传输的值以实现此功能。虽然这种方法可以有效消除重复值,但内存使用是一个考虑因素。地图数据结构需要分配和维护键值对的集合,如果管理不仔细,可能会导致内存泄漏。

为了提供实用的解决方案,以下代码片段介绍了 UniqueGen 函数,该函数生成指定范围内唯一整数的通道:

<code class="go">func UniqueGen(min, max int) <-chan int {
    m := make(map[int]struct{}, max-min)
    ch := make(chan int)
    go func() {
        for i := 0; i < 1000; i++ {
            v := min + rand.Intn(max)
            if _, ok := m[v]; !ok {
                ch <- v
                m[v] = struct{}{}
            }
        }
        close(ch)
    }()

    return ch
}</code>

UniqueGen 函数使用映射来记录传输的整数。它启动一个 goroutine,重复生成指定范围内的整数。对于每个生成的值,该函数通过在映射中查找来检查它是否已被传输。如果没有,它会通过通道发送整数并将其记录在映射中。此过程有效地过滤掉重复值,确保仅通过通道传输不同的整数。

使用 UniqueGen 函数,可以实现以下测试用例来演示该行为:

<code class="go">func TestShouldReturnDistinctValues(t *testing.T) {
    var c = make([]chan int)

    c <- UniqueGen(1, 1000)

    for e := range c {
        // only print distinct values 
        fmt.println(e)
    }
}</code>

此测试用例将生成一个包含 1000 个唯一整数的通道并将它们打印到控制台。通过利用 UniqueGen 函数,测试可以确保其输出不同的值。

以上是如何在 Go 中创建唯一整数的通道?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn