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

释放双眼,带上耳机,听听看~!

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


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

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

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

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

我们拿Integer来举例子


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

输出

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

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

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

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


1
2
1* 字符串转成基本数据类型
2

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

输出的结果

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

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

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


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
1package com.lgl.hellojava;
2
3//公共的   类   类名
4public class HelloJJAVA {
5
6    public static void main(String[] args) {
7
8        /**
9         * 基本数据类型的对象包装类
10         */
11        Integer x = new Integer("123");
12        Integer y = new Integer(123);
13        // 问
14        sop("x == y :" + (x == y));
15        sop("x.equals(y) : " + (x.equals(y)));
16
17    }
18
19    /**
20     * 输出
21     */
22    public static void sop(Object obj) {
23        System.out.println(obj);
24    }
25
26}
27
28

这样得到的结果呢?

这里就好理解了

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

  • 自动装箱


1
2
3
4
5
1Integer x = new Integer(4);
2Integer x = 4;  //自动装箱
3
4x = x + 2; //进行了自动拆箱,变成了int类型,和2进行加法运算,再将和进行装箱,赋给x
5

再来一个有意思的例子


1
2
3
4
5
6
7
8
9
10
1
2        Integer x = 128;
3        Integer y = 128;
4
5        Integer i = 127;
6        Integer j = 127;
7
8        sop("x == y :" + (x == y));
9        sop("i == j : " + (i == j));
10

这里输出多少?

为什么会这样?

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

二.集合框架

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

  • 为什么出现集合类

  • 面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象的操作,就对对象进行了存储,集合就是存储对象最常用的一种方式

  • 数组和集合类同时容器有何不同?

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

  • 集合的特点

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

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

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

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

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

三.Collection

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


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
1package com.lgl.hellojava;
2
3import java.util.ArrayList;
4
5//公共的   类   类名
6public class HelloJJAVA {
7
8    public static void main(String[] args) {
9        /**
10         * Collection
11         */
12        // 创建一个集合容器,使用Collection接口的子类Arraylist
13        ArrayList list = new ArrayList();
14        // 添加元素
15        list.add("Hello 0");
16        list.add("Hello 1");
17        list.add("Hello 2");
18        list.add("Hello 3");
19        list.add("Hello 4");
20
21        // 获取集合的长度
22        sop("长度:" + list.size());
23    }
24
25    /**
26     * 输出
27     */
28    public static void sop(Object obj) {
29        System.out.println(obj);
30    }
31
32}
33
34

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

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

所以我们还可以


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
1        // 获取集合的长度
2        sop("长度:" + list.size());
3
4        //打印集合
5        sop(list);
6
7        //删除元素
8        list.remove("Hello 1");
9        sop(list);
10
11        //判断
12        sop("Hello 3是否存在:"+list.contains("Hello 3"));
13
14        //清空
15        list.clear();
16
17        //是否为空
18        sop(list.isEmpty());
19
20        sop(list);
21
22

得出结论

我们再来讲一个交集


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
1public static void method_2() {
2        ArrayList list = new ArrayList();
3        // 添加元素
4        list.add("Hello 0");
5        list.add("Hello 1");
6        list.add("Hello 2");
7        list.add("Hello 3");
8        list.add("Hello 4");
9
10        ArrayList list1 = new ArrayList();
11        // 添加元素
12        list1.add("java 0");
13        list1.add("Hello 1");
14        list1.add("java 2");
15        list1.add("Hello 3");
16        list1.add("java 4");
17
18        // 取交集 list只会保留和list1中相同的元素
19        list.retainAll(list1);
20        sop(list);
21    }
22

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

四.迭代器Iterator

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


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
1/**
2     * 迭代器
3     */
4    public static void method_get() {
5        ArrayList list = new ArrayList();
6        // 添加元素
7        list.add("Hello 0");
8        list.add("Hello 1");
9        list.add("Hello 2");
10        list.add("Hello 3");
11        list.add("Hello 4");
12        //获取迭代器,用于取出集合中的元素
13        Iterator iterator = list.iterator();
14        while (iterator.hasNext()) {
15            sop(iterator.next());
16        }
17    }
18

这样就能全部打印出来了

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

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

就把取出方式定义在集合的内部,这样取出的方式就直接访问集合内容的集合,那么取出方式就会定义成内部类,而每个容器的数据结构都不同,所以取出的动作细节也不同,但是都有共性内容,判断,取出,那么可以将写共性抽取,那么这些内部类都符合一个规则,该规则就是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()

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


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
1package com.lgl.hellojava;
2
3import java.util.ArrayList;
4import java.util.Iterator;
5
6//公共的   类   类名
7public class HelloJJAVA {
8
9    public static void main(String[] args) {
10        /**
11         * List
12         */
13        ArrayList al = new ArrayList();
14        // 添加元素
15        al.add("java 0");
16        al.add("java 1");
17        al.add("java 2");
18
19        sop("原集合 : " + al);
20
21        // 在指定位置添加元素
22        al.add(1, "java 3");
23        sop("添加后 : " + al);
24
25        // 删除指定位置的元素
26        al.remove(2);
27        sop("删除后: " + al);
28
29        // 修改元素
30        al.set(2, "java 4");
31        sop("修改后: " + al);
32
33        // 通过角标获取元素
34        sop("查找 : " + al.get(1));
35
36        sop("所有元素");
37        // 获取所有元素
38        for (int i = 0; i < al.size(); i++) {
39            sop("元素" + i + " = " + al.get(i));
40        }
41
42        sop("迭代器");
43        // 通过迭代器
44        Iterator it = al.iterator();
45        while (it.hasNext()) {
46            sop("next:" + it.next());
47        }
48
49    }
50
51    /**
52     * 输出
53     */
54    public static void sop(Object obj) {
55        System.out.println(obj);
56    }
57
58}
59
60

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

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

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

给TA打赏
共{{data.count}}人
人已打赏
安全技术

详解Node.js API系列C/C++ Addons(1) API文档

2021-12-21 16:36:11

安全技术

从零搭建自己的SpringBoot后台框架(二十三)

2022-1-12 12:36:11

个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索