Java笔记14:泛型初探
一、泛型简介
泛型是从Java SE 1.5开始出现的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数。这种参数类型可以用在类、接口和方法的创建中,分别称为泛型类、泛型接口、泛型方法。 Java语言引入泛型的好处是安全简单。
在JavaSE 1.5之前,没有泛型的情况的下,通过对类型Object的引用来实现参数的“任意化”,“任意化”带来的缺点是要做显式的强制类型转换,而这种转换是要求开发者对实际参数类型可以预知的情况下进行的。对于强制类型转换错误的情况,编译器可能不提示错误,在运行的时候才出现异常,这是一个安全隐患。
泛型的好处是在编译的时候检查类型安全,并且所有的强制转换都是自动和隐式的,以提高代码的重用率。
二、代码实现
这里给出了两个例子实现同样的功能,一个使用了泛型,一个没有使用泛型,通过对比,可以很快学会泛型的应用,学会这两个例子基本上就学会了泛型70%的内容。
例1:使用了泛型
classGen<T> {
private T obj;
public Gen(T obj) {
this.obj = obj;
}
public TgetObj() {
return obj;
}
public void setObj(T obj) {
this.obj = obj;
}
public void printType() {
System.out.println("T的实际类型为:" + obj.getClass().getName());;
}
}
public class GenDemo {
public static voidmain(String[] args) {
Gen<Integer> intObj = new Gen<Integer> (888);
intObj.printType();
int i = intObj.getObj();
System.out.println("value = " + i);
System.out.println("----------我是分割线----------");
Gen<String> strObj = new Gen<String>("Hello Gen!");
strObj.printType();
String s = strObj.getObj();
System.out.println("value = " + s);
}
}
运行结果:
T的实际类型为:java.lang.Integer
value =888
----------我是分割线----------
T的实际类型为:java.lang.String
value =Hello Gen!
例2:不使用泛型
class Gen2 {
private Object obj;
publicGen2(Object obj) {
this.obj = obj;
}
public ObjectgetObj() {
return obj;
}
public void setObj(Object obj) {
this.obj = obj;
}
public void printType() {
System.out.println("T的实际类型为:" + obj.getClass().getName());
}
}
public class GenDemo2 {
public static voidmain(String[] args) {
Gen2 intObj = new Gen2(new Integer(666));
intObj.printType();
int i =(Integer)intObj.getObj();
System.out.println("value = " + i);
System.out.println("----------我是分割线----------");
Gen2 strObj = new Gen2("Hello Gen!");
strObj.printType();
String s =(String)strObj.getObj();
System.out.println("value = " + s);
}
}
运行结果:
T的实际类型为:java.lang.Integer
value =666
----------我是分割线----------
T的实际类型为:java.lang.String
value = Hello Gen!
Java笔记14:泛型初探的更多相关文章
- 【Java入门提高篇】Day14 Java中的泛型初探
		泛型是一个很有意思也很重要的概念,本篇将简单介绍Java中的泛型特性,主要从以下角度讲解: 1.什么是泛型. 2.如何使用泛型. 3.泛型的好处. 1.什么是泛型? 泛型,字面意思便是参数化类型,平时 ... 
- Thinking in Java——笔记(14)
		Type Information The need for RTTI Because it is a dynamically bound method, the proper behavior wil ... 
- java笔记14之private
		private: 1 是一个权限修饰符 2 可以修饰成员变量和成员方法 被其修饰的成员只能在本类中被访问 class Demo { //int num = 1 ... 
- JAVA自学笔记14
		JAVA自学笔记14 1.正则表达式 1)是指一个用来描述或者匹配一系列符合某个句法规则的字符串的单个字符串.其实就是一种规则.有自己的特殊应用 2)组成规则: 规则字符在java.util.rege ... 
- Java笔记--泛型总结与详解
		泛型简介: 在泛型没有出来之前,编写存储对象的数据结构是很不方便的.如果要针对每类型的对象写一个数据结构, 则当需要将其应用到其他对象上时,还需要重写这个数据结构.如果使用了Object类型, ... 
- Java笔记2 : 泛型的体现,及其上限、下限、通配符
		Java中的泛型是在jdk5.0引入的,语法不难,但是需要注意的细节有很多,这里写一下备忘. 首先是最简单的泛型类,泛型方法,泛型接口: //泛型接口的定义 interface MyInter< ... 
- java笔记整理
		Java 笔记整理 包含内容 Unix Java 基础, 数据库(Oracle jdbc Hibernate pl/sql), web, JSP, Struts, Ajax Spring, E ... 
- TypeScript笔记[5]泛型+Dictionary 转
		TypeScript笔记[5]泛型 在C++.C#.Java等主流编程语言中,一般对泛型编程提供了支持.合理利用泛型,可以提高开发效率.提升代码质量. 例如在C++编程语言中,常常利用下面的结构表 ... 
- Java 中的泛型详解-Java编程思想
		Java中的泛型参考了C++的模板,Java的界限是Java泛型的局限. 2.简单泛型 促成泛型出现最引人注目的一个原因就是为了创造容器类. 首先看一个只能持有单个对象的类,这个类可以明确指定其持有的 ... 
随机推荐
- 596. Classes More Than 5 Students
			There is a table courses with columns: student and class Please list out all classes which have more ... 
- 关于k8s里的service互访,有说法
			昨天,测试了一个项目的接入.明白了以下几个坑: 1,traefik有可能有性能问题,如果daemonset安装,可重建.也需要通过8580端口查看性能. 2,集群中的service访问自己时,好像性能 ... 
- AC日记——红色的幻想乡 洛谷 P3801
			红色的幻想乡 思路: 线段树+容斥原理: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 100005 #de ... 
- PHP的命名空间namespace
			对于命名空间,官方文档已经说得很详细[查看],我在这里做了一下实践和总结. 命名空间一个最明确的目的就是解决重名问题,PHP中不允许两个函数或者类出现相同的名字,否则会产生一个致命的错误.这种情况下只 ... 
- 30、Flask实战第30天:cms模版抽离和个人信息页面完成
			cms模版抽离 新建一个cms_base.html文件作为基础模板,把cms_index.html的内容拷贝到cms_base.html中. 编辑 cms_base.html,把在不同页面会变动的部分 ... 
- 【Floyd】噪音恐惧症
			[UVA10048]噪音恐惧症 题面略 试题分析:直接Floyd一下维护u到v的路径最大值最小就可以了,1A 代码: #include<iostream> #include<cstr ... 
- BZOJ 4403 序列统计(Lucas)
			[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=4403 [题目大意] 给定三个正整数N.L和R,统计长度在1到N之间, 元素大小都在L到 ... 
- BZOJ 1123 [POI2008]BLO(Tarjan算法)
			[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1123 [题目大意] Byteotia城市有n个towns,m条双向roads. 每条r ... 
- [CF843D]Dynamic Shortest Path
			[CF843D]Dynamic Shortest Path 题目大意: 给定一个带权有向图,包含\(n(n\le10^5)\)个点和\(m(m\le10^5)\)条边.共\(q(q\le2000)\) ... 
- Problem F: 零起点学算法101——统计字母数字等个数
			#include<stdio.h> #include<string.h> int main(){ ]; while(gets(str)!=NULL){ ,b=,c=,d=; ; ... 
