登录
首页 >  Golang >  Go问答

使用 nil 传递 Golang 指针给方法不会导致更新

来源:stackoverflow

时间:2024-02-24 18:48:25 345浏览 收藏

欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《使用 nil 传递 Golang 指针给方法不会导致更新》,这篇文章主要讲到等等知识,如果你对Golang相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!

问题内容

我正在尝试使用递归函数创建一个线性链表,但由于某种原因我没有得到正确的结果。

当我向列表中添加数字时,我注意到 l.headrecursiveadd 方法返回后永远不会更新。鉴于它是一个指针,难道不应该更新它吗?

list.display() 后的预期结果: 1 2 3

实际结果:空字符串

package main

import "fmt"

type Node struct {
    num int
    next *Node
}

type List struct {
    head *Node
}

func (L *List) Add(n int) {
    L.recursiveAdd(L.head, n)
}

func recursiveAdd(node *Node, n int){
    if node == nil {
        node = &Node{n, nil}
        return
    }
    L.recursiveAdd(node.next, n)
}

func (L *List) Display() {
    recursiveDisplay(L.head)
}

func recursiveDisplay(n *Node){
    if n == nil {
        return
    }
    fmt.Println(n.num)
    recursiveDisplay(n.next)
}

func main(){
    list := List{}

    list.Add(1)
    list.Add(2)
    list.Add(3)

    list.Display()
}

解决方案


list.add 不会更新 l.head。您将 l.head 传递给 recursiveadd,但您传递的是 l.head 的副本,该副本为 nil,并且当您为其分配值时,您仅更新堆栈上指针的副本,而不是 l.head。你可以这样做:

func (L *List) Add(n int) {
    l.head=L.recursiveAdd(L.head, n)
}

func (L *list) recursiveAdd(node *Node, n int) *Node{
    if node == nil {
        node = &Node{n, nil}
        return node
    }
    node.next=L.recursiveAdd(node.next,n)
    return node
}

终于介绍完啦!小伙伴们,这篇关于《使用 nil 传递 Golang 指针给方法不会导致更新》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

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