Java版數(shù)據(jù)結構插入數(shù)據(jù)時遇到的結點為空的問題詳解
在演示Java版數(shù)據(jù)結構與算法教材中的頭插法代碼時遇到了空結點問題 。 先上代碼。
鏈表類
import java.util.Scanner;
public class ListLinked<T> {
ListLinkedNode<Integer> head=new ListLinkedNode<Integer>();//聲明頭結點
//添加結點
public void addFromHead(int e){
ListLinkedNode<Integer> p=new ListLinkedNode<Integer>();//聲明并創(chuàng)建結點p為插入結點
p.setData(e);
p.setNext(head.getNext());
head.setNext(p);//將p插入到頭結點后
}
//頭插法創(chuàng)建鏈表
public static ListLinked<Integer> createFromHead() {
ListLinked<Integer> listLinked=new ListLinked<>();//初始化鏈表
System.out.println("-頭插法建立鏈表-");
System.out.println("請輸入鏈表長度:");
Scanner sc=new Scanner(System.in);
//n : 鏈表長度
int n=sc.nextInt();
System.out.println("請輸入值:");
for(int i=0;i<n;i++) {
System.out.print("請輸入第"+(i+1)+"個值:");
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é)點類
public class ListLinkedNode<T>{
//數(shù)據(jù)成員
private T data;
private ListLinkedNode<T> next;
//獲得數(shù)據(jù)域
public T getData() {
return data;
}
//設置數(shù)據(jù)域
public void setData(T data) {
this.data=data;
}
//得到指針域
public ListLinkedNode<T> getNext(){
return next;
}
//設置指針域
public void setNext(ListLinkedNode<T> next) {
this.next=next;
}
//有參構造函數(shù)
public ListLinkedNode(T data) {
this.data=data;
this.next=null;
}
//無參構造函數(shù)
public ListLinkedNode() {
}
}
測試類
public class test {
public static void main(String[] args) {
ListLinked list=new ListLinked();
list.createFromHead();
list.display();
}
}
測試,在判斷p是否為空執(zhí)行輸出的時候,p一直為null。
打斷點調試的時候發(fā)現(xiàn)了問題所在。

因為java把引用類型當作了指針,所以在addFromHead方法里,head里的next存的是p對象的地址。
當出了addFromHead方法,局部變量p的生命周期結束被垃圾回收機制帶走
棧中沒有變量再指向之前在堆中的p對象,所以堆中的對象也被當作了垃圾被帶走,head的next又變成了null

以上就是Java版數(shù)據(jù)結構插入數(shù)據(jù)時遇到的結點為空的問題的全部內容,感謝大家對腳本之家的支持。
相關文章
spring?cloud之eureka高可用集群和服務分區(qū)解析
這篇文章主要介紹了spring?cloud之eureka高可用集群和服務分區(qū)解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03
SpringBoot+Vue實現(xiàn)動態(tài)菜單的思路梳理
這篇文章主要為大家詳細介紹了利用SpringBoot+Vue實現(xiàn)動態(tài)菜單的思路梳理,文中的示例代碼講解詳細,感興趣的小伙伴可以動手嘗試一下2022-07-07

