java链表算法题中,把链表已被删除结点置空的问题

新手上路,请多包涵

如题所示:

public class test {
public static void deleteNodeC(Node currentNode){
//单独是考虑核心部分
currentNode =currentNode.next;//已经到了NodeB
Node deletedNode = currentNode.next;//deletedNode 指向了nodeC
currentNode.next=deletedNode.next;
deletedNode=null;//这一步置空是不是多余?画蛇添足毫无作用还是一种良好的编程习惯?
}
public static void main(String[] args) {
Node nodeA= new Node();
Node nodeB= new Node();
Node nodeC= new Node();
Node nodeD= new Node();

    nodeA.next=nodeB;
    nodeB.next=nodeC;
    nodeC.next=nodeD;

    deleteNodeC(nodeA);
}

}

ABCD链表四个结点,当前结点是B结点Node nodeB = new Node(),将要删除C结点
deletedNode=null;//这一步置空是不是多余?画蛇添足毫无作用还是一种良好的编程习惯?
是否涉及到参数传递问题?

阅读 3.5k
1 个回答

将变量设为 null 是多余的行为。如果它是一个本地变量,那么方法执行完系统就会自动回收引用。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题