JAVA之旅(十八)——基本数据类型的对象包装类,集合框架,数据结构,Collection,ArrayList,迭代器Iterator,List的使用

简介: JAVA之旅(十八)——基本数据类型的对象包装类,集合框架,数据结构,Collection,ArrayList,迭代器Iterator,List的使用 JAVA把完事万物都定义为对象,而我们想使用数据类型也是可以引用的一.

JAVA之旅(十八)——基本数据类型的对象包装类,集合框架,数据结构,Collection,ArrayList,迭代器Iterator,List的使用


JAVA把完事万物都定义为对象,而我们想使用数据类型也是可以引用的

一.基本数据类型的对象包装类

左为基本数据类型,又为引用数据类型

  • byte Byte
  • int Integer
  • long Long
  • boolean Booleab
  • float Float
  • double Double
  • char Character

我们拿Integer来举例子

//整数类型的最大值/最小值
sop("最大值:"+Integer.MAX_VALUE);
sop("最小值:"+Integer.MIN_VALUE);

输出

这里写图片描述

基本数据类型对象包装类的最常见作用

  • 就是用于基本数据类型和字符串数据类型之间的转换

    • 基本数据类型转成字符串

      基本数据类型+“”
      Integer.toString(34)

    • 字符串转成基本数据类型

      // 将一个字符串转为整数
      int num = Integer.parseInt("123");
      sop("值:" + (num + 5));

      输出的结果

      这里写图片描述

像其他的使用方法都是类似的,但是有特殊的,那就是boolean,一个是true一个是“true”,再比如你传的是abc转int类型,这就奇葩了,他会报数据格式异常的

当然,还有各种进制的转换,说白了就是几个方法,大家可以研究一下,这里就不多做赘述了

我们实际来一个小例子来突出他们的特性

package com.lgl.hellojava;

//公共的   类   类名
public class HelloJJAVA {

    public static void main(String[] args) {

        /**
         * 基本数据类型的对象包装类
         */
        Integer x = new Integer("123");
        Integer y = new Integer(123);
        // 问
        sop("x == y :" + (x == y));
        sop("x.equals(y) : " + (x.equals(y)));

    }

    /**
     * 输出
     */
    public static void sop(Object obj) {
        System.out.println(obj);
    }

}

这样得到的结果呢?

这里写图片描述

这里就好理解了

JDK1.5版本以后出现的新特性

  • 自动装箱
Integer x = new Integer(4);
Integer x = 4;  //自动装箱

x = x + 2; //进行了自动拆箱,变成了int类型,和2进行加法运算,再将和进行装箱,赋给x

再来一个有意思的例子


        Integer x = 128;
        Integer y = 128;

        Integer i = 127;
        Integer j = 127;

        sop("x == y :" + (x == y));
        sop("i == j : " + (i == j));

这里输出多少?

这里写图片描述

为什么会这样?

  • 因为i和j是同一个Integer对象,在byte范围内,对于新特性,如果该数值已经存在,则不会再开辟新的空间

二.集合框架

讲完杂七杂八的数据类型,我们接着讲数据类型存储,首先我们聊聊集合

  • 为什么出现集合类

    • 面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象的操作,就对对象进行了存储,集合就是存储对象最常用的一种方式
  • 数组和集合类同时容器有何不同?

    • 数组虽然也可以存储对象,但是长度是固定的,集合长度是可变的,数组中可以存储数据类型,集合只能存储对象
  • 集合的特点

    • 集合只用于存储对象,集合长度是可变的,集合可以存储不同类型的对象

集合框架是不断的向上抽取的

这里写图片描述

为什么会出现这么多的容器呢?

  • 因为每一个容器对数据的存储方式都有不同,这个存储方式我们称之为:数据结构

我们会依次的学习这个数据结构

三.Collection

这里写图片描述

根接口,我们来学习他们的共性方法

package com.lgl.hellojava;

import java.util.ArrayList;

//公共的   类   类名
public class HelloJJAVA {

    public static void main(String[] args) {
        /**
         * Collection
         */
        // 创建一个集合容器,使用Collection接口的子类Arraylist
        ArrayList list = new ArrayList();
        // 添加元素
        list.add("Hello 0"); 
        list.add("Hello 1");
        list.add("Hello 2");
        list.add("Hello 3");
        list.add("Hello 4");

        // 获取集合的长度
        sop("长度:" + list.size());
    }

