day16<集合框架+>
集合框架(去除ArrayList中重复字符串元素方式)
集合框架(去除ArrayList中重复自定义对象元素)
集合框架(LinkedList的特有功能)
集合框架(栈和队列数据结构)
集合框架(用LinkedList模拟栈数据结构的集合并测试)
集合框架(泛型(generic)概述和基本使用)
集合框架(ArrayList存储字符串和自定义对象并遍历泛型版)
集合框架(泛型的由来)
集合框架(泛型类的概述及使用)
集合框架(泛型方法的概述和使用)
集合框架(泛型接口的概述和使用)
集合框架(泛型高级之通配符)
集合框架(增强for的概述和使用)
集合框架(ArrayList存储自定义对象并遍历增强for版)
集合框架(三种迭代的能否删除)
集合框架(静态导入的概述和使用)
集合框架(可变参数的概述和使用)
集合框架(Arrays工具类的asList()方法的使用)
集合框架(集合嵌套之ArrayList嵌套ArrayList)
###16.01_集合框架(去除ArrayList中重复字符串元素方式)(掌握)
A:案例演示
需求:ArrayList去除集合中字符串的重复值(字符串的内容相同)
思路:创建新集合方式
public class Demo1_ArrayList { public static void main(String[] args) { ArrayList list = new ArrayList(); list.add("a"); list.add("a"); list.add("b"); list.add("b"); list.add("c"); list.add("c"); ArrayList newList = getSingle(list); System.out.println(newList); //[a, b, c] } /* * 创建新集合将重复元素去掉 * 1,明确返回值类型,返回ArrayList * 2,明确参数列表ArrayList * * 分析: * 1,创建新集合 * 2,根据传入的集合(老集合)获取迭代器 * 3,遍历老集合 * 4,通过新集合判断是否包含老集合中的元素,如果包含就不添加,如果不包含就添加 */ public static ArrayList getSingle(ArrayList list) { ArrayList newList = new ArrayList(); //1,创建新集合 Iterator it = list.iterator(); //2,根据传入的集合(老集合)获取迭代器 while(it.hasNext()) { //3,遍历老集合 Object obj = it.next(); //记录住每一个元素 if(!newList.contains(obj)) { //如果新集合中不包含老集合中的元素 newList.add(obj); //将该元素添加 } } return newList; } } |
###16.02_集合框架(去除ArrayList中重复自定义对象元素)(掌握)
A:案例演示
需求:ArrayList去除集合中自定义对象元素的重复值(对象的成员变量值相同)
B:注意事项
重写equals()方法的
@Override public boolean equals(Object obj) { Person p = (Person)obj; return this.name.equals(p.name) && this.age == p.age; } |
public class Demo2_ArrayList { /** contains方法判断是否包含,底层依赖的是equals方法 remove方法判断是否删除,底层依赖的是equals方法,没重写前比较的是地址值,重写后比较对象的属性值 */ public static void main(String[] args) { ArrayList list = new ArrayList(); //创建集合对象 list.add(new Person("张三", 23)); list.add(new Person("张三", 23)); list.add(new Person("李四", 24)); list.add(new Person("李四", 24)); //ArrayList newList = getSingle(list); //调用方法去除重复 //System.out.println(newList); list.remove(new Person("张三", 23)); System.out.println(list); //重写后比较对象的属性,所以没重写equals方法比较的是地址值,删不了 } /* * 创建新集合将重复元素去掉 * 1,明确返回值类型,返回ArrayList * 2,明确参数列表ArrayList * * 分析: * 1,创建新集合 * 2,根据传入的集合(老集合)获取迭代器 * 3,遍历老集合 * 4,通过新集合判断是否包含老集合中的元素,如果包含就不添加,如果不包含就添加 */ public static ArrayList getSingle(ArrayList list) { ArrayList newList = new ArrayList(); //1,创建新集合 Iterator it = list.iterator(); //2,根据传入的集合(老集合)获取迭代器 while(it.hasNext()) { //3,遍历老集合 Object obj = it.next(); //记录住每一个元素 if(!newList.contains(obj)) { //如果新集合中不包含老集合中的元素 newList.add(obj); //将该元素添加 } } return newList; } } |
###16.03_集合框架(LinkedList的特有功能)(掌握)
A:LinkedList类概述
B:LinkedList类特有功能
public void addFirst(E e)及addLast(E e)
public E getFirst()及getLast()
public E removeFirst()及public E removeLast()
public E get(int index);
LinkedList list = new LinkedList(); list.addFirst("a"); list.addFirst("b"); list.addLast("c"); System.out.println(list.getFirst()); //b System.out.println(list.getLast()); //c System.out.println(list.removeFirst()); //b System.out.println(list.removeLast()); //c System.out.println(list.get(1)); //a System.out.println(list); //[b, a, c] |
###16.04_集合框架(栈和队列数据结构)(掌握)
栈
先进后出
队列
先进先出
###16.05_集合框架(用LinkedList模拟栈数据结构的集合并测试)(掌握)
A:案例演示
需求:请用LinkedList模拟栈数据结构的集合,并测试
创建一个类将Linked中的方法封装
public class Stack { private LinkedList list = new LinkedList(); // 模拟进栈方法 public void in(Object obj) { list.addLast(obj); } // 模拟出栈 public Object out() { return list.removeLast(); } // 模拟栈结构是否为空 public boolean isEmpty() { return list.isEmpty(); } } |
//用LinkedList模拟栈结构 public static void main(String[] args) { //demo1(); Stack s = new Stack(); s.in("a"); //进栈 s.in("b"); s.in("c"); s.in("d"); while(!s.isEmpty()) { //判断栈结构是否为空 System.out.println(s.out()); //弹栈 } } public static void demo1() { LinkedList list = new LinkedList(); //创建集合对象 list.addLast("a"); list.addLast("b"); list.addLast("c"); list.addLast("d"); /*System.out.println(list.removeLast()); System.out.println(list.removeLast()); System.out.println(list.removeLast()); System.out.println(list.removeLast());*/ while(!list.isEmpty()) { System.out.println(list.removeLast()); } } |
###16.06_集合框架(泛型概述和基本使用)(掌握)
A:泛型概述
B:泛型好处
提高安全性(将运行期的错误转换到编译期)
省去强转的麻烦
C:泛型基本使用
<>中放的必须是引用数据类型
D:泛型使用注意事项
前后的泛型必须一致,或者后面的泛型可以省略不写(1.7的新特性菱形泛型)
public static void main(String[] args) { demo1(); //int[] arr = new byte[5]; //数组要保证前后的数据类型一致 //ArrayList<Object> list = new ArrayList<Person>(); //集合的泛型要保证前后的数据类型一致 //ArrayList<Object> list = new ArrayList<>();//1.7版本的新特性,菱形泛型 ArrayList<Object> list = new ArrayList<Object>(); //泛型最好不要定义成Object,没有意义 list.add("aaa"); list.add(true); } public static void demo1() { ArrayList<Person> list = new ArrayList<Person>(); // list.add(110); // list.add(true); list.add(new Person("张三", 23)); list.add(new Person("李四", 24)); Iterator<Person> it = list.iterator(); while(it.hasNext()) { //System.out.println(it.next()); //System.out.println(it.next().getName() + "..." + it.next().getAge());//张三...24 //next方法只能调用一次,如果调用多次会将指针向后移动多次 Person p = it.next(); System.out.println(p.getName() + "..." + p.getAge()); } } |
###16.07_集合框架(ArrayList存储字符串和自定义对象并遍历泛型版)(掌握)
A:案例演示
ArrayList存储字符串并遍历泛型版
public static void main(String[] args) { //demo1(); ArrayList<Person> list = new ArrayList<Person>(); list.add(new Person("张三", 23)); list.add(new Person("李四", 24)); list.add(new Person("王五", 25)); list.add(new Person("赵六", 26)); Iterator<Person> it = list.iterator(); while(it.hasNext()) { Person p = it.next(); //将集合中的每一个元素用Person记录 System.out.println(p.getName() + "..." + p.getAge()); } } public static void demo1() { ArrayList<String> list = new ArrayList<String>(); //创建集合对象 list.add("a"); list.add("b"); list.add("c"); list.add("d"); Iterator<String> it = list.iterator(); while(it.hasNext()) { System.out.println(it.next()); } } |
###16.08_集合框架(泛型的由来)(了解)
A:案例演示
泛型的由来:通过Object转型问题引入
早期的Object类型可以接收任意的对象类型,但是在实际的使用中,会有类型转换的问题。也就存在这隐患,所以Java提供了泛型来解决这个安全问题。
###16.09_集合框架(泛型类的概述及使用)(了解)
A:泛型类概述<T>
把泛型定义在类上
B:定义格式
public class 类名<泛型类型1,…>
C:注意事项
泛型类型必须是引用类型
D:案例演示
泛型类的使用
public class Tool<Q> { //泛型一个字母大写,当用Tool创建对象时指定泛型,指定泛型是什么这个Q就是什么 private Q q; public Q getObj() { return q; } public void setObj(Q q) { this.q = q; } } |
public static void main(String[] args) { Tool<Student> t = new Tool<Student>(); //创建工具类对象 t.setObj(new Student("张三",23)); //Worker w = (Worker) t.getObj(); //向下转型 //System.out.println(w); } |
###16.10_集合框架(泛型方法的概述和使用)(了解)
A:泛型方法概述
把泛型定义在方法上
B:定义格式
public <泛型类型> 返回类型 方法名(泛型类型 变量名)
C:案例演示
泛型方法的使用
public class Tool<Q> { private Q q; public Q getObj() { return q; } public void setObj(Q q) { this.q = q; } public<T> void show(T t) { //方法泛型最好与类的泛型一致 System.out.println(t); //如果不一致,需要在方法上声明该泛型 } //Static方法随类的加载而加载,加载时可能还没创建对象Q没值 public static<W> void print(W w) { //静态方法必须声明自己的泛型 System.out.println(w); } } |
public static void main(String[] args) { //demo1(); Tool<String> t = new Tool<String>();//创建工具类对象指定为String类型 //t.show("abc"); t.show(true); } public static void demo1() { Tool<Student> t = new Tool<Student>(); //创建工具类对象 t.setObj(new Student("张三",23)); //Worker w = (Worker) t.getObj(); //向下转型 //System.out.println(w); } |
###16.11_集合框架(泛型接口的概述和使用)(了解)
A:泛型接口概述
把泛型定义在接口上
B:定义格式
public interface 接口名<泛型类型>
C:案例演示
泛型接口的使用
interface Inter<T> { public void show(T t); } class Demo implements Inter<String> { //推荐用这种 @Override public void show(String t) { System.out.println(t); } } |
class Demo<T> implements Inter<T> { //没有必要在实现接口的时候给自己类加泛型 @Override public void show(T t) { System.out.println(t); } } |
###16.12_集合框架(泛型高级之通配符)(了解)
A:泛型通配符<?>
任意类型,如果没有明确,那么就是Object以及任意的Java类了
B:? extends E
向下限定,E及其子类
C:? super E
向上限定,E及其父类
//List<?> list = new ArrayList<Integer>(); //当右边的泛型是不确定时,左边可以指定为? ArrayList<Person> list1 = new ArrayList<Person>(); list1.add(new Person("张三", 23)); list1.add(new Person("李四", 24)); list1.add(new Person("王五", 25)); ArrayList<Student> list2 = new ArrayList<Student>(); list2.add(new Student("赵六", 26)); list2.add(new Student("周七", 27)); list1.addAll(list2); //Student必须继承Person才能放进去 System.out.println(list1); |
###16.13_集合框架(增强for的概述和使用)(掌握)
A:增强for概述
简化数组和Collection集合的遍历
B:格式:
for(元素数据类型 变量 : 数组或者Collection集合) {
使用变量即可,该变量就是元素
}
C:案例演示
数组,集合存储元素用增强for遍历
ArrayList存储字符串并遍历增强for版
D:好处
简化遍历
int[] arr = {11,22,33,44,55}; for (int i : arr) { System.out.println(i); } ArrayList<String> list = new ArrayList<String>(); list.add("a"); list.add("b"); list.add("c"); list.add("d"); for (String string : list) { System.out.println(string); } |
###16.14_集合框架(ArrayList存储字符串和自定义对象并遍历增强for版)(掌握)
A:案例演示
自定义对象并遍历增强for版
增强for循环底层依赖的是迭代器(Iterator)
ArrayList<Person> list = new ArrayList<Person>(); list.add(new Person("张三", 23)); list.add(new Person("李四", 24)); list.add(new Person("王五", 25)); list.add(new Person("赵六", 26)); for (Person person : list) { System.out.println(person); } |
###16.15_集合框架(三种迭代的能否删除)(掌握)
普通for循环,可以删除,但是索引要--
迭代器,可以删除,但是必须使用迭代器自身的remove方法,否则会出现并发修改异常
jdk1.5增强for循环不能删除
ArrayList<String> list = new ArrayList<String>(); list.add("a"); list.add("b"); list.add("b"); list.add("c"); list.add("d"); //1,普通for循环删除,索引要-- for(int i = 0; i < list.size(); i++) { if("b".equals(list.get(i))) { list.remove(i--); //通过索引删除元素 } } |
//2,迭代器删除 Iterator<String> it = list.iterator(); while(it.hasNext()) { if("b".equals(it.next())) { //list.remove("b"); //不能用集合的删除方法,因为迭代过程中如果集合修改会出现并发修改异常 it.remove(); //可以操作自身的方法 } } /*for(Iterator<String> it2 = list.iterator(); it2.hasNext();) { if("b".equals(it2.next())) { //list.remove("b"); //不能用集合的删除方法,因为迭代过程中如果集合修改会出现并发修改异常 it2.remove(); } }*/ |
//3,增强for循环,增强for循环不能删除,只能遍历 for (String string : list) { if("b".equals(string)) { list.remove("b"); //ConcurrentModificationException并发修改异常 } } System.out.println(list); |
###16.16_集合框架(jdk1.5静态导入的概述和使用)(掌握)
A:静态导入概述
B:格式:
import static 包名….类名.方法名;
可以直接导入到方法的级别
C:注意事项
方法必须是静态的,如果有多个同名的静态方法,容易不知道使用谁?这个时候要使用,必须加前缀。由此可见,意义不大,所以一般不用,但是要能看懂。
import static java.util.Arrays.sort; //静态导入 import static java.util.Arrays.toString; //静态导入 public class Demo2_StaticImport { public static void main(String[] args) { int[] arr = {55,22,33,44,11}; sort(arr); //排序 //System.out.println(toString(arr)); } } |
###16.17_集合框架(jdk1.5可变参数的概述和使用)(掌握)
A:可变参数概述
定义方法的时候不知道该定义多少个参数
B:格式
修饰符 返回值类型 方法名(数据类型… 变量名){}
C:注意事项:
这里的变量其实是一个数组
如果一个方法有可变参数,并且有多个参数,那么,可变参数肯定是最后一个
public static void main(String[] args) { int[] arr = {11,22,33,44,55}; //print(arr); print(11,22,33,44,55); System.out.println("---------------"); //print(); } /*public static void print(int[] arr) { for (int i = 0; i < arr.length; i++) { System.out.println(arr[i]); } }*/ public static void print(int ... arr) { //可变参数其实是一个数组 for (int i = 0; i < arr.length; i++) { System.out.println(arr[i]); } } |
###16.18_集合框架(Arrays工具类的asList()方法的使用)(掌握)
A:案例演示
Arrays工具类的asList()方法的使用
Collection中toArray(T[] a)泛型版的集合转数组
数组转换成集合
数组转换成集合虽然不能增加或减少元素,但是可以用集合的思想操作数组,也就是说可以使用其他集合中的方法。
public static void demo2() { //int[] arr = {11,22,33,44,55}; //List<int[]> list = Arrays.asList(arr); //基本数据类型的数组转换成集合,会将整个数组当作一个对象转换 //System.out.println(list); //[[I@67006d75] Integer[] arr = {11,22,33,44,55}; //将数组转换成集合,数组必须是引用数据类型 List<Integer> list = Arrays.asList(arr); System.out.println(list); //[11, 22, 33, 44, 55] } public static void demo1() { String[] arr = {"a","b","c"}; List<String> list = Arrays.asList(arr); //将数组转换成集合 //list.add("d");//ConcurrentModificationException //不能添加 System.out.println(list); //[a, b, c] } |
//集合转数组,加泛型的 ArrayList<String> list = new ArrayList<String>(); list.add("a"); list.add("b"); list.add("c"); list.add("d"); String[] arr = list.toArray(new String[10]); //当集合转换数组时,数组长度如果是小于等于集合的size时,转换后的数组长度等于集合的size //如果数组的长度大于了size,分配的数组长度就和你指定的长度一样 for (String string : arr) { System.out.print(string + " "); //a b c d null null null null null null } |
###16.19_集合框架(集合嵌套之ArrayList嵌套ArrayList)(掌握)
A:案例演示
集合嵌套之ArrayList嵌套ArrayList
ArrayList<ArrayList<Person>> list = new ArrayList<ArrayList<Person>>(); ArrayList<Person> first = new ArrayList<Person>(); //创建第一个班级 first.add(new Person("杨幂", 30)); first.add(new Person("李冰冰", 33)); first.add(new Person("范冰冰", 20)); ArrayList<Person> second = new ArrayList<Person>(); second.add(new Person("黄晓明", 31)); second.add(new Person("赵薇", 33)); second.add(new Person("陈坤", 32)); //将班级添加到学科集合中 list.add(first); list.add(second); //遍历学科集合 for(ArrayList<Person> a : list) { for(Person p : a) { System.out.println(p); } } |
###16.20_day16总结
把今天的知识点总结一遍。
###16.21_day16作业
1,定义一个方法swap()传入集合和两个角标使集合中元素交换位置
a,定义一个临时变量, 记住其中一个元素
b,用第一个位置存放第二个位置上的元素
c, 用第二个位置存放临时变量记住的元素
2,把集合中存储多个Person对象,Person有姓名和年龄,找出年龄最大的
a,定义一个Person类型的变量, 先记住第一个元素
b,循环遍历集合
c,用每一个元素和变量比较年龄, 如果集合中的元素比变量记住的年龄大
d,用变量记住这个年龄较大的元素
e,返回变量记住的元素
3,把集合中的元素反转
a,定义循环, 循环size()/2次
b,第一次交换第一个和最后一个, 第二次交换第二个和倒数第二个
4,public static void main(String[] args) {
List<String> list1 = new ArrayList<>();
list1.add("b");
list1.add("f");
list1.add("e");
list1.add("c");
list1.add("a");
list1.add("d");
sort1(list1);
System.out.println(list1); // a, b, c, d, e, f
List<Integer> list2 = new ArrayList<>();
list2.add(5);
list2.add(8);
list2.add(3);
list2.add(1);
list2.add(4);
sort2(list2);
System.out.println(list2); //1,3,4,5,8
}
对集合中添加的元素排序
5,List<String> list = new ArrayList<>();
list.add("a");
list.add("a");
list.add("a");
list.add("b");
list.add("b");
list.add("c");
list.add("d");
list.add("d");
list.add("d");
list.add("d");
list.add("d");
System.out.println(frequency(list, "a")); // 3
System.out.println(frequency(list, "b")); // 2
System.out.println(frequency(list, "c")); // 1
System.out.println(frequency(list, "d")); // 5
System.out.println(frequency(list, "xxx")); // 0
定义方法统计集合中指定元素出现的次数
6,定义一个replaceAll方法,将传入的新值替换集合中的老值(list,old,new)
day16<集合框架+>的更多相关文章
- python_way day16 JQuary
python_way day16 JQuery 封装dom js代码 jQuery(1.10,1.12-兼容性好,2.0.以后放弃了ie9以下) - 封装了Dom & JavaScript 查 ...
- python_way day16 DOM
Python_way day16 1.Dom (找到html中的标签) 一.DOM 1.查找元素 直接查找 document.getElementById 根据ID获取一个标签 --->这里是 ...
- Spark Streaming揭秘 Day16 数据清理机制
Spark Streaming揭秘 Day16 数据清理机制 今天主要来讲下Spark的数据清理机制,我们都知道,Spark是运行在jvm上的,虽然jvm本身就有对象的自动回收工作,但是,如果自己不进 ...
- Python之路,Day16 - Django 进阶
Python之路,Day16 - Django 进阶 本节内容 自定义template tags 中间件 CRSF 权限管理 分页 Django分页 https://docs.djangoproj ...
- day16 十六、包、循环导入、导入模块
一.包的概念 包:一系列模块的集合体.包通过文件夹管理一系列功能相近的模块 重点:包中一定有一个专门用来管理包中所有模块的文件 包名:存放一系列模块的文件夹的名字 包名(对象)存放的是管理模块的那个文 ...
- 11.5 正睿停课训练 Day16
目录 2018.11.5 正睿停课训练 Day16 A 道路规划(思路) B 逻辑判断(枚举 位运算/DP 高维前缀和) C 区间(贪心/树状数组) 考试代码 A B C 2018.11.5 正睿停课 ...
- python开发学习-day16(Django框架初识)
s12-20160507-day16 *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: ...
- Day16模块
Day16 当做执行文件时 __name__ = "__main__" 当做模块被导入时 __name__ 等于文件名即模块名 ```python 循环导入(模块的名称空间已经建立 ...
- 学习日常笔记<day16>mysql加强
1.数据约束 1.1什么是数据约束 对用户操作表的数据进行约束 1.2 默认值 作用:当永辉对使用默认值的字段不插入值的时候,就使用默认值 注意: 1)对默认值字段插入null是可以的 2)对默认值字 ...
- 100天搞定机器学习|Day16 通过内核技巧实现SVM
前情回顾 机器学习100天|Day1数据预处理100天搞定机器学习|Day2简单线性回归分析100天搞定机器学习|Day3多元线性回归100天搞定机器学习|Day4-6 逻辑回归100天搞定机器学习| ...
随机推荐
- 一起来学Go --- (go的枚举以及数据类型)
枚举 枚举指一系列的相关的常量,比如下面关于一个星期的中每天的定义,通过上篇博文,我们可以用在const后跟一对圆括号的方式定义一组常量,这种定义法在go语言中通常用于定义枚举值.go语言并不支持众多 ...
- 深入理解JVM(七)——性能监控工具
前言 工欲善其事必先利其器,性能优化和故障排查在我们大都数人眼里是件比较棘手的事情,一是需要具备一定的原理知识作为基础,二是需要掌握排查问题和解决问题的流程.方法.本文就将介绍利用性能监控工具,帮助开 ...
- ASM的备份集在文件系统上恢复测试
背景:最近时常有客户咨询这类问题,其实很简单一个操作,但由于每个人的理解差异,也容易出现各种问题或者误解,本文主要总结下这个过程以及常遇到的问题处理. 环境:Site A(Oracle RAC 11. ...
- JavaScript笔记之第四天
HTML DOM (文档对象模型) 当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model). 查找 HTML 元素 通常,通过 JavaScript,您需要操作 ...
- monogodb使用
菜鸟教程有相关介绍,已经很详细. http://www.runoob.com/mongodb/mongodb-databases-documents-collections.html 网上找了一些博客 ...
- VS2015企业版和专业版永久密匙
专业版:HMGNV-WCYXV-X7G9W-YCX63-B98R2企业版:HM6NR-QXX7C-DFW2Y-8B82K-WTYJV
- 散列表(拉链法与线性探测法)Java实现
package practice; import java.security.Principal; import java.util.Scanner; import edu.princeton.cs. ...
- struts.xml如何加载到及配置问题
今天项目做客户化处理,看到struts.xml,突然间想不起来这个文件从哪里加载的了,真是越学越回去了.这里记录下. web工程启动的时候,系统会加载web.xml文件,在这个时候会加载Spring的 ...
- SGI STL内存配置器存在内存泄漏吗?
阅读了SGI的源码后对STL很是膜拜,很高质量的源码,从中学到了很多.温故而知新!下文中所有STL如无特殊说明均指SGI版本实现. STL 内存配置器 STL对内存管理最核心部分我觉得是其将C++对象 ...
- dnsmasq一次成功的配置
第一次用这个小软件,感觉还不错,因为没有像bind那样配置起来繁琐,并且我们也不需要去配置很多文件,内外网访问互不干涉. 我是在centos6.5下进行配置的: 先说说自己的理解: dnsmasq先去 ...