登录
首页 >  Golang >  Go问答

将引用的内部结构字段与 go 中的字符串类型进行比较

来源:stackoverflow

时间:2024-02-20 09:21:55 268浏览 收藏

一分耕耘,一分收获!既然都打开这篇《将引用的内部结构字段与 go 中的字符串类型进行比较》,就坚持看下去,学下去吧!本文主要会给大家讲到等等知识点,如果大家对本文有好的建议或者看到有不足之处,非常欢迎大家积极提出!在后续文章我会继续更新Golang相关的内容,希望对大家都有所帮助!

问题内容

假设我有两个定义链表的结构:

....
....

type node struct {
    item interface{}
    next *node
}

type linkedlist struct {
    first *node
    n int
}

...
...

我想比较底层节点类型的值,比如说,在一个 find 函数中,我们检查 k == node.item 是否这样:

func (l *linkedlist) find (key interface{}) bool {

    result := false
    if !l.isempty() {
        for x:= l.first; x != nil; x = x.next {
            if x.item == key {
                result = true 
                break
            }
        }
    return result
}

这对于预期的 find 函数不起作用,因为底层类型不同,因此 func 将始终返回 false。我们可以通过反映类型来确认这一点:

fmt.println(reflect.typeof(key), reflect.typeof(x.item)) 
>>> string, *main.node

尝试过解决方法吗?

我尝试过断言类型,但可惜这不起作用并且出现恐慌

tmp := x.item.(string)
>>>panic: interface conversion: interface {} is *main.node, not string

这种情况与使用 fmt.sprintf(x.item) 相同

我有点不知道从这里该去哪里。有没有办法做到这一点?

将项目插入链接列表 以下代码片段应阐明如何处理插入

func (l *LinkedList) insertFirst(item interface{}) {
    var first *node = new(node)
    oldfirst := l.first
    first.item = item
    first.next = oldfirst
    l.first = first
    l.N++
}

.....
//which gets called somewhere like
var n *node = new(node)
n.item = item
l.insertFirst(n)


.....wait no theres the error! 
----------

burak-serdar 你 100% 正确,我正在将节点插入节点!


解决方案


find() 中的接口比较是有效的比较,如果键的类型和节点中存储的值的类型相同,则该比较有效。但是,有证据表明您添加了一个节点来代替值。

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

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