luogg_java学习_09_泛型_集合
这篇博客总结了半天,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用.
**转载请注明 出自 : luogg的博客园 ** ,
泛型
泛型介绍
1)、类内部的属性的类型可以由外部决定;
2)、泛型可以解决数据类型的安全性问题;
实现原理
1、在类声明时通过一个标识表示类中的某个属性的类型或者是某个方法的返回值及参数类型,
2、在实例化时只要指定好需要的具体的类型即可
泛型类定义
[访问权限] class 类名称<泛型类型标识>{
[访问权限] 泛型类型标识 变量名称; 占位符
[访问权限] 泛型类型标识 方法名称(){}
[访问权限] 返回值类型声明 方法名称(泛型类型标识 变量名称){};
}
泛型对象定义
类名称<具体类> 对象名称 = new 类名称<具体类>();
定义多个泛型
类名称<具体类1,具体类2,…> 对象名称 = new 类名称<具体类1,具体类2,…>();
泛型构造方法
构造方法可以为类中的成员变量初始化,如果类中的成员变量类型通过泛型指定,但初始化又需要由构造方法来完成,那么这时就可以将泛型应用在构造方法上。
格式:
[访问权限] 构造方法 ([泛型类型 参数名称]){
}
泛型的安全警告
在泛型应用中最好的在声明类对象时指定好其内部的数据类型,如 Info,如果不指定类型,在使用该类的时候就会出现不安全的警告,但是这样并不影响程序的运行
/**
* 泛型练习2 创建一个xy轴
* @author luogg
* @version v1.0 2016-xx-xx
*/
public class Test2 {
public static void main(String[] args) {
Point2<Integer> p1 = new Point2<Integer>();
p1.setX(10);
p1.setY(12);
int x = p1.getX();
int y = p1.getY();
System.out.println("x坐标:"+ x + ",y坐标:"+ y);
Point2<Character> p2 = new Point2<Character>();
p2.setX('哈');
p2.setY('呵');
char c1 = p2.getX();
char c2 = p2.getY();
System.out.println(c1+",,,"+c2);
Point2<Boolean> p3 = new Point2<Boolean>();
p3.setX(true);
System.out.println(p3.getX());
}
}
class Point2<T>{
private T x;
private T y;
public T getX() {
return x;
}
public void setX(T x) {
this.x = x;
}
public T getY() {
return y;
}
public void setY(T y) {
this.y = y;
}
}
集合
定义
和数组类似,可以用来存放一组数据,和数组不同的是,集合里面只能放对象,长度是可变的,也已叫做“对象容器”
表示:
用 Java API 中定义好的一系列类和接口,这些类和接口放在 java .util 包中。
java中的集合结构
List接口(有序的)
List 接口是 Collection 的子接口,也是最常用的接口。此接口对 Collection 接口进行了大量的扩充,里面的内容是可以重复存放的
ArrayList类
一、方法的使用
核心方法:
- add(E e)添加元素
- get(int index)获取指定位置元素
- size()长度
常用方法:
clear()
isEmpty()
remove(int index) 移除指定位置元素
set(int index, E element) 替换
其他方法(熟悉即可)
二、集合的遍历
1、普通for
2、增强for循环,不需要写集合的大小,for( : )前边写接收的,后边写集合名字
3、迭代器 Iterator(集合的输出接口,用于输出集合中的内容,只能进行从前到后的单项输出) / / 直接将it.next写在syso中, Perosn的输出结果会少一半,因为next是取,取第一个人的名,取第二个人的年龄...
Set 接口(无序的)
同样是 Collection 的子接口,但没有对 Collection 接口进行扩充,里面不允许存放重复的值
HashSet类
集合中内容是无序的,并且不能存放重复数据
一、常用方法
add(E e); 加进去元素
remove(Object o);移除所加元素
clear(); 清空所有元素
二、集合的遍历
1、增强for循环
2、迭代器
三、加不进去重复数据的原因:
当使用 HashSet 时,会自动调用 hashCode(),判断已经存储的 Hash code 值是否与增加的 hash code 值一致,如果不一致,直接放进去,如果一致,再进行 equals 的比较,equals 方法返回 true,表示对象已经加进去了,就不会加进去新的对象,否则加进去。
所以,重复与否与 equals()和 hashCode()方法有关,重写 equals 方法必须重写 HashCode()方法,反之亦然。
四、自定义对象想要实现不重复必须实现 equals()和 hashCode()
//在Person类中通过sorce,快捷导入equals()方法和hashcode()方法,之后输入相同的数据就不会输出了.
TreeSet类
自动排序,有小到大排序, 集合中内容是有序的,并且不能存放重复数据
一、方法的使用
和 HashSet 相同
其他方法(熟悉即可)
二、集合的遍历
1、增强for循环
2、迭代器
三、自定义对象的排序问题
如果想要自定义的对象进行排序。需要两步:
1、实现 Comparable 接口
2、覆写其中的所有抽象类,(重点覆写compareTo方法)
定义排序规则,若要TreeSet.add()一个自定义对象,
这个对象所在的类必须要有CompareTo()方法
Map接口
是存放一对值的最大父接口,所谓的对值指的是每一个元素都是一对,以 key -> value 的形式保存的
HashMap类
Map 接口不同,每次操作的是一对对象,即二元偶对象,Map中的每个元素都使用“key-->value”的形式存储在集合中。
一、方法的使用
put(key , value); //添加数据
get(key) //通过 key 值获取对象
keySet() //以 Set 的形式获得 Map 对象的 key 值
二、集合内容的遍历
不可以使用for 也不可以使用增强for 不可以输出两个值key value
1、使用ketSet 然后用增强for循环 通过key获取
Map<Integer, Person> map = new HashMap<Integer,Person>();
map.put(10, new Person("张三",20));
map.put(1, new Person("李四",18));
map.put(5, new Person("王五",23));
Set<Integer> set = map.keySet();
for(int key:set) {
Person p = map.get(key);
System.out.println(p.getName()+p.getAge());
}
总结
集合的特点:
集合中提供了很多方法,便于程序员操作集合中的元素
集合的长度是可变的。
数组可以放简单数据类型和复合类型,而集合只能存放对象
//集合不能装简单数据类型 会自动装箱
区别总结:
List 和 Set的区别 //重复与不重复 父类一样
HashSet 和 TreeSet 的区别//都不可以重复 有序 无序
Collection 和 Map 的区别 //单值存放最大父接口 对值存放最大父接口
luogg_java学习_09_泛型_集合的更多相关文章
- luogg_java学习_10_异常_反射
本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! 异常_反射 异常 异常就是导致程序中断执行的一段指令流 ...
- luogg_java学习_07_抽象类_接口_多态学习总结
这篇博客总结了半天,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 , 抽象 一种专门用来做父类,被继承的. (模板) 格式: abs ...
- 18_集合框架_第18天_集合、Iterator迭代器、增强for循环 、泛型_讲义
今日内容介绍 1.集合 2.Iterator迭代器 3.增强for循环 4.泛型 01集合使用的回顾 *A:集合使用的回顾 *a.ArrayList集合存储5个int类型元素 public stati ...
- 牛客网Java刷题知识点之泛型概念的提出、什么是泛型、泛型在集合中的应用、泛型类、泛型方法、泛型接口、泛型限定上限、泛型限定下限、 什么时候使用上限?泛型限定通配符的体现
不多说,直接上干货! 先来看个泛型概念提出的背景的例子. GenericDemo.java package zhouls.bigdata.DataFeatureSelection; import ja ...
- 大数据技术之_16_Scala学习_08_数据结构(下)-集合操作+模式匹配
第十一章 数据结构(下)-集合操作11.1 集合元素的映射-map11.1.1 map 映射函数的操作11.1.2 高阶函数基本使用案例1+案例211.1.3 使用 map 映射函数来解决11.1.4 ...
- Java 理论和实践: 了解泛型 识别和避免学习使用泛型过程中的陷阱
Brian Goetz (brian@quiotix.com), 首席顾问, Quiotix 简介: JDK 5.0 中增加的泛型类型,是 Java 语言中类型安全的一次重要改进.但是,对于初次使用泛 ...
- 学习javascript数据结构(三)——集合
前言 总括: 本文讲解了数据结构中的[集合]概念,并使用javascript实现了集合. 原文博客地址:学习javascript数据结构(三)--集合 知乎专栏&&简书专题:前端进击者 ...
- .Net 笔记(二) 泛型和集合
前言: 本文中介绍 泛型和集合的区别.也算是自己的一个知识点的回顾,并且把它们写在自己的笔记中. 1.集合: 在讲到集合之前,我们先来回顾下数组的知识点吧,因为集合和数组的关系也是比较微妙的各有利弊, ...
- python学习博客地址集合。。。
python学习博客地址集合... 老师讲课博客目录 http://www.bootcdn.cn/bootstrap/ bootstrap cdn在线地址 http://www.cnblogs. ...
随机推荐
- 日志系统实战(三)-分布式跟踪的Net实现
介绍 在大型系统开发调试中,跨系统之间联调开始变得不好使了.莫名其妙一个错误爆出来了,日志虽然有记录,但到底是哪里出问题了呢? 是Ios端参数传的不对?还是A系统或B系统提供的接口导致?相信有不少人遇 ...
- 【Java并发编程实战】-----“J.U.C”:ReentrantLock之三unlock方法分析
前篇博客LZ已经分析了ReentrantLock的lock()实现过程,我们了解到lock实现机制有公平锁和非公平锁,两者的主要区别在于公平锁要按照CLH队列等待获取锁,而非公平锁无视CLH队列直接获 ...
- [ASP.NET MVC 小牛之路]08 - Area 使用
ASP.NET MVC允许使用 Area(区域)来组织Web应用程序,每个Area代表应用程序的不同功能模块.这对于大的工程非常有用,Area 使每个功能模块都有各自的文件夹,文件夹中有自己的Cont ...
- 大叔最新课程~MVC核心技术剖析
<MVC核心技术剖析介绍> 主讲:仓储大叔 时间:2016-12-04 20:30分 MVC各层分工 Http请求的过程 如何查找Action 如何渲染视图 ViewModel,DTO,D ...
- iOS-在团队开发过程中控制代码版本
Cornerstone Svn简单使用指南: -- what if 负责编写 一.安装并拷贝项目 1.第一步:安装svn.2.第二步:第一个使用svn,找到“Check Out Working Cop ...
- .net基础复习之一
一. ADO 与ADO.NET两种数据访问方式区别? 1. ADO与ADO.NET简介ADO与ADO.NET既有相似也有区别,他们都能够编写对数据库服务器中的数据进行访问和操作 ...
- Resource governor2:Configuration query
SQL Server Engine 当前使用的configuration,称作 In-memory configuration,使用DMV:sys.dm_resource_governor_XXX查看 ...
- IIS7.5+WebConfig实现页面伪静态和301重定向
IIS7.5+WebConfig实现页面伪静态和301重定向 使用URLRewriter组件在windows 2003 +iis 6.0下配置伪静态的文章网络上一大堆.但在iis7.0或iis 7.5 ...
- Sql Server系列:存储过程
1 存储过程简介 存储过程是使用T-SQL代码编写的代码段.在存储过程中,可以声明变量.执行条件判断语句等其他编程功能.在MS SQL Server 2012中存储过程主要分三类:系统存储过程.自定义 ...
- Windows下使用Dev-C++开发基于pthread.h的多线程程序
一.下载Windows版本的pthread 目前最新版本是:pthreads-w32-2-9-1-release.zip. 二.解压pthread到指定目录 我选择的目录是:E:\DEV-C ...