    /**
     * 输出
     */
    public static void sop(Object obj) {
        System.out.println(obj);
    }

}

写法是这样写的,这里有疑问,为什么add参数是Object?

  • 1.add方法的参数类型是Object,已便于接收任意类型的对象
  • 2.集合中存储的都是对象的引用和地址,

所以我们还可以

        // 获取集合的长度
        sop("长度:" + list.size());

        //打印集合
        sop(list);

        //删除元素
        list.remove("Hello 1");
        sop(list);

        //判断
        sop("Hello 3是否存在:"+list.contains("Hello 3"));

        //清空
        list.clear();

        //是否为空
        sop(list.isEmpty());

        sop(list);

得出结论

这里写图片描述

我们再来讲一个交集

public static void method_2() {
        ArrayList list = new ArrayList();
        // 添加元素
        list.add("Hello 0");
        list.add("Hello 1");
        list.add("Hello 2");
        list.add("Hello 3");
        list.add("Hello 4");

        ArrayList list1 = new ArrayList();
        // 添加元素
        list1.add("java 0");
        list1.add("Hello 1");
        list1.add("java 2");
        list1.add("Hello 3");
        list1.add("java 4");

        // 取交集 list只会保留和list1中相同的元素
        list.retainAll(list1);
        sop(list);
    }

list只会保留和list1中相同的元素

这里写图片描述

四.迭代器Iterator

我们再来说下迭代器,也就是怎么取出数据操作

/**
     * 迭代器
     */
    public static void method_get() {
        ArrayList list = new ArrayList();
        // 添加元素
        list.add("Hello 0");
        list.add("Hello 1");
        list.add("Hello 2");
        list.add("Hello 3");
        list.add("Hello 4");
        //获取迭代器,用于取出集合中的元素
        Iterator iterator = list.iterator();
        while (iterator.hasNext()) {
            sop(iterator.next());
        }
    }

这样就能全部打印出来了

这里写图片描述

那我们理解什么是迭代器?


  • 其实就是集合取出元素的方式

就把取出方式定义在集合的内部,这样取出的方式就直接访问集合内容的集合,那么取出方式就会定义成内部类,而每个容器的数据结构都不同,所以取出的动作细节也不同,但是都有共性内容,判断,取出,那么可以将写共性抽取,那么这些内部类都符合一个规则,该规则就是iterator,如何获取集合的取出对象呢?通过一个对外提供的方法interator();
大体的方向我们掌握了,这样我们就应该细分下去讲了,我们先说下List

六.List

Collection下有两个子接口,list和set,他们两个的区别就是

  • list:元素是有序的,元素可以重复,因为该集合体系有索引
  • set:元素是无序,元素不可以重复,不能索引

我们只要说的就是list,共性的就不讲了,我们、他独有的

List特有方法:凡是可以操纵交表的方法都是该体系的特有方法,也就是


    • add(index,element)
    • addAll(index Collection);

    • remove(index)

    • set(index)

    • get(index)
    • subList(from,to)
    • listIterator()

我们挨个说一遍就好了,这个本来就是老套路了,我们就算总结一下前面的知识

package com.lgl.hellojava;

import java.util.ArrayList;
import java.util.Iterator;

//公共的   类   类名
public class HelloJJAVA {

    public static void main(String[] args) {
        /**
         * List
         */
        ArrayList al = new ArrayList();
        // 添加元素
        al.add("java 0");
        al.add("java 1");
        al.add("java 2");

        sop("原集合 : " + al);

        // 在指定位置添加元素
        al.add(1, "java 3");
        sop("添加后 : " + al);

        // 删除指定位置的元素
        al.remove(2);
        sop("删除后: " + al);

        // 修改元素
        al.set(2, "java 4");
        sop("修改后: " + al);

        // 通过角标获取元素
        sop("查找 : " + al.get(1));

        sop("所有元素");
        // 获取所有元素
        for (int i = 0; i < al.size(); i++) {
            sop("元素" + i + " = " + al.get(i));
        }

        sop("迭代器");
        // 通过迭代器
        Iterator it = al.iterator();
        while (it.hasNext()) {
            sop("next:" + it.next());
        }

    }

