Java版數(shù)據(jù)結(jié)構(gòu)插入數(shù)據(jù)時(shí)遇到的結(jié)點(diǎn)為空的問(wèn)題詳解
在演示Java版數(shù)據(jù)結(jié)構(gòu)與算法教材中的頭插法代碼時(shí)遇到了空結(jié)點(diǎn)問(wèn)題 。 先上代碼。
鏈表類
import java.util.Scanner; public class ListLinked<T> { ListLinkedNode<Integer> head=new ListLinkedNode<Integer>();//聲明頭結(jié)點(diǎn) //添加結(jié)點(diǎn) public void addFromHead(int e){ ListLinkedNode<Integer> p=new ListLinkedNode<Integer>();//聲明并創(chuàng)建結(jié)點(diǎn)p為插入結(jié)點(diǎn) p.setData(e); p.setNext(head.getNext()); head.setNext(p);//將p插入到頭結(jié)點(diǎn)后 } //頭插法創(chuàng)建鏈表 public static ListLinked<Integer> createFromHead() { ListLinked<Integer> listLinked=new ListLinked<>();//初始化鏈表 System.out.println("-頭插法建立鏈表-"); System.out.println("請(qǐng)輸入鏈表長(zhǎng)度:"); Scanner sc=new Scanner(System.in); //n : 鏈表長(zhǎng)度 int n=sc.nextInt(); System.out.println("請(qǐng)輸入值:"); for(int i=0;i<n;i++) { System.out.print("請(qǐng)輸入第"+(i+1)+"個(gè)值:"); int e=sc.nextInt(); listLinked.addFromHead(e); } System.out.println("鏈表創(chuàng)建完畢"); return listLinked; } //輸出 public void display() { System.out.println("{"); ListLinkedNode<Integer> p=new ListLinkedNode<Integer>(); p=head.getNext(); while(p!=null) { int value=p.getData(); System.out.println(value); p=p.getNext(); } System.out.println("}"); } }
節(jié)點(diǎn)類
public class ListLinkedNode<T>{ //數(shù)據(jù)成員 private T data; private ListLinkedNode<T> next; //獲得數(shù)據(jù)域 public T getData() { return data; } //設(shè)置數(shù)據(jù)域 public void setData(T data) { this.data=data; } //得到指針域 public ListLinkedNode<T> getNext(){ return next; } //設(shè)置指針域 public void setNext(ListLinkedNode<T> next) { this.next=next; } //有參構(gòu)造函數(shù) public ListLinkedNode(T data) { this.data=data; this.next=null; } //無(wú)參構(gòu)造函數(shù) public ListLinkedNode() { } }
測(cè)試類
public class test { public static void main(String[] args) { ListLinked list=new ListLinked(); list.createFromHead(); list.display(); } }
測(cè)試,在判斷p是否為空?qǐng)?zhí)行輸出的時(shí)候,p一直為null。
打斷點(diǎn)調(diào)試的時(shí)候發(fā)現(xiàn)了問(wèn)題所在。
因?yàn)閖ava把引用類型當(dāng)作了指針,所以在addFromHead方法里,head里的next存的是p對(duì)象的地址。
當(dāng)出了addFromHead方法,局部變量p的生命周期結(jié)束被垃圾回收機(jī)制帶走
棧中沒(méi)有變量再指向之前在堆中的p對(duì)象,所以堆中的對(duì)象也被當(dāng)作了垃圾被帶走,head的next又變成了null
以上就是Java版數(shù)據(jù)結(jié)構(gòu)插入數(shù)據(jù)時(shí)遇到的結(jié)點(diǎn)為空的問(wèn)題的全部?jī)?nèi)容,感謝大家對(duì)腳本之家的支持。
相關(guān)文章
Spring?Boot實(shí)現(xiàn)分布式任務(wù)調(diào)度的步驟
Spring?Boot提供了一些工具和框架,可以幫助我們輕松地實(shí)現(xiàn)分布式任務(wù)調(diào)度,在本文中我們將介紹如何使用Spring?Boot、Spring?Cloud、Quartz和Redis來(lái)實(shí)現(xiàn)分布式任務(wù)調(diào)度,感興趣的朋友跟隨小編一起看看吧2023-06-06spring?cloud之eureka高可用集群和服務(wù)分區(qū)解析
這篇文章主要介紹了spring?cloud之eureka高可用集群和服務(wù)分區(qū)解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03ES6學(xué)習(xí)筆記之新增數(shù)據(jù)類型實(shí)例解析
這篇文章主要介紹了ES6學(xué)習(xí)筆記之新增數(shù)據(jù)類型,結(jié)合實(shí)例形式分析了ES6數(shù)據(jù)解構(gòu)賦值、新增數(shù)據(jù)類型Set集合、新增數(shù)據(jù)類型Map、Symbol類型等相關(guān)原理與操作注意事項(xiàng),需要的朋友可以參考下2020-01-01SpringBoot+Vue實(shí)現(xiàn)動(dòng)態(tài)菜單的思路梳理
這篇文章主要為大家詳細(xì)介紹了利用SpringBoot+Vue實(shí)現(xiàn)動(dòng)態(tài)菜單的思路梳理,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以動(dòng)手嘗試一下2022-07-07使用Filter實(shí)現(xiàn)登錄權(quán)限驗(yàn)證
這篇文章主要為大家詳細(xì)介紹了使用Filter實(shí)現(xiàn)登錄權(quán)限驗(yàn)證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10電腦上安裝多個(gè)JDK版本時(shí)該如何自由切換(詳細(xì)圖文)
我們?cè)趯W(xué)習(xí)的過(guò)程中經(jīng)常用到不同的jdk版本,那么如何在一臺(tái)電腦上同時(shí)安裝多個(gè)jdk版本并進(jìn)行切換呢,這篇文章主要給大家介紹了關(guān)于電腦上安裝多個(gè)JDK版本時(shí)該如何自由切換的相關(guān)資料,需要的朋友可以參考下2023-10-10