登录
首页 >  Golang >  Go问答

自动将子类实例转换为接口的 过程

来源:stackoverflow

时间:2024-02-10 11:00:23 368浏览 收藏

学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《自动将子类实例转换为接口的 过程》,以下内容主要包含等知识点,如果你正在学习或准备学习Golang,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!

问题内容

我有一个界面,如下所示:

type collections[t any] interface {
    add(element t) bool

    get(index uint64) t

    length() uint64
}

我有一个子类实现该接口:

type linkedlist[t any] struct {
    size uint64
    head *linkedlistnode[t]
    tail *linkedlistnode[t]
}

我定义了一个包函数:

func isempty[t any](collections collections[t]) bool {
    if collections == nil {
        return true
    }

    return collections.length() <= 0
}

现在我有一个问题,如果我有这样的构造函数:

func newlinkedlist[t any]() collections[t] {
    linklist := &linkedlist[t]{size: 0}

    headnode := &linkedlistnode[t]{}
    tailnode := &linkedlistnode[t]{}

    headnode.next = tailnode
    tailnode.pre = headnode

    linklist.head = headnode
    linklist.tail = tailnode

    return linklist
}

然后我可以像这样使用包函数:

func testlinkedlistcreate(t *testing.t) {
    var obj = datastruct.newlinkedlist[string]()
    empty := datastruct.isempty(obj)
    println(empty)
}

但是如果我有一个像这样的构造函数:

func newlinkedlist[t any]() *linkedlist[t] {
    linklist := &linkedlist[t]{size: 0}

    headnode := &linkedlistnode[t]{}
    tailnode := &linkedlistnode[t]{}

    headnode.next = tailnode
    tailnode.pre = headnode

    linklist.head = headnode
    linklist.tail = tailnode

    return linklist
}

我必须使用这样的包函数:

func TestLinkedListCreate(t *testing.T) {
    var obj datastruct.Collections[string] = datastruct.NewLinkedList[string]()
    empty := datastruct.IsEmpty(obj)
    println(empty)
}

为什么golang可以在函数中自动将子类转换为接口,但不能在声明中将子类转换为接口?

我使用golang 1.19


正确答案


Volkerin a comment

本篇关于《自动将子类实例转换为接口的 过程》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

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