容器(list集合)
--为什么使用集合而不使用数组?why
·集合和数组相似点:都可以存储多个对象,对外作为一个整体存在;
··数组的缺点:1.长度必须在初始化时指定,且固定不变;
2.数组采用连续存储空间,删除和添加元素效率低下;
3.数组无法直接保存映射关系;
Connection 接口存储一组不唯一,无序的对象;
List 接口存储一组不唯一,有序(索引顺序)的对象;
Set接口存储一组唯一,无序的对象;
Map接口存储一组键值对象,提供key到value的映射;
----- Key 唯一,无序; value不唯一,无序;
<List集合>---------------------------------是collection集合的子接口;
特点:有序,不唯一(可重复);
ArrayList:--在内存中分配连续的空间,实现了长度可变的数组;
--优点:遍历元素和随机访问元素的效率表较高;
--缺点:添加和删除需大量移动元素效率低,按照内容查询效率
LinkedList:--采用链表存储方式。
--缺点:遍历和随机访问元素低下。
-- 优点:插入、删除元素效率比较高(但是前提也是必须低效率查询)
集合当中常用到的方法:------增----删----改-----查------
1.添加的方法:add(int index,E e); ---->在制定位置进行添加元素。
addAll(Collection c);---->添加全部。
2.删除的方法:remove(int index);---->根据角标位置删除元素
remove(Object obj);---->根据内容进行删除元素
removeAll(Collection c);---->删除集合
3.修改的方法:set(int index,E element);
4.查询的方法:get(int index);根据角标进行查询元素
------------------------------------
5.获取集合大小的方法---->size();
6.判断集合是否为空的方法---->isEmpty();
7.清除集合当中所有的元素的方法---->clear();
8.集合和数组之间能否转换
集合---------->数组转换 toArray() <T> T[] toArray(T[] a)
迭代器输出的原理:先判断集合当中是否有元素,如果有则进行获取,反之,循环结束。
public class ArrayListTest {
public static void main(String[] args) {
//1.实例化List接口对象
List<String> list = new ArrayList<String>();
//2.添加的方法
list.add("javaSE");
list.add("javaEE");
list.add("HTML5");
list.add("CSS3");
list.add("JavaScript");
//遍历集合元素
System.out.println("---------------标准for循环---------------");
for(int i=0;i<list.size();i++) {
//i变量相当于角标 最大角标:list.size()-1;
//list集合当中存在一个get(int index)
System.out.println(list.get(i)+"\t");
}
System.out.println();
System.out.println("--------------增强for循环---------------");
for (String str : list) {
System.out.println(str+"\t");
}
System.out.println();
System.out.println("--------------迭代输出Iterator---------------");
Iterator<String> iter = list.iterator();
while(iter.hasNext()) {
System.out.println(iter.next()+"\t");
}
}
}
容器(list集合)的更多相关文章
- STL中的set集合容器进行集合运算:并、交、差实例
集合容器的集合运算:并.交.差: #include "stdafx.h" #include <iostream> #include <set> #inclu ...
- multiset集合容器的集合运算:并、交、差
set和multiset的内部通常是采用平衡二叉树来实现.当放入元素时,会按照一定的排序方法自动排序,默认是按照less<>排序规则来排序.这种自动排序的特性加速了元素查找的过程,但问题是 ...
- java基础之容器、集合、集合常用方法
一.容器(Collection):数组是一种容器,集合也是一种容器 java编程中,装其他各种各样的对象(引用类型)的一种东西,叫容器 注意: 1.数组的长度是固定的 2.集合:长度不固定, 可以随时 ...
- Java中的容器(集合)之ArrayList源码解析
1.ArrayList源码解析 源码解析: 如下源码来自JDK8(如需查看ArrayList扩容源码解析请跳转至<Java中的容器(集合)>第十条):. package java.util ...
- Java中的容器(集合)之HashMap源码解析
1.HashMap源码解析(JDK8) 基础原理: 对比上一篇<Java中的容器(集合)之ArrayList源码解析>而言,本篇只解析HashMap常用的核心方法的源码. HashMap是 ...
- Java 容器(集合)
import java.util.*; 一.基础概念 1.什么是容器? 2.为什么需要容器? 3.容器的分类? 二.重点知识 List接口 Collections类 (1)为什么需要? Collect ...
- Java中的容器(集合)
1.Java常用容器:List,Set,Map List: 继承了Collection接口(public interface List<E> extends Collection<E ...
- Set容器--HashSet集合
Set容器特点: ① Set容器是一个不包含重复元素的Collection,并且最多包含一个null元素,它和List容器相反,Set容器不能保证其元素的顺序; ② 最常用的两个Set接口的实 ...
- Python创建容器和集合之源码分析
_collections_abc.py文件中提供了许多抽象基类,这些类将集合分解成许多互相独立的属性集 __all__ = ["Awaitable", "Coroutin ...
- 练习:自己写一个容器ArrayList集合 一一数组综合练习
package cn.bjsxt.myCollection; import java.util.Arrays; /** * 天下文章一大抄,看你会抄不会抄. * 模拟Stringbuilder 写一个 ...
随机推荐
- lager_transform未定义错误
lager_transform未定义错误rebar编译时报错:D:\server\six>d:/tools/rebar/rebar.cmd compile==> mysql (compil ...
- 【并发编程】ThreadPoolExecutor参数详解
ThreadPoolExecutor executor = new ThreadPoolExecutor( int corePoolSize, int maximumPoolSize, long ke ...
- IIS部署WCF报 无法读取配置节“protocolMapping”,因为它缺少节声明
今天写了个wcf的测试程序放在客户的服务器上供他们测试调用,部署到IIS后浏览报错了,根据错误的提示看出似乎是识别不了这个节点名,偶然的去看了下进程池中该站点的进程池名字的高级设置,看到使用的.net ...
- Nginx+PHP-FPM的域Socket配置方法
1什么是域Socket "Unix domain socket 或者 IPCsocket 是一种终端,可以使同一台操作系统上的两个或多个进程进行数据通信.与管道相比,Unix domain ...
- 使用GDAL库中的RPC校正问题
最近将GDAL库更新至1.11版本之后,发现之前写的RPC像方改正模型校正的结果偏差特别大(更新版本之前结果和PCI处理的结果一致).所以初步判断是GDAL库的bug,经过各个参数修改发现原来是指定的 ...
- 【shell脚本】nginx每天自动切割日志脚本
nginx每天日志量比较大的时候,最好每天自动切割,存储,这样可以方面以后的查询和分析 #!/bin/sh ################### #filename: nginx_log_rotat ...
- 海量数据挖掘MMDS week6: MapReduce算法(进阶)
http://blog.csdn.net/pipisorry/article/details/49445519 海量数据挖掘Mining Massive Datasets(MMDs) -Jure Le ...
- ubuntu14下mysql忘记密码的处理
ubuntu14下mysql忘记密码的处理 ubuntu14.04忘记了mysql的用户(root)的密码.接下来: 1) 停止mysql服务 $ sudo stop mysql 2) 启动mysql ...
- 解决bootstrap row span设置border换行的问题
Hadoop方面的毕业设计告一段落了,趁这几天空闲时间认真学习一下之前常使用但是却没用好的Bootstrap. 本文记录Bootstrap框架使用栅格系统时,遇到row内的span设置border换行 ...
- Windows200864位操作系统下的SQLPLUS.EXE 无法找到入口解决办法和Oracle环境变量的设置
本机环境:Windows2008 64位中文版操作系统+Oracle11G+安装了Oracle32位和64位客户端驱动 问题起源:Path环境变量被360安全卫士优化修复后,整个给清空了,hosts文 ...