5、数组和集合--Collection、Map
一、数组:同一个类型数据的集合,其实他也是一个容器
1、数组的好处:可以自动给数组中的元素从0开始编号,方便操作这些数据
2、数组的定义:
在Java中常见:
格式1: 类型 [] 数组名 = new 类型[数组长度或数组元素的个数]; 例如: int [] dada = new int[3];
格式2: 类型 [] 数组名 = new 类型[]{值1,值2,值3……}; 例如: int [] data = new int{1,2,3,……};
和上边的意思一模一样,更符合用用过C语言编程的程序员的编程习惯:
格式1: 类型 数组名 [] = new 类型[数组长度或数组元素的个数]; 例如: int dada [] = new int[3];
格式2: 类型 数组名 [] = new 类型[]{值1,值2,值3……}; 例如: int data [] = new int{1,2,3,……};
3、数组的遍历方式:通过属性length获取该数组的元素个数。
使用方式: 数组名称.length
例如:
public static void main(String[] args) {
int data[] = new int[3];
for(int i=0;i<data.length;i++)
data[i]=i;
for(int i=0;i<data.length;i++)
System.out.println("数组data的第"+i+"个数字为"+data[i]);
}
输出结果为:
数组data的第0个数字为0
数组data的第1个数字为1
数组data的第2个数字为2
二、集合-Collection: 分为List、Set两种。
1、List:元素是有序的,元素可以重复,因为该集合体有索引
a)、ArrayList:底层数据结构使用的数据结构。特点是:查询速度快,增删速度慢,线程不同步。
b)、LinkedList:底层使用的链表数据结构。特点查询速度慢,增删速度快,线程不同步。
c)、Vector:底层数据结构,线程同步。
2、Set:元素是无序的,元素不可以重复。
a)、HashSet:d
b)、TreeSet:可以set集合中的元素进行排序,线程不同步。
三、集合-Map
1、Map:存储键值对
a)、HashMap:底层是哈希表数据结构,可以存入null作为键或值,线程不同步
b)、HashTable:底层是哈希表数据结构,不可以存入null作为键或值,线程同步。
c)、TreeMap:底层是二叉树结构,线程不同步。
四、泛型:用于解决安全问题,是一个类型安全机制。
泛型在集合框架中很常见,只要见到<>就要定义泛型
当使用集合时,将集合中要存储的数据类型作为参数传递到<>中即可
五、遍历:即查询集合中的所有元素。
1、利用size()和get()方法获取。因为List是有序的,所以可以用这种分方法来遍历。
@Test
public void Test(){
List<String> list = new ArrayList<String>();
list.add("DDDDD");
list.add("EEEEE");
list.add("FFFFF");
print(list);
//因为list有顺序,利用size()和get()方法获取
for (int i = 0; i < list.size(); i++) {
System.out.println(list.get(i));
}
}
2、利用Iterator迭代器进行遍历
@Test
public void test(){
List list = new LinkedList();
list.add("123");
list.add("456");
Iterator<String> it = list.iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
}
3、增强for循环
@Test
public void test(){
List list = new LinkedList();
list.add("123");
list.add("456");
for(List a : list)
System.out.println(a);
}
4、对于Map的遍历方式
@Test
public void test() {
Map<String,String> map = new TreeMap<String, String>();
map.put("Jerry", "10000");
map.put("shellway", "20000");
map.put("Kizi", "30000");
print(map.entrySet());
//Map的第一种遍历方式:先获得key的集合,再获得值value
Set<String> sett = map.keySet();
for (String s : sett) {
System.out.println(s+":"+map.get(s));
}
//Map的第二种遍历方式:获得键值对
for (Map.Entry<String, String> entry : map.entrySet()) {
System.out.println(entry.getKey()+" : "+entry.getValue());
}
}
五、集合和数组的区别:
1、数组长度是不变的,集合长度是可变的。
2、数组存储相同的类型对象,集合可以存储不同类型的对象。
5、数组和集合--Collection、Map的更多相关文章
- [UE4]换枪需要做的事,容器:数组、集合、Map
换枪: 1.需要同时保存多把枪 2.换下去的枪需要隐藏,而不是销毁 3.换枪应该有动作 4.不同的枪应该有不同的行为 蓝图中常见的容器 1.数组 特点: 1.元素连续存放 2.通过索引访问 3.索引从 ...
- Java集合Collection&Map
Map<K,V>是键值对,K - 此映射所维护的键的类型,V - 映射值的类型.键值是一一对应的关系: Collection是只有键,底层也是由键值对,但是值的类型被隐藏起来. Colle ...
- JAVASE(十四) 集合: 数组和集合、Collection、Iterator、List、Set、Map
个人博客网:https://wushaopei.github.io/ (你想要这里多有) 1.数组和集合 1.1 内存中对数据进行存储和管理的“容器”:数组,集合 1.2 数组存储的特点和缺点 ...
- Java 学习笔记 两大集合框架Map和Collection
两大框架图解 Collection接口 由第一张图,我们可以知道,Collection接口的子接口有三种,分别是List接口,Set接口和Queue接口 List接口 允许有重复的元素,元素按照添加的 ...
- Java学习笔记(2)----散列集/线性表/队列/集合/图(Set,List,Queue,Collection,Map)
1. Java集合框架中的所有实例类都实现了Cloneable和Seriablizable接口.所以,它们的实例都是可复制和可序列化的. 2. 规则集存储的是不重复的元素.若要在集合中存储重复的元素, ...
- Collection集合与Map集合的知识点梳理
在Java中集合分为单列集合(Collection)与双列集合(Map),本文主要对两种集合的常用实现类作一介绍,如果有不足,恳请指教更正. 1.前言 说到集合肯定要介绍下集合的概念与特点:集合是一个 ...
- Java集合 Collection、Set、Map、泛型 简要笔记
集合 什么是集合 概念 对象的容器,实现了对对象常用的操作 和数组的区别 数组长度固定,集合长度不固定 数组可以存储基本类型和引用类型,集合只能存储引用类型 位置 java.util.*; Colle ...
- 零基础学习java------day14-----泛型,foreach,可变参数,数组和集合间的转换,Set,Map,
1.泛型(jdk1.5以后出现) https://www.cnblogs.com/lwbqqyumidi/p/3837629.html#!comments (1)为什么要用泛型? 限制集合,让它只能存 ...
- paip.数组以及集合的操作uapi java php python总结..
paip.数组以及集合的操作uapi 作者Attilax 艾龙, EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn.net/att ...
随机推荐
- Uva11538 排列组合水题
画个图就很容易推出公式: 设mn=min(m,n),mx=max(m,n) 对角线上: 横向:m*C(n,2) 纵向:n*C(m,2) 因为所有的C函数都是只拿了两个,所以可以优化下.不过不优化也过了 ...
- ECSHOP Inject PHPCode Into ecs_mail_templates table Via \admin\mail_template.php && \includes\cls_template.php Vul Tag_PHP_Code Execute Getshell
目录 . 漏洞描述 . 漏洞触发条件 . 漏洞影响范围 . 漏洞代码分析 . 防御方法 . 攻防思考 1. 漏洞描述 Ecshop后台模版编辑漏洞,黑客可以在获得了后台管理员的帐号密码之后,可以通过在 ...
- js实现A*寻路算法
这两天在做百度前端技术学院的题目,其中有涉及到寻路相关的,于是就找来相关博客进行阅读. 看了Create Chen写的理解A*寻路算法具体过程之后,我很快就理解A*算法的原理.不得不说作者写的很好,通 ...
- linux系统安装配置
以中文拼音输入法为例:1.sudo apt install ibus-pinyin2.sudo apt install ibus-libpinyin3.注销重新登录 或则 重启计算机4.进入输入设置, ...
- 为什么要用Markdown写东西
为什么要用Markdown 不用费心去调格式了,比方说题目加粗什么的,删除线什么的,代码也只要四个空格就好了~ 学起来很简单,几乎没什么学习成本,而收益却很大 这几乎快让我我想从cnblog转到简书了 ...
- Windows系统:桌面,开始菜单和工具栏都不见了
win7桌面,开始菜单和工具栏都不见了 ctrl+alt+del 打开任务管理器 然后文件-运行 --- 输入框里输入 explorer.exe 其实就是打开系统文件夹下的(大约是‘windows ...
- HTML5系列四(WebWorker、地理定位)
WebWorker简单应用 先从一个简单例子说起,计算数值加法 <script> var worker = new Worker('sumCalculate.js'); worker.on ...
- java编程思想-java中的并发(二)
二.共享受限资源 有了并发就可以同时做多件事情了.但是,两个或多个线程彼此互相干涉的问题也就出现了.如果不防范这种冲突,就可能发生两个线程同时试图访问同一个银行账户,或向同一个打印机打印,改变同一个值 ...
- c语言程序
汇编语言嵌入到c语言中 #include<stdio.h> int main(void) { int a,b,c; a=4; b=5; _asm { mov eax,a; add eax, ...
- Oracle11g的exp导出空表提示EXP-00011: 不存在
刚lg问我11g无法导出空表,实验了下,果真如此. 原因:11g默认创建一个表时不分配segment,只有在插入数据时才会产生(当然也可以强制分配),以节省磁盘空间. 对于已经存在的空表解决办法: 就 ...