Javase0801---集合初讲(List,Colletion)、BigDecimal类、Calendar类、BigInteger类

BigDecimal类

BigDecimal的概述
为了能精确的表示、计算浮点数,Java提供了BigDecimal
构造方法
public BigDecimal(String val)
成员方法
public BigDecimal divide(BigDecimal divisor,int scale,int roundingMode)//scale 小数点后面保留几位
roundingMode 取舍模式 比如四舍五入

Calendar 类

Calendar类的概述
Calendar 类是一个抽象类,不能直接new对象,可以通过他的一个静态成员方法getInstance()来获取他的对象
:成员方法
public static Calendar getInstance() 使用默认时区和语言环境获得一个日历对象
public int get(int field) 获得给定日历字段对应的值 field通过Calendar提供的字段来拿

成员方法
public void add(int field,int amount) 根据日历的规则,为给定的日历字段添加或减去指定的时间量
public final void set(int year,int month,int date) 设置日历时间 年月日

BigInteger 类

可以计算超出 long 范围的数据进行运算,在有些需要精度计算时,可以转化为BigInteger类型。常见构造方法有:

public BigInteger(String val) 举例:

 BigInteger bi1=new BigInteger("100");
 BigInteger bi2=new BigInteger("2");
        
 System.out.println(bi1.add(bi2));   //+
 System.out.println(bi1.subtract(bi2));   //-
 System.out.println(bi1.multiply(bi2));   //*
 System.out.println(bi1.divide(bi2));    //(除)

集合

未来了保存数量不确定的数据,以及保存具有映射关系的数据,Java提供了集合类。由于集合类主要负责保存、盛装其他数据,又被称为容器类。

集合与数组的区别:

​ 数组可以是基本类型,也可以是对象。集合一般是对象。

Collection集合

添加功能
	boolean add(Object obj):添加一个元素
	boolean addAll(Collection c):添加一个集合的元素  
删除功能
	void clear():移除所有元素
	boolean remove(Object o):移除一个元素
	boolean removeAll(Collection c):移除一个集合的元素 删除的元素是两个集合的交集元素 
判断功能
	boolean contains(Object o):判断集合中是否包含指定的元素	
	boolean containsAll(Collection c):判断集合中是否包含指定的集合元素(这个集合 包含 另一个集合中所有的元素才算包含 才返回true)
	boolean isEmpty():判断集合是否为空
获取功能
	Iterator<E> iterator()(重点)
长度功能
	int size():元素的个数
以及部分功能测试:
    toArray() 把一个集合转成数组

List集合

List 集合代表一个元素有序、可重复的集合,集合中每个元素都有其对应的顺序索引。由于List 作为Collection的子接口,所以可以使用父接口的所有方法,而且List是有序可重复集合,所以根据索引来操作集合元素的方法。举例:
    void add(int index,E element):	在指定索引处添加元素
	remove(int index):移除指定索引处的元素  返回的是移除的元素
	get(int index):获取指定索引处的元素
	set(int index,E element):更改指定索引处的元素 返回的而是被替换的元素
	int indexOf(Object o)  返回此列表中第一次出现的指定元素的索引;如果此列表不包含该元素,则返回 -1int lastIndexOf(Object o)  返回此列表中最后出现的指定元素的索引;如果列表不包含此元素,则返回 -1。
    Java 8为List集合增加了 sort()replaceAll()两个常用方法。
    与set 中只提供 Integer方法不同,List还提供一个listIterator方法,增加了如下的方法:
        boolean hasPrevious();返回该迭代器关联的集合是否还有上一个元素
        Object previous(); 返回迭代器的上一个元素
        void  add(Object o);在指定位置插入一个元素
拿ListIterator 和普通的Iteger 进行对比,不难发现ListIterator增加了向前迭代的功能,而且ListIterator还可以通过add()方法向集合中添加元素。举例:
        public static void main(String[] args) {
        String [] books={"JAVAEE","JAVASE","JAVAME"};
        List List =new ArrayList();
        for (int i = 0; i < books.length; i++) {
            List.add(books[i]);
        }
        ListIterator listIterator = List.listIterator();
        while (listIterator.hasNext()) {
            System.out.println(listIterator.next());
        }
        System.out.println("=======反向迭代=======");
        while (listIterator.hasPrevious()) {
            System.out.println(listIterator.previous());
        }
可以看到输出结果:
JAVAEE
JAVASE
JAVAME
=======反向迭代=======
JAVAME
JAVASE
JAVAEE

总结

数据结构中我们学过,数据的存数类型除了数组,还可以是链表。
    数组的特点在于,每次new一个新数组,会在内存中开辟一整块空间,也就是所谓的数组长度固定,
    而链表的存储较为随机,只需要在一个数据后跟一个地址指向下一个数据,这样的==存储方式==也决定了数组和链表增删查改的特点。

数组易查改,查随机查,改直接改。长度固定,不易增删。链表查改难。要从链表索引第一位查起,增删直接改地址索引即可。

List三个子类中

    ArrayList:
		底层数据结构是数组,线程不安全,效率高。
	Vector:
		底层数据结构是数组,线程安全,效率低。
	LinkedList:
		底层数据结构是链表,线程不安全,效率高。    

仔细的讲一下,ArrayList,多个线程访问同一集合时,如果有超过一个线程修改了集合,就必须手动保证集合同步性,相较而言Vector,线程安全,效率低。
另,Vector会提供一个Stack子类,模拟栈这种元素结构,先进后出,且从栈中取出元素后必须进行类型转换。都是一种古老的集合类,基本不用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值