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) 返回此列表中第一次出现的指定元素的索引;如果此列表不包含该元素,则返回 -1。
int 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子类,模拟栈这种元素结构,先进后出,且从栈中取出元素后必须进行类型转换。都是一种古老的集合类,基本不用。