《Java从入门到放弃》JavaSE入门篇:集合

今天来讲讲Java中的集合和常见集合类型的使用。

什么是集合呢?

刚好最近学校里面军训,只听到教官一声喊:“集合!!!”各位小萌新们就屁颠屁颠的跑过来排列整齐了,这就是集合···

Java中的集合也是一样的意思,Java一声喊:“集合!!!”,那么我们就把需要放在一起的数据放到一个集合中。有的人会说“数组不就有这个功能么”。是的,数组是有这个功能,但集合与数组相比,功能会更多些,而且不同的集合侧重点不一样,具体有哪些优势,我们接下来讲解。

集合与数组最大的区别:集合的长度是不固定的,可以任意添加或删除元素,而数组的长度是固定的,超过了放不进去数据,删除了数据但位置还在。

Java当中的集合提供了一系列的接口和类,都在java.util包中:


一、Collection接口中的通用方法如下:

    Collection接口下又分为List接口和Set接口,它们的区别如下:

List接口:存储有序,可以保存重复元素

    Set接口: 存储无序,不能保存重复元素

List的用法:

    list最常用的子类——ArrayList。

public static void main(String[] args) {
	List list = new ArrayList();
	list.add("111");
	list.add("aaa");
	list.add("222");
	list.add("bbb");
	list.add("555");
	list.add("abc");
	
	for (int i = 0; i < list.size(); i++) {
		System.out.println(list.get(i));
	}
}

Set的用法:

    Set最常用的子类——HashSet。

public static void main(String[] args) {
	Set list = new HashSet();
	list.add("111");
	list.add("aaa");
	list.add("222");
	list.add("bbb");
	list.add("555");
	list.add("abc");
	
	for (Object object : list) {
		System.out.println(object);
	}
}

List因为是有序的,所以有对应的get方法根据下标读取数据,而Set是无序的,所以只能遍历来得到数据。下图左边为List的遍历结果,右边为Set的遍历结果。

至于删除数据和添加相同数据,各位看官就自己测试一下吧,没什么好讲的了。


二、Map接口中的通用方法如下:

    Map下面最常用的子类有HashMap和Hashtable。

    Map集合是采用键值对的形式来保存数据的,所以很明显,它也没有顺序,这个东西和我们生活中使用的字典类似(根据拼音或部首去查对应的字)。

    HashMap和Hashtable的区别:HashMap允许出现空键或空值。而Hashtable则相反。

	public static void main(String[] args) {
		Map map = new HashMap();
		map.put("wang", "王九蛋");
		map.put("yang", "杨羊洋");
		map.put("li", null);
		map.put(null, "钱列先");
		
		for (Object key : map.keySet()) {
			System.out.println(key+":"+map.get(key));
		}
	}

运行结果:

使用Hashtable效果:


实现开发中,大部分场合我们都使用的泛型集合,它与普通集合相比,其优点是在保存数据之前就要指定数据的类型,否则就不允许你放进去!!!

OK,今天的集合入门就讲到这儿,小伙们可以把上一篇布置的任务使用本篇的集合来实现看看(不再使用数组)。具体集合怎么用,等后面那个综合练习中再来仔细分析。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏编程直播室

读书笔记:《算法图解》第二章 选择排序选择排序:#

1764
来自专栏Android知识点总结

再见kotlin--02函数

612
来自专栏恰同学骚年

剑指Offer面试题:9.二进制中1的个数

  一个基本的思路:先判断整数二进制表示中最右边一位是不是1。接着把输入的整数右移一位,此时原来处于从右边数起的第二位被移到最右边了,再判断是不是1。这样每次移...

642
来自专栏算法channel

程序员必看:实现栈有这两种策略,有完整分析和代码实现

这两篇中分别总结了程序的时间性能度量指标,典型的时间复杂度类型,Java中类型的空间消耗的量化情况。后一篇考虑计算机中最重要的基础算法查找和排序算法,这篇可以说...

930
来自专栏CodingBlock

Java数据结构和算法总结-字符串相关高频面试题算法

前言:周末闲来无事,在七月在线上看了看字符串相关算法的讲解视频,收货颇丰,跟着视频讲解简单做了一下笔记,方便以后翻阅复习同时也很乐意分享给大家。什么字符串在算...

2920
来自专栏Java帮帮-微信公众号-技术文章全总结

第十一天 面向对象-接口多态【悟空教程】

1394
来自专栏Android相关

Kotlin---扩展

通过data关键字来定义数据类。通常用来定义纯数据类型的结构体。定义的数据类只能有一个主构造函数定义该数据类中的变量。而在该类中,可以定义函数

613
来自专栏Java技术栈

Java 10 实战第 1 篇:局部变量类型推断

现在 Java 9 被遗弃了直接升级到了 Java 10,之前也发过 Java 10 新特性的文章,现在是开始实战 Java 10 的时候了。

944
来自专栏专注研发

poj-1056-IMMEDIATE DECODABILITY(字典)

An encoding of a set of symbols is said to be immediately decodable if no code f...

711
来自专栏noteless

正确重写hashcode hashcode与equals方法 集合元素如何判断是否相等 集合如何查看是否包含某个元素

相等的两个对象,即equals(Object)方法判断两个对象相等,那么他们必须要有相同的hashcode

1161

扫码关注云+社区