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

目录

[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>`等泛型类,可以根据实际需求指定不同的类型


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

相关推荐
小王努力学编程21 分钟前
【算法与数据结构】单调队列
数据结构·c++·学习·算法·leetcode
万兴丶1 小时前
Unity 适用于单机游戏的红点系统(前缀树 | 数据结构 | 设计模式 | 算法 | 含源码)
数据结构·unity·设计模式·c#
程序员东min1 小时前
数据结构:实验题目:单链表归并。将两个非递减次序排列的单链表归并为一个非递增次序排列的单链表,并计算表长。要求利用原来两个单链表的结点存放合并后的单链表。
数据结构
黄雪超2 小时前
深入HBase——核心组件
数据结构·数据库·hbase
夏末秋也凉3 小时前
力扣-贪心-53 最大子数组和
数据结构·算法·leetcode
OrangeJiuce6 小时前
【QT中的一些高级数据结构,持续更新中...】
数据结构·c++·qt
萌の鱼9 小时前
leetcode 2826. 将三个组排序
数据结构·c++·算法·leetcode
Buling_09 小时前
算法-哈希表篇08-四数之和
数据结构·算法·散列表
左灯右行的爱情11 小时前
Redis数据结构总结-listPack
数据结构·数据库·redis
fai厅的秃头姐!11 小时前
C语言03
c语言·数据结构·算法