Collection中list集合的应用常见的方法
集合 : 用存放对象的容器(集合)
Collection : 跟接口 : 单列集合
---> List :有序的 ,元素是可以重复的。
---> Set : 无序的 ,元素是不可以重复的。
Collectionz红常用的方法:
增
add();添加一个元素
addAll();A.addAll(B) 将B中的元素添加到A中。
删
remove(Object o); 移除指定的对象。
removeAll(Collection c);A.removeAll(B); 删除A中含有B的元素。
clear(); 清空所有的元素
判断:
contains(Object); 判断集合中是否含有某一个对象。 实际上还是以equals来比较的对象。
如果比较的自定义的对象 这个时候可能需要重写equals和hashCode方法。
containsAll(Collection c); A.containsAll(B);判断A中是否包含有B集合。
isEmpty() : 判断集合是否为空。
将集合转为数组 :
toArray(); 数组是一个对象数组。遍历集合的方法。
集合比数组的优势:
1.集合可以存任意类型的对象,长度的可变的
2.数组只能同一种类型变量,长度是固定的。
3.集合中只能存对象
List集合 : 接口 提供公有的方法
特有的方法:
1.list中的特有方法都是通过下标来操作元素。
查找 :
add(int index, Object o) ; 添加元素到指定的位置。
get(int index);获取集合中指定位置的元素。
set(int index,Object o); 用来修改集合中指定位置元素的值。
迭代器:
作用:操作集合中元素。 可以增删改查
根迭代器 : Iterator 接口 集中获取迭代器 :通过集合中方法来获取。
collection 集合中获取迭代器:iterator();
迭代器中的方法:
hasNext(); 判断当前指针指向的位置是否有元素
next(); 获取当前指针指向的元素,并且指针下移一位
remove(); 移除最后操作时指针指向的元素。
ListIterator :
特有方法:
hasProvious();判断当前指针指向的上一个位置是否存在元素。
provious(); 获取上一个元素。
proviousIndex();获取上一个元素所在的位置。
add(); 在当前指针指向的位置添加一个元素
set(); 修改当前指针指向的元素。
注意点:
1.add 和 set 不能过同时使用。
2.如果你是用了迭代器来操作元素,那么就不用再用集合来操作元素了。
ArrayList : 底层是维护一个Object[]o数组,默认容量是10 ,如果容量不够增加到原来的1.5倍。
优点 : 查找快 ,增删慢。
trimToSize();调整集合的容量和数据保持一致。
ensureCapacity(int minCapacity) 自定容量。
LinkedList : 链接列表实现, 特点:添加元素比较快,查找慢。
Collection中list集合的应用常见的方法的更多相关文章
- python学习之【第七篇】:Python中的集合及其所具有的方法
1.前言 python中的集合set与列表类似,它们最大的区别是集合内不允许出现重复元素,如果在定义时包含重复元素,会自动去重. 集合是无序的,集合中的元素必须是不可变类型.集合可以作为字典的key. ...
- Collection中Set集合在应用中常见的方法和注意点
Set集合 : 元素无序的,元素不允许重复. ---->HashSet : 存值方式使用哈希表来存值的. 原理 : 如果HashSet中存放对象 ...
- Java中List集合去除重复数据的方法
1. 循环list中的所有元素然后删除重复 public static List removeDuplicate(List list) { for ( int i = 0 ; i < list. ...
- Java中List集合去除重复数据的方法1
1. 循环list中的所有元素然后删除重复 public static List removeDuplicate(List list) { for ( int i = ...
- Javascript中数组的定义和常见使用方法
一.定义数组 1.定义数组 var arry=[1,2,'小名',false] //var 数组名=[值1,值2,...] 2.设置数组长度 arry.length=10 //数组长度设置为10 二. ...
- 老出BUG怎么办?游戏服务器常见问题解决方法分享
在游戏开发中,我们经常会遇到一些技术难题,而其引发的bug则会影响整个游戏的品质.女性向手游<食物语>就曾遇到过一些开发上的难题,腾讯游戏学院专家团Wade.Zc.Jovi等专家为其提供了 ...
- 牛客网Java刷题知识点之Java 集合框架的构成、集合框架中的迭代器Iterator、集合框架中的集合接口Collection(List和Set)、集合框架中的Map集合
不多说,直接上干货! 集合框架中包含了大量集合接口.这些接口的实现类和操作它们的算法. 集合容器因为内部的数据结构不同,有多种具体容器. 不断的向上抽取,就形成了集合框架. Map是一次添加一对元素. ...
- java方法中Collection集合的基本使用与方法
集合类的由来,对象用于封闭特有数据,对象多了需要存储,如果对象的个数不确定就使用集合容器进行存储. 集合特点:1.用于存储对象的容器.2.集合的长度是可变的.3.集合中不可以存储基本数据类型值. 集合 ...
- Java基础(40):Java中的集合介绍---Collection与Map
集合类说明及区别Collection├List│├LinkedList│├ArrayList│└Vector│ └Stack└SetMap├Hashtable├HashMap└WeakHashMap ...
随机推荐
- Linux内核源码树建立加载hello模块
在加载模块之前,书中说要先建立内核源码树,那么,如何建立内核源码树呢? 首先,要先知道你的OS的内核版本,用uname -r可以查得到 在/url/src/目录下可以看到对应的版本目录 如果没有可以用 ...
- css3 Gradient背景
css3的gradient分为两种:线性渐变(linear)和径向渐变(radial). 一.线性渐变linear-gradient 1.介绍 linear-gradient([设置方向],[设置开始 ...
- Manacher's algorithm: 最长回文子串算法
Manacher 算法是时间.空间复杂度都为 O(n) 的解决 Longest palindromic substring(最长回文子串)的算法.回文串是中心对称的串,比如 'abcba'.'abcc ...
- 高级c++头文件bits/stdc++.h
用这种方法声明头文件只需两行代码 #include<bits/stdc++.h> using namespace std; 这个头文件包含以下等等C++中包含的所有头文件: #includ ...
- (三)策略模式-C++实现
策略模式:定义一系列算法,把它们一个个封装起来,并且使它们可以相互替换,本模式使得算法可独立于使用它的客户而变化. 三种角色: 1.策略:一个抽象类,这个接口定义了若干个算法标识,即多个虚函数,这些个 ...
- POJ1065Wooden Sticks[DP LIS]
Wooden Sticks Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 21902 Accepted: 9353 De ...
- Android SDK和N多Android开发资源
开发资源 本文收集整理Android开发需要的Android SDK.工具.Android开发教程.Android设计规范,免费的设计素材等. 欢迎大家推荐自己在Android开发过程中用的好用的工具 ...
- 适配ipone5
PROJECT和TARGETS都需要设置
- Android中如何设置RadioButton在文字的右边,图标在左边
from:http://blog.csdn.net/sunnyfans/article/details/7901592?utm_source=tuicool&utm_medium=referr ...
- log4j.properties 详解与配置步骤(转)
找的文章,供参考使用 转自 log4j.properties 详解与配置步骤 一.log4j.properties 的使用详解 1.输出级别的种类 ERROR.WARN.INFO.DEBUGERROR ...