《学习笔记Day14》Math类方法;集合超详细学习笔记,Collection接口,List接口;List的3种实现类(Vector,ArrayList,LinkedList)

Math

1、E:自然对数的底数
2、PI:圆周率
常用方法

(1)abs(数字类型) 求绝对值
(2)cbrt(double d) 开立方
(3)sqrt(double d) 开平方
(4)ceil(double d) 向上取整
(5)floor(double d) 向下取整
(6)max(int a, int b) 求最大值
(7)min(int a, int b) 求最小值
(8)pow(int a, int b) 求a的b次方
(9)random() 返回[0.0, 1.0)的随机数
(10)round(double d) 四舍五入,负数部分可以看成”五舍六入”

集合概述

1、是一个类似于数组的统一存储、管理数据的容器,集合只能存储引用数据类型,不能存储基本数据类型,就好像是对象数组
为什么用数组
1、对象数组的不足:
1)无法扩展:数组长度固定,一旦创建无法更改
2)结果:每次要添加一个新的元素,都需要创建一个更大的数组,将原数组的内容填入新数组,并且填入新加入的元素,长此以往非常麻烦。并且这些操作和我们实际开发中的业务逻辑并不相关
3)所有关于数据操作的业务逻辑都需要自己取定义,并且自己定义的操作不全面
2、集合的优势:
1)可扩展:底层会自动增长,不用我们主动操作进行扩展,避免了不必要的麻烦
2)集合中定义了大量的错做集合的方法,这些方法十分易用,为我们操作集合提供了便利
3)集合存储的全是引用数据类型,以及对象,也利于我们面向对象的编程思想
4)不带泛型的集合可以存储各种类型的数据

集合和数组的区别

1、共同点:
1)都是用于存储和管理数据的容器
2)零散的变量不便于操作和存储,使用一个容器统一管理,容器都具有索引或者类似索引的标志,便于查找和管理数据
2、不同点:
(1)存储内容不同:
1)数组既能够存储基本数据类型,也能够存储引用数据类型
2)集合只能存储引用数据类型,就算添加的时候是基本数据类型,存储在集合中也是基本数据类型包装类的对象
(2)存储的数量不同:
1)数组创建出来后,大小不可变,数组容量有多大,就能存储多少数据
2)集合底层可以自动增长,容量可变
(3)方法不同:
1)数据只能使用Object类型的方法和一个length
2)集合中有大量易用的方法

(四)集合的体系结构

1、集合分类:
(1)单列集合:每个元素都是一个单独的个体,就类似数组一样
(2)双列集合:每个操作都针对一对数据进行,以一对数据为单位

在这里插入图片描述
3、双列集合的体系结构:
在这里插入图片描述

Collection接口

1、单列集合顶层接口,定义了所有单列集合共性的功能
2、Collection是接口无法创建对象,所以为了学习,我们使用实现类ArrayList,进行使用:接口Collection的引用,指向了实现类ArrayList的对象

3、常用方法:
(1)add(Object obj):将obj元素添加到集合中
(2)remove(Object obj) 将obj元素从集合中删除
(3)clear() 清空集合
(4)isEmpty() 判断集合是否为空
(5)contains(Object obj) 判断集合是否包含指定元素
(6)size() 返回集合元素个数

(二)Collection的第一种遍历方式

1、toArray() 将集合中的元素添加到一个数组并且返回
2、调用此方法,将集合元素存入数组返回数组,再对数组进行遍历即可

public class Demo01 {
	public static void main(String[] args) {
		Collection list = new ArrayList();
		
		list.add(123);
		list.add(123);
		list.add(3.5);
		list.add(3.5);
		list.add("abc");
		list.add("abc");
		list.add(false);
		list.add(false);
		list.add(true);
		list.add(true);
		list.add('a');
		list.add('q');
		
		//1.将集合转为数组
		Object[] arr = list.toArray();
		
		//2.遍历数组
		for (int i = 0; i < arr.length; i++) {
			System.out.print(arr[i] + " ");
		}
	}
}

(三)Collection中带All的方法

1、addAll(Collection list) 将参数几何的元素全部添加到调用者集合中
2、containsAll(Collection list) 判断调用者集合中是否包含参数几何的所有元素,如果是就返回true,否则为false
3、removeAll(Collection list) 从调用者集合中删除和参数几何相同的那些元素
4、retainAll(Collection list) 仅在调用者集合中保留和参数几何重复的元素

(四)集合的第二种遍历方式:迭代器

1、迭代:更代,更新换代,从一个到另一个的过程
2、迭代器:专门用于将集合中的元素,一个到另一个迭代的对象
3、迭代器的获取:集合内部就有一个可以迭代自己的对象,我们直接从集合获取即可;

调用iterator()方法,返回一个迭代器对象

4、迭代器的使用:获取到的迭代器是Iterator接口的实现类对象,在迭代器接口中由相应的方法

(1)hasNext() 判断是否有下一个可以迭代的元素,如果有,就返回true
(2)next() 获取集合中的下一个元素
(3)remove() 删除集合中迭代器正在遍历的那个元素

5、迭代器使用的注意事项:

(1)hasNext() 每次只能判断下一个元素是否存在
(2)next() 每次只能获取一个元素并且将迭代器向下一个元素移动一个位置
(3)调用一次hasNext()方法只能调用一次next()方法
(4)如果调用一次hasNext()就调用多次next()会出现NoSuchElementException(没有当前元素异常)

