教你实现链表判空与取值方法 | 带你学《Java面向对象编程》之九十二

简介: 有了增加方法和计数方法,那么如何直观地判断链表内有没有数据呢,本节将带读者实现isEmpty()方法进行判空操作、实现toArray()方法获取链表内所有数据。

上一篇:改数需备案-记录链表数据量 | 带你学《Java面向对象编程》之九十一
【本节目标】
通过阅读本节内容,你将学会实现isEmpty()和toArray()方法,为链表对象提供直接判断是否为空以及获取链表数据的方法,进一步完善链表类的相关功能。

空集合判断:public Boolean isEmpty()

链表里面可以保存有若干数据,如果说现在链表还没有保存数据,则就表示是一个空集合,则应该提供有一个空的判断。
1、在ILink接口里面追加有判断方法:

public boolean isEmpty() ;   //判断是否空集合

2、在LinkImpl子类里面覆写此方法。

public boolean isEmpty() {
    //return this.root == null ;
    return this.count == 0 ;
}

使用根节点或者长度判断其本质是一样的。

interface ILink<E> {         //设置泛型避免安全隐患
       public void add(E e) ;   //增加数据
       public int size() ;    //获取数据的个数
       public boolean isEmpty() ;   //判断是否空集合
}
class LinkImpl<E> implements ILink<E> {
      private class Node {         //保存节点的数据关系
              private E data ;      //保存数据
              private Node next ;       //保存下一个引用
              public Node(E data) {          //有数据的情况下才有意义
                     this.data = data ;
              }
                //第一次调用:this = LinkImpl.root ;
                //第二次调用:this = LinkImpl.root.next ;
                 //第三次调用:this = LinkImpl.root.next.next ;
              public void addNode(Node newNode){      //保存新的Node数据
                      if (this.next == null) {   //当前节点的下一个节点为null
                           this.next = newNode;      //保存当前节点
                      }else {
                           this.next.addNode(newNode);
                      }
               }
      }
      //------------以下为Link类中定义的成员-----------------
      private Node root ;       //保存根元素
      private int count ;     //保存数据的个数
      //------------以下为Link类中定义的方法-----------------
      public void add(E e){
         if(e == null){
             return ;
         }
        //数据本身是不具有关联特性的,只有Node类有,要想关联处理就必须将数据包装在Node类中
         Node newNode = new Node(e);    //创建一个新的节点
         if (this.root == null){            //现在没有根节点
            this.root = newNode;       //第一个节点作为根节点
         }else{                          //根节点存在
           this.root.addNode(newNode);       //将新节点保存在合适的位置
         }   
         this.count++ ;  
     }
     public int size() {
            return this.count ;
     }
      public boolean isEmpty() {
             //return this.root == null ;
             return this.count == 0 ;
      }
}
public class LinkDemo{
       public static void main(String args[])  {
              ILink<String> all = new LinkImpl<String>() ;
              System.out.println("【增加之前】数据个数:" + all.size() + "、是否为空集合:" + all.isEmpty()) ;
              all.add("Hello") ;
              all.add("World") ;  
              all.add("MLDN") ;   
              System.out.println("【增加之后】数据个数:" + all.size() + "、是否为空集合:" + all.isEmpty()) ;
       }
}

image.png
图一 执行结果图

返回集合数据:public Object[] toArray()

链表本身就属于一个动态对象数组,那么既然是一个对象数组,就应该可以把所有的数据以数组的形式返回来,那么这个时候就可以定义一个toArray()方法,但是这个时候的方法只能够返回Object型的数组。

image.png
图二 数据返回

1、在ILink接口里面追加新的处理方法:

public Object[] toArray() ;     //将集合元素以数组的形式返回

2、在LinkImpl子类里面追加有两个属性:

private int foot ;     //描述的是操作数组的脚标
private Object [] returnData ;   //返回的数据保存

3、在Node类中根据递归获取数据

//第一次调用:this = LinkImpl.root
//第二次调用:this = LinkImpl.root.next
//第三次调用:this = LinkImpl.root.next.next
public void toArrayNode() {
    LinkImpl.this.returnData [LinkImpl.this.foot ++] = this.data ;
    if (this.next != null) {     //还有下一个数据
        this.next.toArrayNode() ;
    }
}

4、在进行数据返回的时候一定要首先判断数据返回是否为空

