java集合

集合类是Java数据结构的实现

Java集合类允许以各种方式将元素分组,并定义了各种使用这些元素更容易操作的方法

Java集合可分为Collection和Map两种体系

Collection接口:Set:元素无序、不可重复的集合;List:元素有序,可重复的集合 - 动态数组

Map接口:具有映射关系“key-value对”的集合

List接口:扩展了Collection接口,具有顺序的集合,元素可以通过其整型下标访问,可以包含重复元素;方法分类:定位方法:get()、set()、add()、remove()、addAll(); 搜索方法:indexOf()和lastIndexOf()[搜索方法不常用]

ListIterator方法:listIterator()和subList()

import java.util.*;

public class ListDemo {

    public static void main(String[] args) {
//        ListDemo.arrayListDemo();
        linkedListDemo();

    }

    public static void linkedListDemo(){
        List<Integer> list = new LinkedList<>();
        //往list中添加
        list.add(6);
        list.add(7);
        list.add(9);
        list.add(87);
        list.add(67);

        list.set(1, 777);
        list.remove(2);

        for (Integer num : list){
            System.out.println(num);
        }


    }

    public static void arrayListDemo(){
        //工作标准写法,一般在前面声明数据类型        List是ArrayList的父类
        List<Integer> list = new ArrayList();//<>里面不能用基本数据类型,要用包装数据类型
        //往list中添加
        list.add(6);
        list.add(7);
        list.add(9);
        list.add(87);
        list.add(67);



        //遍历3 增强型的for
        for (Integer num : list){
            System.out.println(num);
        }

    }


}

Set接口:是Collection的子接口,set接口没有提供额外的方法

Set集合不允许包含相同的元素,如果试把两个相同的元素加入同一个set集合中,则添加操作失败

Set实现类:HashSet

HashSet是Set接口的典型实现,大多数时候使用Set集合时都使用这个实现类

HashSet具有以下特点:不能保证元素的排序顺序;HashSet不是线程安全的;集合元素可以是null

遍历:把一个数组的所有元素全部取出来

package com.yunshen.demo1;

import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Set;

public class SetDemo {
    public static void main(String[] args) {
//set里面不允许有重复元素
        Set<Integer> set = new HashSet();
        set.add(30);
        set.add(38);
        set.add(8);
        set.add(8);
        set.add(27);

        //第一种打印方法
        Iterator<Integer> it = set.iterator();
        while (it.hasNext()){
            Integer next = it.next();
            System.out.println(next);
        }

        System.out.println("-----");
        
        //第二种打印方法
        for (Integer n:set){
            System.out.println(n);
        }

    }

}

 

Map接口:用于保存具有映射关系的数据:Key-Value

关键字唯一,将键映射至值得对象,每个键最多都只能映射至一个值;

基本操作:put()、get()、remove()、containsKey()、containsValue()、size()和isEmpty()

批操作:putAll()和clear()

集合视图:keySet()、values()和entrySet()

键值对:k-v key-value

基本数据类型里面不能存null,如果没有赋值,默认是0;

Map接口常用的实现类:HashMap、TreeMap和Properties

HashMap是Map接口使用频率最高的实现类

允许使用null键和null值,与HashSet一样,不保证映射的顺序

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

public class MapDemo {

    public static void main(String[] args) {
//        hashMapDemo();
        treeMapDemo();//帮你做数据的排序

    }

    public static void treeMapDemo(){
        HashMap<Integer, String> map = new HashMap<>();//第一个是数据类型,第二个是值的类型
        map.put(5, "aa");
        map.put(2, "bb");
        map.put(4, "cc");
        map.put(8, "dd");

        //for加强型
        for (Integer key : map.keySet()){
            String value = map.get(key);
            System.out.println(key + ":" + value);
        }
    }

    public static void hashMapDemo(){
        HashMap<Integer, String> map = new HashMap<>();//第一个是数据类型,第二个是值的类型
        map.put(5, "aa");
        map.put(2, "bb");
        map.put(4, "cc");
        map.put(8, "dd");

        map.put(4, "pp");//
        map.put(10, "cc");//值允许一样,key不允许一样
        map.remove(5);

//        Set<Integer> ks = map.keySet();//把map中的所有key取到Set里面
//        Iterator<Integer> it = ks.iterator();
//        while (it.hasNext()){
//            Integer key = it.next();
//            String value = map.get(key);
//            System.out.println(key + ":" + value);
//        }

        //for加强型
        for (Integer key : map.keySet()){
            String value = map.get(key);
            System.out.println(key + ":" + value);
        }


    }


}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值