1.集合与数组存储数据概述:
集合,数组都是对多个数据进行存储操作的结构,简称Java 容器。
说明:此时的存储,主要指的是内存层面的存储,不涉及到持久化的存储(. txt,. jpg,.avi,数据库中)
2.数组存储的特点:
一旦初始化以后,其长度就确定了。
数组- -旦定义好,其元素的类型也就确定了。我们也就只能操作指定类型的数据了。
比如: String[] arr;int[] arr1;object[] arr2;*
3.数组存储的弊端:
*
- :旦初始化以后,其长度就不可修改。
数组中提供的方法非常限,对于添加、删除、插入数据等操作,非常不便,同时效率不高。
获取数组中实际元素的个数的需求,数组没有现成的属性或方法可用
数组存储数据的特点:有序、可重复。对于无序、不可重复的需求,不能病足。
Java集合可以分为Collection和Map体系
Collection接口:单列数据,定义了存取一组对象的方法的集合
————List:元素有序,可重复的集合
————Set:元素无需,不可重复的集合
Map接口:双列数据,保存具有映射关系”key-value对“的集合
ArryList方法实现:
import java.util.ArrayList;
import java.util.Collection;
import java.util.Date;
/*
* 1.集合,数组都是对多个数据进行存储操作的结构,简称java容器此时的存储主要是指内存层面的存储,不涉及持久化的存储(硬盘)
*
*集合框架
* -----Collection接口:单列集合,用来存储一个一个的对象
* --List接口:存储有序的,可重复的数据(使用List替换数组,动态的数组)
* -----ArrayList,LinkedList,Vector
* --Set接口:存储无序的,不可重复的数据(高中讲的“集合”)
* -----HashSet,LinkedSet,TreeSet
* -----Map接口:双列集合,用来存储一对(key-value),一对的数据(高中函数:y=f(x),一个key只能对应一个value,不同的key可以对应一个value)
-----HashMap,LinkedMap,TreeMap,Hashtable,Properties
* * */
public class CollectionTest_1 {
public void test1(){
Collection c1=new ArrayList();
//add(Object e); :将元素e添加到集合c1中
c1.add("ad");
c1.add("ad");
c1.add("as");
c1.add(new Date());
//size():获取添加的元素的个数
System.out.println(c1.size());
//addAll();
Collection c2=new ArrayList();
c1.add("asddf");
c1.add(1156);
c2.addAll(c1);//将c1中的元素添加到c2中
System.out.println(""+c2.size());
System.out.println(c1);
System.out.println(c2);
//isEmpty()判断当前集合是否为空,通过size判断
System.out.println(c1.isEmpty());
//clear()清空集合元素(数据不要了,并不是空指针)
c2.clear();
}
public static void main(String[] args) {
CollectionTest_1 c=new CollectionTest_1();
c.test1();
}
}
import com.sun.org.apache.xpath.internal.objects.XString;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.List;
public class adf {
public void test2(){
Collection coll=new ArrayList();
coll.add(123);
coll.add(456);
System.out.println(coll.size());
coll.add(new String("Tom"));
coll.add(false);
coll.add(new Person("alix",12));
Person p=new Person("woof",15);
coll.add(p);
//2.contains(Object obj):判断当前集合中是否包含obj(判断的是内容是否相同,而不是逻辑地址)
boolean ct=coll.contains(123);
System.out.println(ct);
System.out.println(coll.contains(new String("Tom")));
System.out.println(coll.contains(p));
System.out.println();
Collection coll1= Arrays.asList(123,456);
//containsAll判断形参coll1中的所有元素是否都存在于当前集合中