public Object[] toArray() {
    if (this.isEmpty()) {           //空集合
       return null ;      //现在没有数据
    }
    this.foot = 0 ;  //脚标清零
    this.returnData = new Object[this.count] ;   //根据已有的长度开辟数组
    this.root.toArrayNode() ; //利用Node类进行递归数据获取
    return this.returnData ;
}

image.png
图三 执行结果图

集合的数据一般如果要返回肯定要以对象数组的形式返回。

想学习更多的Java的课程吗?从小白到大神,从入门到精通,更多精彩不容错过!免费为您提供更多的学习资源。
本内容视频来源于阿里云大学

下一篇:速度了解神奇的索引操作 | 带你学《Java面向对象编程》之九十三
更多Java面向对象编程文章查看此处

相关文章
|
1月前
|
Java
Java语言实现字母大小写转换的方法
Java提供了多种灵活的方法来处理字符串中的字母大小写转换。根据具体需求,可以选择适合的方法来实现。在大多数情况下,使用 String类或 Character类的方法已经足够。但是,在需要更复杂的逻辑或处理非常规字符集时,可以通过字符流或手动遍历字符串来实现更精细的控制。
223 18
|
1月前
|
Java 编译器 Go
【Java】(5)方法的概念、方法的调用、方法重载、构造方法的创建
Java方法是语句的集合,它们在一起执行一个功能。方法是解决一类问题的步骤的有序组合方法包含于类或对象中方法在程序中被创建,在其他地方被引用方法的优点使程序变得更简短而清晰。有利于程序维护。可以提高程序开发的效率。提高了代码的重用性。方法的名字的第一个单词应以小写字母作为开头,后面的单词则用大写字母开头写,不使用连接符。例如:addPerson。这种就属于驼峰写法下划线可能出现在 JUnit 测试方法名称中用以分隔名称的逻辑组件。
196 4
|
2月前
|
算法 安全 Java
除了类,Java中的接口和方法也可以使用泛型吗?
除了类,Java中的接口和方法也可以使用泛型吗?
134 11
|
1月前
|
编解码 Java 开发者
Java String类的关键方法总结
以上总结了Java `String` 类最常见和重要功能性方法。每种操作都对应着日常编程任务,并且理解每种操作如何影响及处理 `Strings` 对于任何使用 Java 的开发者来说都至关重要。
265 5
|
2月前
|
Java 开发者
Java 函数式编程全解析:静态方法引用、实例方法引用、特定类型方法引用与构造器引用实战教程
本文介绍Java 8函数式编程中的四种方法引用:静态、实例、特定类型及构造器引用,通过简洁示例演示其用法,帮助开发者提升代码可读性与简洁性。
|
3月前
|
算法 Java 开发者
Java 项目实战数字华容道与石头迷阵游戏开发详解及实战方法
本文介绍了使用Java实现数字华容道和石头迷阵游戏的技术方案与应用实例,涵盖GUI界面设计、二维数组操作、游戏逻辑控制及自动解法算法(如A*),适合Java开发者学习游戏开发技巧。
277 46
|
3月前
|
算法 Java
Java语言实现链表反转的方法
这种反转方法不需要使用额外的存储空间,因此空间复杂度为,它只需要遍历一次链表,所以时间复杂度为,其中为链表的长度。这使得这种反转链表的方法既高效又实用。
370 0
|
3月前
|
存储 Java 数据处理
Java映射操作:深入Map.getOrDefault与MapUtils方法
结合 `getOrDefault`方法的简洁性及 `MapUtils`的丰富功能,Java的映射操作变得既灵活又高效。合理地使用这些工具能够显著提高数据处理的速度和质量。开发人员可以根据具体的应用场景选择适宜的方法,以求在性能和可读性之间找到最佳平衡。
176 0
|
3月前
|
缓存 人工智能 NoSQL
Java中实现Token设置过期时间的方法
本文介绍了在Java应用中实现Token设置过期时间的多种方法,包括使用JWT和Redis缓存,并结合定时任务清理过期Token,以提升系统安全性与用户隐私保护。
437 0
|
4月前
|
安全 Java API
Java 集合高级应用与实战技巧之高效运用方法及实战案例解析
本课程深入讲解Java集合的高级应用与实战技巧,涵盖Stream API、并行处理、Optional类、现代化Map操作、不可变集合、异步处理及高级排序等核心内容,结合丰富示例,助你掌握Java集合的高效运用,提升代码质量与开发效率。
253 0