public class Demo06_Iterator {
	
	public static void main(String[] args) {
		Collection list = new ArrayList();
		
		list.add(new Person("张三", 23));
		list.add(new Person("李四", 24));
		list.add(new Person("王五", 25));
		
		
		//1.获取当前集合的迭代器对象
		Iterator it = list.iterator();
		
		//2.迭代器遍历
		while(it.hasNext()) {
			Object obj = it.next();
			
			Person p = (Person)obj;

			System.out.println(p.getName() + "..." + p.getAge());

		}
		
	}

List接口

是Collection的子接口
2、特点:
(1)有序:元素的存储顺序和获取顺序保持一致
(2)可重复:允许存储重复元素
(3)可重复的原因:有索引。因为对于重复的元素,具有不同的索引来区分
3、特有方法:
(1)add(int index, Object obj) 将指定元素插入到集合的指定位置
(2)remove(int index) 删除指定索引上的指定元素
(3)set(int index, Object obj) 用指定元素替换指定索引上原有的元素
(4)get(int index) 返回指定索引上的元素

第三种遍历方式

1、针对List集合特有的遍历方式,Collection中不一定能用,Set中一定不能用
2、可以通过size方法获取到集合的长度,进而就能得到List集合的索引范围,再配合get方法,就能获取到每一个索引对应的每一个元素了

public static void main(String[] args) {
		List list = new ArrayList();
		
		list.add("abc");
		list.add("abc");
		list.add(123);
		list.add(123);
		list.add(3.5);
		list.add(3.5);
		list.add(false);
		list.add(false);
		list.add(true);
		
		for(int i = 0; i < list.size(); i++) {
			System.out.println(list.get(i));
		}
	}
}

并发修改异常

1、ConcurrentModificationException
并发 修改 异常
2、出现原因:在使用迭代器对象遍历集合的时候,通过集合对象操作集合【修改删除】
3、避免方式:
(1)集合遍历集合修改
(2)迭代器遍历迭代器修改
4、List集合特有的迭代器:ListIterator
(1)迭代便利操作:和以前一样
(2)迭代增加:在ListIterator中有add方法,可以向集合中添加元素
(3)ListIterator是Iterator的子接口
(4)在List集合中要调用方法获取这个迭代器,方法:listIterator()

public static void main(String[] args) {
		List list = new ArrayList();
		
		list.add("abc");
		list.add("qwe");
		list.add("[][]");
		list.add("qwe");
		list.add("iuo");
		list.add("def");
		list.add("iuo");
		list.add("iuo");
		list.add("[][]");
		
		/*System.out.println(list);
		
		for (int i = 0; i < list.size(); i++) {
			Object obj = list.get(i);
			
			if("def".equals(obj)) {
				list.add("666");
			}
		}*///在list最后的元素加上666
		
		/*Iterator it = list.iterator();
		
		while(it.hasNext()) {
			Object obj = it.next();
			
			if("def".equals(obj)) {
				list.add("666");
			}
		}*///出现ConcurrentModificationException
		
		ListIterator lit = list.listIterator();
		
		while(lit.hasNext()) {
			Object obj = lit.next();
			
			if("def".equals(obj)) {
				lit.add("666");
			}
		}
		
		System.out.println(list);//在def之后加上666
	}
}

List的实现类

(一)概述
1、List是一个接口,无法直接创建对象,所以根据底层实现的不同,具有不同的实现类
2、Vector:数组实现,顺序存储
3、ArrayList:数组实现,顺序存储
4、LinkedList:链表实现,节点存储

(二)Vector

1、在JDK1.0版本出现,这个类已经过时,在JDK1.2被ArrayList取代
2、特点:
(1)线程安全,效率低
(2)顺序存储,增删较慢
3、特有方法:
(1)addElement(Object obj) 向集合中添加元素
(2)removeElement(Object obj) 删除集合中的元素
(3)elements() Vector的枚举对象(迭代器)
4、特有的遍历方式:
(1)使用elements方法获取Enumeration对象
(2)使用获取到的对象调用hasMoreElements方法判断是否有下一个元素
(3)使用获取到的对象调用nextElement方法获取下一个元素

(三)ArrayList

1、也是List接口的一个实现类
2、没有什么特有的方法
3、存储方式:
(1)数组实现,顺序存储
(2)增删慢,查询快
(3)通过物理内存结构实现位置关系,来表达逻辑顺序的相临

(四)LinkedList

1、List接口的实现类
2、存储方式:
(1)节点实现,链式存储
(2)不是通过物理结构实现相临关系,是通过逻辑顺序实现的相临关系
(3)每个节点中,既存储了元素,又存储了相临节点的地址,通过地址实现前后的逻辑顺序
3、特点:
(1)查询速度慢:需要根据前面的节点来获取后一个节点的地址,前面所有的节点都要访问一遍,节点数量越多,查询速度越慢
(2)增删速度快:增加或者删除一个元素,只需要修改相邻接点中的地址即可
4、LinkedList特有的方法:由于底层的特性,专门针对性的提供了在头部尾部增删的操作:
(1)addFirst(Object obj) 将指定元素插入到列表头部
(2)addLast(Object obj) 将指定元素插入到列表尾部
(3)removeFirst() 删除头部元素并且返回
(4)removeLast() 删除尾部元素并且返回
(5)getFirst() 返回头部元素
(6)getLast() 返回尾部元素

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿福真的不想掉头发

大爷?赏点?

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值