java集合框架之ArrayList
参考http://how2j.cn/k/collection/collection-arraylist/363.html
使用数组的局限性
一个长度是10的数据:Hero[] heroArr=new Hero[10];
如果用数组存放数据,那么超过10的数据就放不下了
如果数据不足10个,那么数组空间就浪费了
package collection; import charactor.Hero; public class TestCollection {
public static void main(String[] args) {
//数组的局限性
Hero heros[] = new Hero[];
//声明长度是10的数组
//不用的数组就浪费了
//超过10的个数,又放不下
heros[] = new Hero("盖伦");
//放不下要报错
heros[] = new Hero("提莫"); } }
ArrayList存放对象
ArrayList实现了接口List
常见的写法会把引用声明为接口List类型
注意:是java.util.List,而不是java.awt.List
List heros =
new
ArrayList();
为了解决数组的局限性,引入容器类的概念。 最常见的容器类就是
ArrayList
容器的容量"capacity"会随着对象的增加,自动增长
只需要不断往容器里增加英雄即可,不用担心会出现数组的边界问题。
package collection; import java.util.ArrayList; import charactor.Hero; public class TestCollection {
@SuppressWarnings("rawtypes")
public static void main(String[] args) {
//容器类ArrayList,用于存放对象
ArrayList heros = new ArrayList();
heros.add( new Hero("盖伦"));
System.out.println(heros.size()); //容器的容量"capacity"会随着对象的增加,自动增长
//只需要不断往容器里增加英雄即可,不用担心会出现数组的边界问题。
heros.add( new Hero("提莫"));
System.out.println(heros.size()); } }
增加
add 有两种用法
第一种是直接add对象,把对象加在最后面
heros.add(new Hero("hero " + i)); 第二种是在指定位置加对象
heros.add(, specialHero);
获取指定位置的对象
通过get获取指定位置的对象,如果输入的下标越界,一样会报错
package collection; import java.util.ArrayList; import charactor.Hero; public class TestCollection {
public static void main(String[] args) {
ArrayList heros = new ArrayList(); // 初始化5个对象
for (int i = ; i < ; i++) {
heros.add(new Hero("hero " + i));
}
Hero specialHero = new Hero("special hero");
heros.add(specialHero); //获取指定位置的对象
System.out.println(heros.get());
//如果超出了范围,依然会报错
System.out.println(heros.get()); } }
获取对象所处的位置
indexOf用于判断一个对象在ArrayList中所处的位置
与contains一样,判断标准是对象是否相同,而非对象的name值是否相等
package collection; import java.util.ArrayList; import charactor.Hero; public class TestCollection {
public static void main(String[] args) {
ArrayList heros = new ArrayList(); // 初始化5个对象
for (int i = ; i < ; i++) {
heros.add(new Hero("hero " + i));
}
Hero specialHero = new Hero("special hero");
heros.add(specialHero); System.out.println(heros);
System.out.println("specialHero所处的位置:"+heros.indexOf(specialHero));
System.out.println("新的英雄,但是名字是\"hero 1\"所处的位置:"+heros.indexOf(new Hero("hero 1"))); }
}
删除
remove用于把对象从ArrayList中删除
remove可以根据下标删除ArrayList的元素
heros.remove(); 也可以根据对象删除
heros.remove(specialHero);
替换
set用于替换指定位置的元素
package collection; import java.util.ArrayList; import charactor.Hero; public class TestCollection {
public static void main(String[] args) {
ArrayList heros = new ArrayList(); // 初始化5个对象
for (int i = ; i < ; i++) {
heros.add(new Hero("hero " + i));
}
Hero specialHero = new Hero("special hero");
heros.add(specialHero); System.out.println(heros);
System.out.println("把下标是5的元素,替换为\"hero 5\"");
heros.set(, new Hero("hero 5"));
System.out.println(heros);
}
}
获取大小
size 用于获取ArrayList的大小
转换为数组
toArray可以把一个ArrayList对象转换为数组。
需要注意的是,如果要转换为一个Hero数组,那么需要传递一个Hero数组类型的对象给toArray(),这样toArray方法才知道,你希望转换为哪种类型的数组,否则只能转换为Object数组
Hero hs[] = (Hero[])heros.toArray(new Hero[]{});
package collection; import java.util.ArrayList; import charactor.Hero; public class TestCollection {
public static void main(String[] args) {
ArrayList heros = new ArrayList(); // 初始化5个对象
for (int i = ; i < ; i++) {
heros.add(new Hero("hero " + i));
}
Hero specialHero = new Hero("special hero");
heros.add(specialHero);
System.out.println(heros);
Hero hs[] = (Hero[])heros.toArray(new Hero[]{});
System.out.println("数组:" +hs); }
}
把另一个容器所有对象都加进来
package collection; import java.util.ArrayList; import charactor.Hero; public class TestCollection {
public static void main(String[] args) {
ArrayList heros = new ArrayList(); // 初始化5个对象
for (int i = ; i < ; i++) {
heros.add(new Hero("hero " + i));
} System.out.println("ArrayList heros:\t" + heros); //把另一个容器里所有的元素,都加入到该容器里来
ArrayList anotherHeros = new ArrayList();
anotherHeros.add(new Hero("hero a"));
anotherHeros.add(new Hero("hero b"));
anotherHeros.add(new Hero("hero c"));
System.out.println("anotherHeros heros:\t" + anotherHeros);
heros.addAll(anotherHeros);
System.out.println("把另一个ArrayList的元素都加入到当前ArrayList:");
System.out.println("ArrayList heros:\t" + heros); }
}
清空
clear 清空一个ArrayList,heros.clear();
做一个一样的MyStringBuffer练习,但是不使用字符数组,而是使用ArrayList来实现
package Test; import java.util.ArrayList; /**
* @Auther: 李景然
* @Date: 2018/5/23 15:56
* @Description:做一个一样的MyStringBuffer练习,但是不使用字符数组,而是使用ArrayList来实现
*/
public class MyStringBufferTest{
ArrayList sb = new ArrayList(); public MyStringBufferTest() {
} public MyStringBufferTest(String string) {
this.append(string);
} public static void main(String[] args) {
MyStringBufferTest sb = new MyStringBufferTest("there light");
System.out.println(sb);
sb.insert(0, "let ");
System.out.println(sb); sb.insert(10, "be ");
System.out.println(sb);
sb.insert(0, "God Say:");
System.out.println(sb);
sb.append("!");
System.out.println(sb);
sb.append('?');
System.out.println(sb); sb.reverse();
System.out.println(sb); sb.reverse();
System.out.println(sb); sb.delete(0, 4);
System.out.println(sb);
sb.delete(4);
System.out.println(sb); } public void append(String str) {
this.insert(sb.size(), str);
} public void append(char c) {
this.insert(sb.size(), c);
} public void insert(int pos, char b) {
sb.add(pos, String.valueOf(b));
} public void insert(int pos, String b) {
if (pos < 0 || pos > sb.size()) throw new RuntimeException("角标越界");
if (b.equals("")) throw new IllegalArgumentException("请勿输入空字符串");
for (int i = pos; i < b.length(); i++) {
sb.add(i, b.charAt(i - pos));
}
} public void delete(int start) {
this.delete(start, sb.size());
} public void delete(int start, int end) {
for (int i = start; i < end; i++) {
sb.remove(i);
}
} public void reverse() {
for (int i = 0; i <= sb.size() - i; i++) {
char c = (char) sb.indexOf(i);
sb.set(i, sb.indexOf(sb.size() - i));
sb.set(sb.size() - i, c);
}
} public int length() {
return sb.size();
} public String toString() {
return sb.toString();
}
}

