登录
首页 >  Golang >  Go问答

如何在函数中使用不可导出的结构体

来源:stackoverflow

时间:2024-03-05 12:03:24 323浏览 收藏

目前golang学习网上已经有很多关于Golang的文章了,自己在初次阅读这些文章中,也见识到了很多学习思路;那么本文《如何在函数中使用不可导出的结构体》,也希望能帮助到大家,如果阅读完后真的对你学习Golang有帮助,欢迎动动手指,评论留言并分享~

问题内容

我有一个包,其中有未导出的结构并导出了用于创建它的新函数以及在此结构上运行的导出函数(例如此处建议的:从函数返回未导出的类型)。 如果我在调用 new 的同一位置运行该函数,我可以运行包函数,但无法将此实体发送到另一个函数。 无需将所有代码放在一个函数中即可实现此行为的最佳方法是什么

例如,这个有效:

client := package.new()

client.foo()

但这行不通:

client := package.New()

hello(client)


func hello(client interface{}) {

    client.Foo()

}

解决方案


您的 hello 函数本质上需要的是具有 foo 函数的东西。这就是 go 有接口的原因。返回未导出的类型没有任何问题(事实上,这很常见,而且通常是正确的做法)。我要做的是这样的:

package foobar

// whatever thing that has a foo function
type fclient interface {
    foo()
}

func hello(client fclient) {
    client.foo() // will work
}

这样做的原因是为了能够对这段代码进行单元测试:

package foobar_test

import (
    "testing"
)

type testFC struct {
    callCount uint64
}

// implement interface
func (t testFC) Foo() {
    testFC.callCount++
}

func TestHello(t *testing.T) {
    client := testFC{}
    Hello(client)
    if client.callCount != 1 {
        t.Fail("dependency not called")
    }
}

当然,对于更复杂的依赖关系,您可以使用诸如mockgen之类的工具或类似的东西,但您明白了。根据定义,unit 测试侧重于单个代码单元。测试包单元所需要做的最后一件事是实例化另一个包中的类型。您应该能够模拟代码所依赖的所有内容。最好的方法是接口。

终于介绍完啦!小伙伴们,这篇关于《如何在函数中使用不可导出的结构体》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>