集合:就是一个容器,放置数据,一般一个集合中放同一类型的数据
集合类中也有很多方法,使用中再熟练即可
集合类的有序性:
添加元素会按照添加的顺序排列;
集合里面的数据可以重复

1. ArrayList

  • get(index):获得指定索引的数据
  • add(object):添加一条数据
  • add(index,element): 插入,在指定位置添加数据
public static void main(String[] args) {
        ArrayList al=new ArrayList();//集合类对象
        al.add("小明");//集合里面数据的添加
        al.add("小华");
        al.add("小林");
        System.out.println(al.get(0));//集合数据的访问,提供索引即可
    }//返回小明
  • addall(collection):添加多条数据

在上面代码基础上

ArrayList al2=new ArrayList();//集合类对象
        al2.addAll(al);
        System.out.println(al2);

输出

[小明, 小华, 小林]
  • 遍历数据,添加for循环

法1: get方法和size方法

for(int i=0;i<al.size();i++){
            System.out.print(al.get(i)+" ");
        }

法2: 引入遍历器Iterator中的next方法,遍历数据,但只能遍历一次

java 测试添加集合 java集合怎么添加数据_数组

Iterator iterator=al.iterator();
        System.out.println(iterator.next());
        System.out.println(iterator.next());
        System.out.println(iterator.next());
        System.out.println(iterator.next());

因为next()方法调用有限次数,如果下一个为空则报错,所以加入while循环

Iterator iterator=al.iterator();

        while(iterator.hasNext()){
            System.out.println(iterator.next());
        }

法3:增强版的for循环

for(Object o:al){//默认Object类型,o为临时变量
           System.out.println(o);
       }

也可以在数组中使用该方法

int[] array=new int[]{1,2,3,4,5};
       int result=0;
       for(int temp:array){
           result+=temp;
       }
        System.out.print(result);//输出15
  • remove(index)和remove(element) 删除指定位置或指定数据
al.remove("小明");
         al.remove(0);
  • isEmpty() 判断是否为空
  • contains() 判断是否包含
  • toArray() 转变成数组,返回的是object类的数组,就可以用数组中的方法进行遍历,取得所有的元素
Object[] ob=al.toArray();//转变成数组之后接下来遍历
        for(int i=0;i<ob.length;i++){
            System.out.print(ob[i]+" ");
        }

但当对其中的元素进行操作时,get获得的是Object类型,所以进行其他操作时需要转变类型
tips:
ArrayList中的所有对象是Object类型,如果要使用的话,要转变成对应的类型

public static void main(String[] args) {
        ArrayList al=new ArrayList();//每一个对象都是object类型
        al.add(1);
        al.add(2);
        al.add(3);
        al.add(555);

        int result=0;
        for(int i=0;i<al.size();i++){
            //result+=al.get(i);错误,get(object),需要转变类型,才能进行其他操作
            result+=(int)al.get(i);//添加的是int类型,所以转换也是int类型
        }
        System.out.println(result);
    }

2. Vector

使用方法同ArrayList
比如遍历数据

