泛型

泛型:参数化的类型,即把数据类型当做参数来传递

有的地方又称为泛化的类型,用一个单个大写字母,例如<T>来代表任意类型,这个T就是泛化的类型。

泛型的好处:

(1)表示某个变量的类型更灵活

(2)安全:有了泛型,在编译期间就可以避免不符合类型的数据赋值

(3)避免数据类型转换

泛型类或泛型接口

【修饰符】 class 类名<类型变量列表/泛型类型形参列表>{

}
【修饰符】 interface 接口名<类型变量列表/泛型类型形参列表>{

}

使用

(1)创建对象时

在创建类的对象时指定类型变量对应的实际类型参数,指定泛型实参时,必须左右两边一致,不存在多态现象

(2)继承、实现接口

在继承泛型类或实现泛型接口时,指定类型变量对应的实际类型参数

注意

(1)<类型变量列表/泛型类型形参列表>:使用单个的大写字母表示,例如:<T>,<E>,<R>...

(2)<类型变量列表/泛型类型形参列表>:可以多个,每个之间使用,分割,例如:<K,V>

(3)如果要指定<类型变量列表/泛型类型形参列表>的实际类型,必须是引用数据类型,不能是基本数据类型

(4)类和接口上的类型形参不能用于静态方法中

(5)<类型变量列表/泛型类型形参列表>可能有上限,< T extends 上限1 >

类型变量的上限

当在声明类型变量时,如果不希望这个类型变量代表任意引用数据类型,而是某个系列的引用数据类型,那么可以设定类型变量的上限。

< T extends 上限1 & 上限2 ...>

上限中类只能有一个,如果有必须在最左边,接口的话可以多个。多个上限之间是&(与)的关系。

如果在声明<类型变量>时没有指定任何上限,默认上限是java.lang.Object。

泛型擦除

当使用参数化类型的类或接口时,如果没有指定泛型,会发生泛型擦除,泛型的类型就会自动按照最左边的第一个上限处理。如果没有指定上限,上限即为Object。

泛型方法

如果我们定义类、接口时没有使用<类型变量>,但是某个方法定义时或静态方法定义时,想要自己定义<类型变量>就可定义泛型方法

语法:

【修饰符】 <类型变量列表/泛型类型形参列表> 返回值类型  方法名(【数据形参列表】)【throws 异常列表】

使用:

方法被调用时,根据方法的实参的类型自动推断。

注意:

泛型方法的定语与泛型类的定义注意点相同,并且泛型方法可定义静态方法

每一个泛型方法的<类型变量列表/泛型类型形参列表>是独立的,和别的方法无关,和类上面的泛型也无关

类型通配符

当我们声明一个方法时,某个形参的类型是一个参数化的泛型类或泛型接口类型(Map<K,V>),但是在声明方法时,又不确定该泛型实际类型,我们可以考虑使用类型通配符。

形式:

(1)泛型类/接口名<?>        ?代表任意引用数据类型

(2)泛型类/接口名<? extends 上限>  ?代表的是该上限或上限的子类类型

(3)泛型类/接口名<? super 下限>     ?代表的是该下限或下限的父类类型

注意:

<?>:不可变,因为<?>类型不确定,编译时,任意类型都是错

<? extends 上限>:不可变,因为<? extends 上限>的?可能是上限或上限的子类,即类型不确定,编译按任意类型处理都是错。

<? super 下限>:可以将值修改为下限或下限子类的对象,因为<? super 下限>?代表是下限或下限的父类,那么设置为下限或下限子类的对象是安全的。

泛型的其他小问题

1、<>在左右两边 类型必须一致

2、JDK1.7之后允许右边<>里面空着,根据左边的自动推断

3、try...catch的catch里面不能使用T这种来代表任意异常类型。

4、泛型类不能创建数组对象

5、泛型可用于可变形参列表(T... t)

超类通配符<? super 下限>主要用于灵活的写入和比较,而<? extends 上限>主要用于读写,不能写入或者修改

数组算法升华

1、数组的反转

方法一:

1、借助一个新数组

2、首尾对应位置交换

缺点:需要借助一个数组,浪费额外空间,原数组需要垃圾回收

方法二:

数组对称位置的元素互换。

2、数组的扩容

(1)先创建一个新数组,可以扩容为原来的1.5倍、2倍等

(2)把旧数组的数据赋值到新数组中

(3)把新元素添加到newArr的最后

(4)如果下面继续使用arr,可以让arr指向新数组

数组扩容太多会造成浪费,太少会导致频繁扩容,效率低下

3、数组元素的插入

(1)判断数组是否需要扩容

  如果需要,先扩容

(2)把[index]位置和它后面的元素往右移动

(3)在[index]位置放入新元素

4、数组元素的删除

(1)把[index+1]位置和它后面的元素往左移动

(2)把当前数组的最后一个元素还原(0/null)

5、数组的二分查找

二分查找:对折对折再对折

要求:要求数组元素必须支持比较大小,并且数组中的元素已经按大小排好序

6、数组的直接选择排序

int[] arr = {....};

//轮数 = arr.length-1
for(int i=0; i<arr.length-1; i++){
  //(1)找出本轮最小值
  int minIndex = i;
  for(int j=i+1; j<arr.length-1; j++){
    if(arr[minIndex] > arr[j]){
      minIndex = j;
    }
  }
  //(2)如果本轮最小值不在它应该在的位置
  if(minIndex != i){
    int temp = arr[minIndex];
    arr[minIndex] = arr[i];
    arr[i] = temp;
  }
}

