欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java版數(shù)據(jù)結(jié)構(gòu)插入數(shù)據(jù)時遇到的結(jié)點為空的問題詳解

 更新時間:2019年09月10日 08:30:08   作者:Devil瑞  
這篇文章主要介紹了Java版數(shù)據(jù)結(jié)構(gòu)插入數(shù)據(jù)時遇到的結(jié)點為空的問題及解決辦法,需要的朋友們可以學(xué)習(xí)下。

在演示Java版數(shù)據(jù)結(jié)構(gòu)與算法教材中的頭插法代碼時遇到了空結(jié)點問題 。 先上代碼。

鏈表類

import java.util.Scanner;

 public class ListLinked<T> {
   ListLinkedNode<Integer> head=new ListLinkedNode<Integer>();//聲明頭結(jié)點
  //添加結(jié)點
  public void addFromHead(int e){
    ListLinkedNode<Integer> p=new ListLinkedNode<Integer>();//聲明并創(chuàng)建結(jié)點p為插入結(jié)點
    p.setData(e);
    p.setNext(head.getNext());
    head.setNext(p);//將p插入到頭結(jié)點后
  }
  //頭插法創(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è)置數(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;
  }
  //無參構(gòu)造函數(shù)
  public ListLinkedNode() {
    
  }
}

測試類

public class test {
  public static void main(String[] args) {
    ListLinked list=new ListLinked();
    list.createFromHead();
    list.display();
  }

}

測試,在判斷p是否為空執(zhí)行輸出的時候,p一直為null。 

打斷點調(diào)試的時候發(fā)現(xiàn)了問題所在。

因為java把引用類型當(dāng)作了指針,所以在addFromHead方法里,head里的next存的是p對象的地址。

當(dāng)出了addFromHead方法,局部變量p的生命周期結(jié)束被垃圾回收機制帶走

棧中沒有變量再指向之前在堆中的p對象,所以堆中的對象也被當(dāng)作了垃圾被帶走,head的next又變成了null

 

以上就是Java版數(shù)據(jù)結(jié)構(gòu)插入數(shù)據(jù)時遇到的結(jié)點為空的問題的全部內(nèi)容,感謝大家對腳本之家的支持。

相關(guān)文章

  • Java枚舉使用方法詳解

    Java枚舉使用方法詳解

    這篇文章主要為大家詳細(xì)介紹了Java枚舉的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • Java之Mybatis的二級緩存

    Java之Mybatis的二級緩存

    本文主要介紹Java中Mybatis的二級緩存,緩存就是一塊內(nèi)存空間,保存臨時數(shù)據(jù),它是SqlSessionFactory的緩存,對Mybaits感興趣的小伙伴可以參考閱讀
    2023-03-03
  • Spring?Boot實現(xiàn)分布式任務(wù)調(diào)度的步驟

    Spring?Boot實現(xiàn)分布式任務(wù)調(diào)度的步驟

    Spring?Boot提供了一些工具和框架,可以幫助我們輕松地實現(xiàn)分布式任務(wù)調(diào)度,在本文中我們將介紹如何使用Spring?Boot、Spring?Cloud、Quartz和Redis來實現(xiàn)分布式任務(wù)調(diào)度,感興趣的朋友跟隨小編一起看看吧
    2023-06-06
  • spring?cloud之eureka高可用集群和服務(wù)分區(qū)解析

    spring?cloud之eureka高可用集群和服務(wù)分區(qū)解析

    這篇文章主要介紹了spring?cloud之eureka高可用集群和服務(wù)分區(qū)解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • ES6學(xué)習(xí)筆記之新增數(shù)據(jù)類型實例解析

    ES6學(xué)習(xí)筆記之新增數(shù)據(jù)類型實例解析

    這篇文章主要介紹了ES6學(xué)習(xí)筆記之新增數(shù)據(jù)類型,結(jié)合實例形式分析了ES6數(shù)據(jù)解構(gòu)賦值、新增數(shù)據(jù)類型Set集合、新增數(shù)據(jù)類型Map、Symbol類型等相關(guān)原理與操作注意事項,需要的朋友可以參考下
    2020-01-01
  • SpringBoot+Vue實現(xiàn)動態(tài)菜單的思路梳理

    SpringBoot+Vue實現(xiàn)動態(tài)菜單的思路梳理

    這篇文章主要為大家詳細(xì)介紹了利用SpringBoot+Vue實現(xiàn)動態(tài)菜單的思路梳理,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以動手嘗試一下
    2022-07-07
  • 使用Filter實現(xiàn)登錄權(quán)限驗證

    使用Filter實現(xiàn)登錄權(quán)限驗證

    這篇文章主要為大家詳細(xì)介紹了使用Filter實現(xiàn)登錄權(quán)限驗證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • 電腦上安裝多個JDK版本時該如何自由切換(詳細(xì)圖文)

    電腦上安裝多個JDK版本時該如何自由切換(詳細(xì)圖文)

    我們在學(xué)習(xí)的過程中經(jīng)常用到不同的jdk版本,那么如何在一臺電腦上同時安裝多個jdk版本并進行切換呢,這篇文章主要給大家介紹了關(guān)于電腦上安裝多個JDK版本時該如何自由切換的相關(guān)資料,需要的朋友可以參考下
    2023-10-10
  • MyBatis緩存功能原理及實例解析

    MyBatis緩存功能原理及實例解析

    這篇文章主要介紹了MyBatis緩存功能原理及實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • SpringBoot整合Redis管道的示例代碼

    SpringBoot整合Redis管道的示例代碼

    本文將結(jié)合實例代碼,介紹SpringBoot整合Redis管道,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-07-07

最新評論