java集合-1

简介: -

Collection体系

  • Collection:代表一组任意类型的对象
  • List:有序、有下标、元素可重复
  • ArrayList 【重点】
  • 数组结构实现,必须要连续空间,查询快、增删慢
  • jdk1.2版本,运行效率块、线程不安全
  • Vector
  • 数组结构实现,查询快、增删慢
  • jdk1.0版本,运行
  • LinkedList
  • 双向链表结构实现,无需连续空间,增删快,查询慢
  • Set

Collection父接口

特点:代表一组任意类型的对象

删除时只能靠元素,不能靠下标

常用方法

/**

* @author 伍六七

* @date 2022/8/12 19:37

*/

public class collection_demo {

   public static void main(String[] args) {

       //0创建集合

       Collection collection = new ArrayList();

       System.out.println(collection);//[]

       

       

       //1添加元素

       collection.add("1");

       collection.add("1");

       collection.add("2");

       System.out.println(collection);//[1, 1, 2]

       

       

       //2删除元素

       collection.remove("1");

       System.out.println(collection);//[1, 2]

       collection.clear();//[]

       System.out.println(collection);

       

       

       //3遍历

       //增强遍历

       for(Object o : collection){

           System.out.println(o);

       }

       

       //迭代器

       Iterator iterator = collection.iterator();

       while (iterator.hasNext()){

           String o = (String) iterator.next();

           System.out.println(o);

       }

       

       //4判断

       System.out.println(collection.contains("1"));//true

       System.out.println(collection.isEmpty());//false

   }

}


JDK的集合工具类

Collection的集合工具类

/**

* @author 伍六七

* @date 2022/8/13 18:24

*/

public class collections_tool {

   public static void main(String[] args) {

       ArrayList collection = new ArrayList();

       collection.add(4);

       collection.add(2);

       collection.add(3);

       collection.add(1);

       ArrayList collection2 = new ArrayList();

       collection2.add(5);

       collection2.add(5);

       collection2.add(5);

       collection2.add(5);

       ArrayList list = new ArrayList();

       ArrayList list2 = new ArrayList();

       list2.add(2);

       list2.add(2);

       list.addAll(collection);



       //将指定元素添加到指定集合

       Collections.addAll(collection,1,2,3,4);

       System.out.println(collection);


       //最大-比较器可以作为第二个参数决定规则

       System.out.println(Collections.max(collection));


       //最小-比较器可以作为第二个参数决定规则

       System.out.println(Collections.min(collection));


       //排序

       Collections.sort(list);

       System.out.println("list"+list);


       //交互指定位置元素

       Collections.swap(list,2,3);

       System.out.println(list);


       //指定元素替换所有元素,初始化

       Collections.fill(list,1);

       System.out.println(list);


       //返回指定元素的个数

       System.out.println(Collections.frequency(collection, 1));


       //两集合没有相同元素,返回true

       System.out.println(Collections.disjoint(collection, collection2));


       //将列表中指定值的所有元素变为另一个

       Collections.replaceAll(list,1,"s");

       System.out.println(list);


       //将列表B的元素覆盖列表A的元素,B比A元素少前提下

       Collections.copy(list,list2);

       System.out.println(list2);

       System.out.println(list);


       //线程安全(不是绝对的线程安全),它是将map的每个方法都加了同步(都加了虚拟锁机制)

       //但是多个方法合在一起还是会线程不安全,建议加上同步机制

       Collections.synchronizedList(new ArrayList<>());

       Collections.synchronizedMap(new HashMap<>());

       Collections.synchronizedSet(new HashSet<>());

   }

}

目录
相关文章
|
7天前
|
Java 大数据 API
Java Stream API:现代集合处理与函数式编程
Java Stream API:现代集合处理与函数式编程
167 100
|
7天前
|
Java API 数据处理
Java Stream API:现代集合处理新方式
Java Stream API:现代集合处理新方式
161 101
|
20天前
|
算法 Java
50道java集合面试题
50道 java 集合面试题
|
3月前
|
存储 安全 Java
常见 JAVA 集合面试题整理 自用版持续更新
这是一份详尽的Java集合面试题总结,涵盖ArrayList与LinkedList、HashMap与HashTable、HashSet与TreeSet的区别,以及ConcurrentHashMap的实现原理。内容从底层数据结构、性能特点到应用场景逐一剖析,并提供代码示例便于理解。此外,还介绍了如何遍历HashMap和HashTable。无论是初学者还是进阶开发者,都能从中受益。代码资源可从[链接](https://pan.quark.cn/s/14fcf913bae6)获取。
207 3
|
2月前
|
Oracle Java 关系型数据库
掌握Java Stream API:高效集合处理的利器
掌握Java Stream API:高效集合处理的利器
341 80
|
2月前
|
安全 Java API
Java 8 Stream API:高效集合处理的利器
Java 8 Stream API:高效集合处理的利器
233 83
|
12天前
|
存储 Java Go
对比Java学习Go——函数、集合和OOP
Go语言的函数支持声明与调用,具备多返回值、命名返回值等特性,结合`func`关键字与类型后置语法,使函数定义简洁直观。函数可作为一等公民传递、赋值或作为参数,支持匿名函数与闭包。Go通过组合与接口实现面向对象编程,结构体定义数据,方法定义行为,接口实现多态,体现了Go语言的简洁与高效设计。
|
1月前
|
存储 缓存 安全
Java集合框架(二):Set接口与哈希表原理
本文深入解析Java中Set集合的工作原理及其实现机制,涵盖HashSet、LinkedHashSet和TreeSet三大实现类。从Set接口的特性出发,对比List理解去重机制,并详解哈希表原理、hashCode与equals方法的作用。进一步剖析HashSet的底层HashMap实现、LinkedHashSet的双向链表维护顺序特性,以及TreeSet基于红黑树的排序功能。文章还包含性能对比、自定义对象去重、集合运算实战和线程安全方案,帮助读者全面掌握Set的应用与选择策略。
144 23
|
1月前
|
存储 缓存 安全
Java集合框架(三):Map体系与ConcurrentHashMap
本文深入解析Java中Map接口体系及其实现类,包括HashMap、ConcurrentHashMap等的工作原理与线程安全机制。内容涵盖哈希冲突解决、扩容策略、并发优化,以及不同Map实现的适用场景,助你掌握高并发编程核心技巧。
|
1月前
|
安全 Java 开发者
Java集合框架:详解Deque接口的栈操作方法全集
理解和掌握这些方法对于实现像浏览器后退功能这样的栈操作来说至关重要,它们能够帮助开发者编写既高效又稳定的应用程序。此外,在多线程环境中想保证线程安全,可以考虑使用ConcurrentLinkedDeque,它是Deque的线程安全版本,尽管它并未直接实现栈操作的方法,但是Deque的接口方法可以相对应地使用。
118 12