Java语法进阶10-泛型的更多相关文章

  1. Java语法进阶12-集合

    集合 集合:是一种容器,用来装对象的容器,不能装基本数据类型. 数组也是容器,可以用来装基本数据类型,也可以用来装对象. 本质上,集合需要用对应的数据结构实现,是多个类实现接口Collection系列 ...

  2. Java语法进阶10-多线程

    多线程 并发与并行.进程,线程调度自行百度 线程(thread):是一个进程中的其中一条执行路径,CPU调度的最基本调度的单位.同一个进程中线程可以共享一些内存(堆.方法区),每一个线程又有自己的独立 ...

  3. Java语法进阶13-文件、IO流

    File File是文件和目录路径名的抽象表示形式,即File类是文件或目录的路径,而不是文件本身,因此File类不能直接访问文件内容本身,如果需要访问文件内容本身,则需要使用输入/输出流. File ...

  4. Java语法进阶16-Lambda-Stream-Optional

    Lambda 大年初二,大门不出二门不迈.继续学习! 函数式接口 Lambda表达式其实就是实现SAM接口的语法糖,所谓SAM接口就是Single Abstract Method,即该接口中只有一个抽 ...

  5. Java语法进阶14-网络编程

    网络编程 软件结构 C/S结构 :全称为Client/Server结构,是指客户端和服务器结构. B/S结构 :全称为Browser/Server结构,是指浏览器和服务器结构. 网络通信协议 网络通信 ...

  6. Java中的10颗语法糖

    语法糖(Syntactic Sugar):也称糖衣语法,指在计算机语言中添加的某种语法,这种语法对语言的功能没有影响,但是更方便程序员使用.通常来说,使用语法糖能够增加程序的可读性,减少程序代码出错的 ...

  7. java语言进阶(二)_Collection_泛型

    主要内容 Collection集合 迭代器 增强for 泛型 第一章 Collection集合 1.1 集合概述 在前面基础班我们已经学习过并使用过集合ArrayList ,那么集合到底是什么呢? 集 ...

  8. Java基础语法<十二> 泛型程序设计

    1 意义 泛型程序设计意味着编写的代码可以被很多不同类型的对象所重用. 常见应用 : ArrayList 2 K T V E ? object等的含义 类型变量使用大写形式 E – Element ( ...

  9. Java语法糖1:可变长度参数以及foreach循环原理

    语法糖 接下来几篇文章要开启一个Java语法糖系列,所以首先讲讲什么是语法糖.语法糖是一种几乎每种语言或多或少都提供过的一些方便程序员开发代码的语法,它只是编译器实现的一些小把戏罢了,编译期间以特定的 ...

随机推荐

  1. Three.js - 走进3D的奇妙世界

    本文将通过Three.js的介绍及示例带我们走进3D的奇妙世界. 文章来源:宜信技术学院 & 宜信支付结算团队技术分享第6期-支付结算部支付研发团队前端研发高级工程师-刘琳<three. ...

  2. c#、ASP.NET core 基础模块之一:linq(原创)

    最近做数据查询,发现linq 真的比我 印象中  要强大的多,实用的多,所以 我决定  要与linq  来一场  深入交流, 因为linq的基础用法 可以百度一大摞,我就记录点不一样的,结合我做项目使 ...

  3. nslookup命令查找域名

    了解 DNS 域名服务 熟悉使用 nslookup 查找 DNS 服务器上登记的域名,记录几次查询的结果, 及服务器的 ip. 1. 某个子域下的一部分主机的名字- IP 地址对应关系,如 flame ...

  4. 【2018寒假集训 Day1】【位运算】桐桐的运输方案

    桐桐的运输方案(transp) [问题描述] 桐桐有 N 件货物需要运送到目的地,它们的重量和价值分别记为: 重量:W1,W2,…,Wn: 价值:V1,V2,…,Vn: 已知某辆货车的最大载货量为 X ...

  5. CSS中如果实现元素浮动,看这篇文章就足够了

    浮动基本介绍 在标准文档流中元素分为2种,块级元素和行内元素,如果想让一些元素既要有块级元素的特点也同时保留行内元素特点,只能让这些元素脱离标准文档流即可. 浮动可以让元素脱离标准文档流,可以实现让多 ...

  6. Java的 FileWriter类 和 FileReader类

    一.FileReader类1,构造方法:FileReader fr = new FileReader(String fileName);//使用带有指定文件的String参数的构造方法.创建该输入流对 ...

  7. MySQL5.7.18自动化安装脚本

    背景 很好的朋友邱启明同学,擅长MySQL,目前任职某大型互联网业MySQL DBA,要来一套MySQL自动安装的Shell脚本,贴出来保存一些. 此版本为 MySQL 5.7.18 ###### 自 ...

  8. java 小程序分析:参数传递

    public class Test{ public static void main (String [] ABC){ StringBuffer a = new StringBuffer(" ...

  9. HTML+CSS的小实例

    通过一个月以来对HTML5+CSS的学习.这篇随笔给大家来做一个简单的网页中常见的导航栏. 这些都称之为网页中的导航栏. 我简单的做了一个某宝和58同城的导航栏,供大家学习参考. 一.58同城导航栏: ...

  10. 一文读懂Python web框架和web服务器之间的关系

    我们都知道 Python 作为一门强大的语言,能够适应快速原型和较大项目的制作,因此被广泛用于 web 应用程序的开发中. 在面试的过程中,大家或多或少都被问到过这样一个问题:一个请求从浏览器发出到数 ...