泛型 Generic
不指定泛型的容器,可以存放任何类型的元素
指定了泛型的容器,只能存放指定类型的元素以及其子类
//对于不使用泛型的容器,可以往里面放英雄,也可以往里面放物品
List heros = new ArrayList(); heros.add(new Hero("盖伦")); //本来用于存放英雄的容器,现在也可以存放物品了
heros.add(new Item("冰杖"));
遍历
用for循环遍历
for (int i = ; i < heros.size(); i++) {
Hero h = heros.get(i);
System.out.println(h);
}
迭代器遍历
package collection; import java.util.ArrayList;
import java.util.Iterator;
import java.util.List; import charactor.Hero; public class TestCollection { public static void main(String[] args) {
List<Hero> heros = new ArrayList<Hero>(); //放5个Hero进入容器
for (int i = ; i < ; i++) {
heros.add(new Hero("hero name " +i));
} //第二种遍历,使用迭代器
System.out.println("--------使用while的iterator-------");
Iterator<Hero> it= heros.iterator();
//从最开始的位置判断"下一个"位置是否有数据
//如果有就通过next取出来,并且把指针向下移动
//直达"下一个"位置没有数据
while(it.hasNext()){
Hero h = it.next();
System.out.println(h);
}
//迭代器的for写法
System.out.println("--------使用for的iterator-------");
for (Iterator<Hero> iterator = heros.iterator(); iterator.hasNext();) {
Hero hero = (Hero) iterator.next();
System.out.println(hero);
} } }
用增强型for循环
使用增强型for循环可以非常方便的遍历ArrayList中的元素,这是很多开发人员的首选。
不过增强型for循环也有不足:
无法用来进行ArrayList的初始化
无法得知当前是第几个元素了,当需要只打印单数元素的时候,就做不到了。 必须再自定下标变量。
for (Hero h : heros) {
System.out.println(h);
}
利用迭代器可以删除ArrayList中的元素
Iterator<Hero> i=hList.iterator();
while (i.hasNext()){
Hero h=i.next();
i.remove();
//这样会把ArrayList中的数据删除光
}
下一节LinkedList
java集合框架之ArrayList的更多相关文章
- Java集合框架之ArrayList浅析
Java集合框架之ArrayList浅析 一.ArrayList综述: 位于java.util包下的ArrayList是java集合框架的重要成员,它就是传说中的动态数组,用MSDN中的说法,就是Ar ...
- Java——集合框架之ArrayList,LinkedList,迭代器Iterator
概述--集合框架 Java语言的设计者对常用的数据结构和算法做了一些规范(接口)和实现(具体实现接口的类).所有抽象出来的数据结构和操作(算法)统称为Java集合框架(Java Collection ...
- java集合框架03——ArrayList和源码分析
最近忙着替公司招人好久没写了,荒废了不好意思. 上一章学习了Collection的架构,并阅读了部分源码,这一章开始,我们将对Collection的具体实现进行详细学习.首先学习List.而Array ...
- Java集合框架(一)-ArrayList
大佬理解->Java集合之ArrayList 1.ArrayList的特点 存放的元素有序 元素不唯一(可以重复) 随机访问快 插入删除元素慢 非线程安全 2.底层实现 底层初始化,使用一个Ob ...
- java集合框架05——ArrayList和LinkedList的区别
前面已经学习完了List部分的源码,主要是ArrayList和LinkedList两部分内容,这一节主要总结下List部分的内容. List概括 先来回顾一下List在Collection中的的框架图 ...
- 深入理解java集合框架之---------Arraylist集合 -----添加方法
Arraylist集合 -----添加方法 1.add(E e) 向集合中添加元素 /** * 检查数组容量是否够用 * @param minCapacity */ public void ensur ...
- 深入理解java集合框架之---------Arraylist集合 -----构造函数
ArrayList有三个构造方法 ArrayList有三个常量 1.private transient Object[] elementData (数组); 2.private int size (元 ...
- java集合框架之ArrayList与LinkedList的区别
参考http://how2j.cn/k/collection/collection-arraylist-vs-linkedlist/690.html#nowhere ArrayList和LinkedL ...
- 深入理解java集合框架之---------Arraylist集合
ArrayList简介 ArrayLIst是动态数组,用MSDN的说法就是Array的复杂版本,它提供了动态的增加和减少元素,实现了Collection和List接口,可以灵活的设置数组的大小,要注意 ...
随机推荐
- obj-c编程08:分类和协议
篇文章里我们来聊聊如何扩展一个类的方法和实例变量,我们首先来看一下命名分类如何扩展一个类.在下面的代码中,首先定义一个类Player用来定义普通球员,如果第三方开发者发现普通球员缺少了一些方法,则可以 ...
- AI之微信跳一跳
需要环境:1,Python3.6 2,android手机 3,ADB驱动,下载地址https://adb.clockworkmod.com/ 步骤: 配置Python3,ADB安装目录到环境变量pat ...
- jquery性能优化的38个建议
一.注意定义jQuery变量的时候添加var关键字 这个不仅仅是jQuery,所有javascript开发过程中,都需要注意,请一定不要定义成如下: $loading = $('#loading'); ...
- Storm 常用命令
1.启动Nimbus bin/storm nimbus & 2.启动Supervisor bin/storm supervisor & 3.启动UI bin/storm ui & ...
- Python循环依赖问题的解决
一个是把某个import移到代码中间,使原先的循环依赖圈打开.
- PHP基础(一)--字符串函数大盘点(基础篇)
参考地址http://php.net/manual/zh/ref.strings.php addcslashes - 以 C 语言风格使用反斜线转义字符串中的字符 string addcslas ...
- c#与webapi交互
public static string HttpConnectToServer(string ServerPage,string strData) { string postData =strDat ...
- Java开源生鲜电商平台-系统架构与技术选型(源码可下载)
Java开源生鲜电商平台-系统架构与技术选型(源码可下载) 1. 硬件环境 公司服务器 2. 软件环境 2.1 操作系统 Linux CentOS 6.8系列 2.2 反向代理/web服务器 ...
- SVD的概念以及应用
第十四章 利用SVD简化数据 一.引言 SVD的全称是奇异值分解,SVD的作用是它能够将高维的数据空间映射到低维的数据空间,实现数据约减和去除噪声的功能. SVD的特点主要有以下几个方面: 1.它的优 ...
- java 字符串池【转】
java 字符串池 java运行环境有一个字符串池.比如String str="abc"时,会首先查看字符串池中是否存在字符串"abc",如果存在则直接将&qu ...