【Java数据结构 -- 包装类和泛型】

包装类和泛型

  • 1. 包装类
    • 1.1 基本数据类型和对应的包装类
    • 1.2 装箱和拆箱
    • 1.3 自动装箱和自动拆箱
    • 1.4 自动装箱实际上是调用了valueOf()
    • 1.5 Integer包装类赋值注意点
  • 2 什么是泛型
  • 3 引出泛型
  • 4 泛型的使用
    • 4.1 语法
    • 4.2 类型推导
  • 5 裸类型
  • 6 泛型如何编译
    • 6.1 擦除机制
  • 7 泛型的上界
    • 写一个泛型类, 求一个数组当中的最大值
    • 另一个类作为参数实例化时要引用它对应的接口和重写对应的方法
  • 8 泛型方法
    • 设为静态方法static

1. 包装类

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

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

基本数据类型 --> 包装类
byte --> Byte
short --> Short
int --> Integer
long --> Long
float --> Float
double --> Double
char --> Character
boolean --> Boolean
除了 Integer 和 Character, 其余基本类型的包装类都是首字母大写。

1.2 装箱和拆箱

装箱/装包:把一个基本类型转变为包装类型
拆箱/拆包:把一个包装类型转变为基本类型

1.3 自动装箱和自动拆箱

    public static void main(String[] args) {int a = 10;Integer ii = a; //自动装箱Integer ii2 = new Integer(10);int b = ii2; //自动拆箱System.out.println(ii);  // 10System.out.println(b);   // 10}

1.4 自动装箱实际上是调用了valueOf()

    public static void main2(String[] args) {int a = 10;//Integer ii = a; //自动装箱Integer ii = Integer.valueOf(a);  // 手动装箱Integer ii2 = new Integer(10);//int b = ii2; //自动拆箱int b = ii2.intValue(); // 手动拆箱double d = ii2.intValue();System.out.println(ii);  // 10System.out.println(b);   // 10System.out.println(d);   // 10.0}

1.5 Integer包装类赋值注意点

    public static void main(String[] args) {//  i >= IntegerCache.low && i <= IntegerCache.high// 在 Integer  valueOf方法中  的int i取值范围是  -128~127// 在这个返回返回的是  -128 到 127 中 255 个地址 存放100// IntegerCache.cache[i + (-IntegerCache.low)] 即返回的地址为同一个地址// 而200不属于这个取值范围里面 返回的是 一个新的 值 new Integer(i)/*Integer ii = 100;Integer ii2 = 100;  //true */Integer ii = 200;Integer ii2 = 200;  //falseSystem.out.println(ii == ii2);}

2 什么是泛型

一般的类和方法,只能使用具体的类型: 要么是基本类型,要么是自定义的类。如果要编写可以应用于多种类型的代码,这种刻板的限制对代码的束缚就会很大。
泛型是在JDK1.5引入的新的语法,通俗讲,泛型:就是适用于许多许多类型。从代码上讲,就是对类型实现了参数化

3 引出泛型

实现一个类,类中包含一个数组成员,使得数组中可以存放任何类型的数据,也可以根据成员方法返回数组中某个下标的值?

class MyArray <T>{// <T> 占位符 是一个泛型类//  泛型的意义:1. 在编译的时候 检查数据类型是否正确 2.在编译的时候   帮助进行类型转化//public Object[] array = new Object[10];// 不能实例化一个泛型类型的数组// public T[] array = new T[10];//public T[] array = (T[])new Object[10];public Object[] array = new Object[10];public void setValue(int pos,T val) {array[pos] = val;}// 在java中不能将整个数组进行强转public T getValue(int pos) {return (T) array[pos];}}
class Person {}
public class Test {public static void main(String[] args) {MyArray<Integer> myArray = new MyArray<>();//MyArray<int> myArray = new MyArray<>(); //<>里面不能是基本数据类型myArray.setValue(1,90); // 直接放int 会发生自动装箱//裸类型  不加包装类型MyArray myArray1 = new MyArray<>();myArray1.setValue(0,1);}//目的:想存放指定的元素public static void main4(String[] args) {MyArray<String> myArray = new MyArray<>();myArray.setValue(0,"hello");MyArray<Integer> myArray2 = new MyArray<Integer>();//类型后加入<Integer> 指定当前类型myArray2.setValue(0,99);myArray2.setValue(1,20);MyArray<Person> myArray3 = new MyArray<>();}
}
  1. 类名后的 代表占位符,表示当前类是一个泛型类
    了解: 【规范】类型形参一般使用一个大写字母表示,常用的名称有:
  • E 表示 Element
  • K 表示 Key
  • V 表示 Value
  • N 表示 Number
  • T 表示 Type
  • S, U, V 等等 - 第二、第三、第四个类型
  1. 不能new泛型类型的数组
  2. 类型后加入 指定当前类型
  3. 不需要进行强制类型转换

4 泛型的使用

4.1 语法

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

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

4.2 类型推导

MyArray<Integer> list = new MyArray<>(); // 可以推导出实例化需要的类型实参为 Integer

5 裸类型

        //裸类型  不加包装类型MyArray myArray1 = new MyArray<>();myArray1.setValue(0,1);

总结

  1. 泛型是将数据类型参数化,进行传递
  2. 使用表示当前类是一个泛型类
  3. 泛型的优点:数据类型参数化,编译时自动进行类型检查和转换

6 泛型如何编译

6.1 擦除机制

在终端通过命令:javap -c 查看字节码文件,所有的T都是Object。
在这里插入图片描述

在编译的过程,将所有的T替换为Object这种机制,称为:擦除机制
即可以直接写成:

class MyArray <T>{//public T[] array = (T[])new Object[10];public Object[] array = new Object[10];public void setValue(int pos,T val) {array[pos] = val;}public T getValue(int pos) {return (T) array[pos]; //加(T) 转一下}public T[] getArray() {return (T[]) array;}}

7 泛型的上界

class MyArray <T extends Number>{  // T 一定是Number或者是Number的子类如Integerpublic Object[] array = new Object[10];public void setValue(int pos,T val) {array[pos] = val;}public T getValue(int pos) {return (T) array[pos];}
}public static void main(String[] args) {MyArray<String> myArray = new MyArray<>();  // 报错 String不是Number的子类// String[] ret = (String[])myArray.getArray();  //会报错 在java中不能将整个数组进行强转// 数组是一种单独的数据类型Object[] ret = myArray.getArray();}

写一个泛型类, 求一个数组当中的最大值

//写一个泛型类, 求一个数组当中的最大值
class Alg<T extends Comparable<T>> {  // 泛型的上界public T findMaxVal(T[] array) {T max = array[0];for (int i = 0; i < array.length; i++) {//if (array[i] > max) {  // 引用类型不能直接通过 大于等于号进行比较//这个时候就需要 写一个Comparable<T> 上界if (array[i].compareTo(max)>0){max = array[i];}}return max;}
}
public class Test {public static void main(String[] args) {Integer[] array = {1,2,8,5,3};Alg<Integer> alg = new Alg<>();System.out.println(alg.findMaxVal(array)); }
}

另一个类作为参数实例化时要引用它对应的接口和重写对应的方法

class Person implements Comparable<Person> {@Overridepublic int compareTo(Person o) {return 0;}
}//写一个泛型类, 求一个数组当中的最大值
class Alg<T extends Comparable<T>> {  // 泛型的上界public T findMaxVal(T[] array) {T max = array[0];for (int i = 0; i < array.length; i++) {//if (array[i] > max) {  // 引用类型不能直接通过 大于等于号进行比较//这个时候就需要 写一个Comparable<T> 上界if (array[i].compareTo(max)>0){max = array[i];}}return max;}
}
public class Test {public static void main(String[] args) {Integer[] array = {1,2,8,5,3};Alg<Integer> alg = new Alg<>();System.out.println(alg.findMaxVal(array));//如果定义一个类 作为Alg实例的话 这个类必须实现Comparable接口并且重写compareTo方法Alg<Person> alg1 = new Alg<Person>();}
}

8 泛型方法

在定义方法的时候加

class Alg2 {public<T extends Comparable> T findMaxVal(T[] array) {T max = array[0];for (int i = 0; i < array.length; i++) {if (array[i].compareTo(max)>0){max = array[i];}}return max;}
}public class Test {public static void main(String[] args) {Alg2 alg2 = new Alg2();Integer[] array = {1,2,8,5,3};alg2.<Integer>findMaxVal(array);  //可以不加<Integer>会通过实参的值自动推导alg2.findMaxVal(array);}
}

设为静态方法static

class Alg3 {public static <T extends Comparable> T findMaxVal(T[] array) {T max = array[0];for (int i = 0; i < array.length; i++) {if (array[i].compareTo(max)>0){max = array[i];}}return max;}
}public class Test {public static void main(String[] args) {Integer[] array = {1,2,8,5,3};Alg3.<Integer>findMaxVal(array);  //直接通过类名调用方法}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/223286.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java远程连接本地开源分布式搜索引擎ElasticSearch

文章目录 前言1. Windows 安装 Cpolar2. 创建Elasticsearch公网连接地址3. 远程连接Elasticsearch4. 设置固定二级子域名 前言 简单几步,结合Cpolar内网穿透工具实现Java远程连接操作本地Elasticsearch。 什么是elasticsearch&#xff1f;一个开源的分布式搜索引擎&#xff0…

[C++]六大默认成员函数详解

☃️个人主页&#xff1a;fighting小泽 &#x1f338;作者简介&#xff1a;目前正在学习C和Linux &#x1f33c;博客专栏&#xff1a;C入门 &#x1f3f5;️欢迎关注&#xff1a;评论&#x1f44a;&#x1f3fb;点赞&#x1f44d;&#x1f3fb;留言&#x1f4aa;&#x1f3fb; …

Python实现艺术设计?提取图片中颜色并绘制成可视化图表,从大师作品中提取配色方案

文章目录 导入模块并加载图片提取颜色并整合成表格绘制图表实战环节关于Python技术储备一、Python所有方向的学习路线二、Python基础学习视频三、精品Python学习书籍四、Python工具包项目源码合集①Python工具包②Python实战案例③Python小游戏源码五、面试资料六、Python兼职渠…

1.ORB-SLAM3中如何保存多地图、关键帧、地图点到二进制文件中

1 保存多地图 1.1 为什么保存(视觉)地图 因为我们要去做导航&#xff0c;导航需要先验地图。因此需要保存地图供导航使用&#xff0c;下面来为大家讲解如何保存多地图。 1.2 保存多地图的主函数SaveAtlas /*** brief 保存地图* param type 保存类型*/ void System::SaveAtlas(…

Java - Stream Filter 多条件筛选过滤

Java Stream流中Filter用于通过设置的条件过滤出元素 &#xff0c;示例如下&#xff1a; List strings Arrays.asList(“abc”, “”, “bc”, “efg”, “abcd”,"", “jkl”);List filtered strings.stream().filter(string -> !string.isEmpty()).collect(C…

生物神经系统的基本原理 神经元Neuron

生物神经系统的基本原理涉及一系列复杂的生物学和生理学机制&#xff0c;主要可以分为以下几个方面&#xff1a; 神经元与突触&#xff1a;神经系统的基本单位是神经元&#xff0c;它们通过突触连接彼此。神经元接收并处理来自身体其他部分或环境的信息&#xff0c;然后通过电信…

用函数初始化数组

将数组全部初始化为相同值 对于一般情况 一般是用函数&#xff0c;传什么数就初始化为什么数 #define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> void init(int arr[], int len, int num) {int i;for (i 0; i < len; i){arr[i] num;} } int main() {int arr[…

快速开发出一个公司网站

问题描述&#xff1a;参加一个创业活动&#xff0c;小组要求做一个公司网站&#xff0c;简单介绍一下自己公司的业务。需要快速完成。 问题解决&#xff1a;从网上找一个网站模板&#xff0c;类似于做PPT&#xff0c;搭建一个网站即可。 这里推荐的是京美建站、wordpress、he…

第1章 爬虫基础

目录 1. HTTP 基本原理1.1 URI 和 URL1.2 HTTP 和 HTTPS1.3 请求1.3.1 请求方法1.3.2 请求的网址1.3.3 请求头1.3.4 请求体 1.4 响应1.4.1 响应状态码1.4.2 响应头1.4.3 响应体 2. Web 网页基础2.1 网页的组成2.1.1 HTML2.1.2 CSS2.1.3 JavaScript 2.2 网页的结构2.3 节点树及节…

PT里如何针对某个模块设置false path

我正在「拾陆楼」和朋友们讨论有趣的话题&#xff0c;你⼀起来吧&#xff1f; 拾陆楼知识星球入口 如题&#xff0c;这个问题实际上讲的是get_cells的用法&#xff0c;我们要抓取某个模块内的全部cell&#xff0c;在ICC2里可以get_flat_cells xx/xx/module_name*&#xff0c;但…

DBeaver连接MySQL提示“Public Key Retrieval is not allowed“问题解决方式

更新时间&#xff1a;2023年10月31日 11:37:53 作者&#xff1a;产品人小柒 dbeaver数据库连接工具,可以支持几乎所有的主流数据库.mysql,oracle.sqlserver,db2 等等,这篇文章主要给大家介绍了关于DBeaver连接MySQL提示"Public Key Retrieval is not allowed"问…

计算机毕业设计|基于SpringBoot+MyBatis框架的仿天猫商城购物系统设计与实现

计算机毕业设计|基于SpringBootMyBatis框架的仿天猫商城购物系统设计与实现 迷你仿天猫商城是一个基于SSM框架的综合性B2C电商平台&#xff0c;需求设计主要参考天猫商城的购物流程&#xff1a;用户从注册开始&#xff0c;到完成登录&#xff0c;浏览商品&#xff0c;加入购物…