数据结构--包装类&简单认识泛型

目录

[1 包装类](#1 包装类)

[1.1 基本数据类型和对应的包装类](#1.1 基本数据类型和对应的包装类)

[1.2 装箱和拆箱,自动装箱和自动拆箱](#1.2 装箱和拆箱,自动装箱和自动拆箱)

[2 什么是泛型](#2 什么是泛型)

[3 引出泛型](#3 引出泛型)

[3.1 语法](#3.1 语法)

[4 泛型类的使用](#4 泛型类的使用)

[4.1 语法](#4.1 语法)

[4.2 示例](#4.2 示例)

[5 泛型的上界](#5 泛型的上界)

[5.1 语法](#5.1 语法)

[5.2 示例](#5.2 示例)

[5.3 复杂示例](#5.3 复杂示例)

[8 泛型方法](#8 泛型方法)

[8.1 定义语法](#8.1 定义语法)

[8.2 示例](#8.2 示例)

总结


1****包装类

在 Java 中,由于基本类型不是继承自 Object ,为了在泛型代码中可以支持基本类型, Java 给每个基本类型都对应了 一个包装类型。

1.1****基本数据类型和对应的包装类


除了 Integer 和 Character , 其余基本类型的包装类都是首字母大写。

1.2 装箱和拆箱,自动装箱和自动拆箱

    public static void main1(String[] args) {

        //装箱
        int b=10;
        Integer a = new Integer(b);
        System.out.println(a);
        //自动装箱
        Integer c = new Integer(20);
        System.out.println(c);

        //拆箱
        Integer j = new Integer(30);
        int k= j.intValue();
        System.out.println(k);

        //自动拆箱
        Integer h = new Integer(40);
        //double等类型
        int o = (int) h;
        System.out.println(o);

    }

2****什么是泛型

就是适用于许多许多类型 。从代码上讲,就是对类型实现了参数化

3****引出泛型

所有类的父类,默认为 Object 类。数组是否可以创建为 Object

//T是一个类型参数(泛型类型参数)
//例如,如果创建MyArray<String>的实例,那么在这个实例中,T就代表String类型。
class MyArray<T>{
    //Object表示这个数组可以用来存储任何类型的对象(因为所有的类都继承自Object类)。
    public Object[] array = new Object[10];

    //在set方法中,它接受一个T类型的参数val,这意味着根据创建MyArray实例时指定的T的类型,val必须是该类型。
    public void set(int pos,T val){
        array[pos]=val;
    }

    //在get方法中,它返回T类型的值
    public T get(int pos){
        return (T) array[pos];
    }

}

public class Test1 {
    public static void main(String[] args) {
        //定义了只能传入String类型
        MyArray<String> myArray = new MyArray<>();
        myArray.set(0,"hello");
        String str = myArray.get(0);
        System.out.println(str);

        //定Integer
        MyArray<Integer> myArray2 = new MyArray<>();
        //在0下标位置下面放数字1
        myArray2.set(0,1);
        Integer a = myArray2.get(0);
        System.out.println(a);


    }

}

所以,泛型的主要目的:就是指定当前的容器,要持有什么类型的对象。让编译
器去做检查

3.1****语法

class 泛型类名称<类型形参列表> {
// 这里可以使用类型参数
}
class ClassName<T1, T2, ..., Tn> {
}



class 泛型类名称<类型形参列表> extends 继承类/* 这里可以使用类型参数 */ {
// 这里可以使用类型参数
}
class ClassName<T1, T2, ..., Tn> extends ParentClass<T1> {
// 可以只使用部分类型参数
}
  1. 类名后的 <T> 代表占位符,表示当前类是一个泛型类
    了解: 【规范】类型形参一般使用一个大写字母表示,常用的名称有:
  2. 不能 new 泛型类型的数组

4****泛型类的使用

4.1****语法

泛型类<类型实参> 变量名; // 定义一个泛型类引用
new 泛型类<类型实参>(构造方法实参); // 实例化一个泛型类对象

4.2****示例

MyArray<Integer> list = new MyArray<Integer>();

注意:泛型只能接受类,所有的基本数据类型必须使用包装类!

5****泛型的上界

在定义泛型类时,有时需要对传入的类型变量做一定的约束,可以通过类型边界来约束。

5.1****语法

class 泛型类名称<类型形参 extends 类型边界> {
...
}

5.2 示例

public class MyArray<E extends Number> {
...
}

5.3****复杂示例

public class MyArray<E extends Comparable<E>> {
...
}

E 必须是实现了 Comparable 接口的

8****泛型方法

8.1****定义语法

方法限定符 <类型形参列表> 返回值类型 方法名称(形参列表) { ... }

8.2****示例

public class Util {
//静态的泛型方法 需要在static后用<>声明泛型类型参数
public static <E> void swap(E[] array, int i, int j) {
E t = array[i];
array[i] = array[j];
array[j] = t;
}
}

总结

包装类为基本数据类型提供了对象的表示形式,如`Integer`对应`int`、`Double`对应`double`等。在数据结构中,像`ArrayList<T>`、`HashMap<K, V>`等泛型类,可以根据实际需求指定不同的类型


希望这篇博客能帮助到读者

相关推荐
盼海1 小时前
排序算法(五)--归并排序
数据结构·算法·排序算法
搬砖的小码农_Sky7 小时前
C语言:数组
c语言·数据结构
先鱼鲨生9 小时前
数据结构——栈、队列
数据结构
一念之坤9 小时前
零基础学Python之数据结构 -- 01篇
数据结构·python
IT 青年9 小时前
数据结构 (1)基本概念和术语
数据结构·算法
熬夜学编程的小王9 小时前
【初阶数据结构篇】双向链表的实现(赋源码)
数据结构·c++·链表·双向链表
liujjjiyun10 小时前
小R的随机播放顺序
数据结构·c++·算法
Reese_Cool11 小时前
【数据结构与算法】排序
java·c语言·开发语言·数据结构·c++·算法·排序算法
djk888812 小时前
.net将List<实体1>的数据转到List<实体2>
数据结构·list·.net
搬砖的小码农_Sky12 小时前
C语言:结构体
c语言·数据结构