public static void main(String[] args) {
        Vector v=new Vector();
        v.add("lina");
        v.add("jack");
        v.addElement(1);
        for(Object o:v){
            System.out.println(o);
        }

和ArrayList区别:
Vector线程较为安全,但性能较低

3. LinkedList

使用方法同ArrayList

  • 比如遍历数据
public static void main(String[] args) {
        LinkedList ll=new LinkedList();
        ll.add(234);
        ll.add(11);

        for(Object o:ll){
            System.out.println(o);
        }
    }
  • 新方法:首位添加数据
ll.addFirst(1);
        ll.addLast(34);
  • 和ArrayList区别

ArrayList内部使用数组进行存储,插入删除数据较慢
LinkedList内部使用链表进行存储,可以方便插入删除数据

Q:集合中泛型怎么使用?

问题:
求和时,每次都需要强制类型转换,很繁琐,如何直接取出int类型数据?

public static void main(String[] args) {
        ArrayList al=new ArrayList();

        al.add(123);
        al.add(344);
        al.add(12);
        al.add(5);

        int result=0;
        for(Object o:al){
            result+=(int)o;//ArrayList存储的是Object类型,所以需要强制类型转换
        }
        System.out.print(result);
    }

解决:
泛型的使用
tips:集合里面只能存储引用类型,存储整型时,会自动对基本类型进行装箱操作,即把基本类型包装成Interger对象;而在数组中,可以存储基本类型和引用类型

public static void main(String[] args) {
        ArrayList<Integer> al=new ArrayList<Integer>();//这个集合里面只能存储int类型,声明整型集合
        al.add(123);//封装成一个Integer对象
        al.add(344);
        al.add(12);
        al.add(5);

        int result=0;
        for(int o:al){//同样声明int类型,不用强制类型转换
            result+=o;
        }
        System.out.print(result);
    }

类似Vector

Vector<String> v=new Vector<String>();
        v.add("wwww");

4. HashSet

  • for循环遍历
public static void main(String[] args) {
        HashSet hs=new HashSet();
        hs.add(1);
        hs.add(2);
        hs.add(3);
        for(Object o:hs){
            System.out.print(o);
        }
    }

5. TreeSet

和其他集合的区别:
ArrayList LinkedList Vector 可添加重复数据,有序
HashSet TreeSet 不可添加重复数据,会自动去重,无序,所以无法通过索引获取某数据,没有get方法

Q:集中中如何存储自定义的类?

  • 以ArrayList存放自定义的类为例

(Student类的setter和getter方法,Student构造方法已给出)

public static void main(String[] args) {
        ArrayList<Student> al=new ArrayList<Student>();//只能存放Student类

        Student s=new Student("lina", "1", "reading");
        al.add(s);//添加一个自定义类的对象
        al.add(new Student("wang", "2", "sleeping"));

        for(Student temp:al){
            System.out.print(temp.getId()+" "+temp.getName()+" "+temp.getHobby());
        }
    }

输出

1 lina reading2 wang sleeping

6:HashMap

  • put方法

无add方法,替代之put方法
以键值对的形式存储 key-value
取值时通过键key来取值,key不能重复(如果相同的key,会把之前的value覆盖)

public static void main(String[] args) {
        HashMap mp=new HashMap();
        mp.put(1, "lina");
        mp.put(2, "mike");
        mp.put(3, "jack");

        System.out.println(mp.get(1));
        System.out.println(mp.get(2));
        System.out.println(mp.get(3));
    }

输出值value,可以重复

lina
mike
jack
  • 遍历

遍历键,返回键的集合(类似set集合)

for(Object key:mp.keySet()){
            System.out.print(key+" "+mp.get(key));
        }

遍历值,返回值的集合
values(),内为collection类型,所以可重复

for(Object value:mp.values()){
            System.out.println(value);
        }
  • 判断

containsKey()
containsValue()
判断是否有某个键或值 返回布尔类型

7:TreeMap

和HashMap使用方法一样,存储上不一样
可指定泛型,比如

TreeMap<Integer,String> tm=new TreeMap<Integer,String>();

8:Hashtable

使用起来和和HashMap几乎一样

9:总结

集合类

  • Collection:存储单个值
    数据有序可以重复(List):ArrayList,LinkedList,Vector
    ArrayList和LinkedList区别在于:ArrayList使用数组进行存储;LinkedList使用链表进行存储,方便进行数据的插入删除。
    Vector和ArrayList区别在于Vector线程安全,性能较低;ArrayList线程不安全,但性能较高。
    数据无序不可重复(Set):HashSet,TreeSet
  • Map:存储键值对
    HashMap,TreeMap,Hashtable
    HashMap和TreeMap的区别在于存储的结构不一样
    HashMap和Hashtable区别在于线程的安全性