    /**
     * 输出
     */
    public static void sop(Object obj) {
        System.out.println(obj);
    }

}

这里就涵盖了很多的list的知识点,不断向上抽取的一个过程了,我们输出的结果

这里写图片描述

好的,那这样的话,我们本节课也就到这里,OK了,感谢你看了这么久,累了就喝杯水吧!

我的群:555974449,欢迎你的到来!

目录
相关文章
|
5月前
|
存储 Java 索引
(Python基础)新时代语言!一起学习Python吧!(二):字符编码由来;Python字符串、字符串格式化;list集合和tuple元组区别
字符编码 我们要清楚,计算机最开始的表达都是由二进制而来 我们要想通过二进制来表示我们熟知的字符看看以下的变化 例如: 1 的二进制编码为 0000 0001 我们通过A这个字符,让其在计算机内部存储(现如今,A 字符在地址通常表示为65) 现在拿A举例: 在计算机内部 A字符,它本身表示为 65这个数,在计算机底层会转为二进制码 也意味着A字符在底层表示为 1000001 通过这样的字符表示进行转换,逐步发展为拥有127个字符的编码存储到计算机中,这个编码表也被称为ASCII编码。 但随时代变迁,ASCII编码逐渐暴露短板,全球有上百种语言,光是ASCII编码并不能够满足需求
250 4
|
8月前
|
并行计算 Java API
Java List 集合结合 Java 17 新特性与现代开发实践的深度解析及实战指南 Java List 集合
本文深入解析Java 17中List集合的现代用法,结合函数式编程、Stream API、密封类、模式匹配等新特性,通过实操案例讲解数据处理、并行计算、响应式编程等场景下的高级应用,帮助开发者提升集合操作效率与代码质量。
369 1
|
8月前
|
存储 安全 Java
Java 学习路线 35 掌握 List 集合从入门到精通的 List 集合核心知识
本文详细解析Java中List集合的原理、常用实现类(如ArrayList、LinkedList)、核心方法及遍历方式,并结合数据去重、排序等实际应用场景,帮助开发者掌握List在不同业务场景下的高效使用,提升Java编程能力。
538 0
|
NoSQL Java Redis
List集合按照由小到大排序或者由大到小排序
List集合按照由小到大排序或者由大到小排序
319 0
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
1168 10
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
371 59
|
9月前
|
编译器 C语言 C++
栈区的非法访问导致的死循环(x64)
这段内容主要分析了一段C语言代码在VS2022中形成死循环的原因,涉及栈区内存布局和数组越界问题。代码中`arr[15]`越界访问,修改了变量`i`的值,导致`for`循环条件始终为真,形成死循环。原因是VS2022栈区从低地址到高地址分配内存,`arr`数组与`i`相邻,`arr[15]`恰好覆盖`i`的地址。而在VS2019中,栈区先分配高地址再分配低地址,因此相同代码表现不同。这说明编译器对栈区内存分配顺序的实现差异会导致程序行为不一致,需避免数组越界以确保代码健壮性。
198 0
栈区的非法访问导致的死循环(x64)
|
存储 C语言 C++
【C++数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现顺序栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 1.初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储
757 77
232.用栈实现队列,225. 用队列实现栈
在232题中,通过两个栈(`stIn`和`stOut`)模拟队列的先入先出(FIFO)行为。`push`操作将元素压入`stIn`,`pop`和`peek`操作则通过将`stIn`的元素转移到`stOut`来实现队列的顺序访问。 225题则是利用单个队列(`que`)模拟栈的后入先出(LIFO)特性。通过多次调整队列头部元素的位置,确保弹出顺序符合栈的要求。`top`操作直接返回队列尾部元素,`empty`判断队列是否为空。 两题均仅使用基础数据结构操作,展示了栈与队列之间的转换逻辑。
|
算法 调度 C++
STL——栈和队列和优先队列
通过以上对栈、队列和优先队列的详细解释和示例,希望能帮助读者更好地理解和应用这些重要的数据结构。
313 11