Java-ArrayList
package 集合类.list类; /**
* System.Collections.ArrayList类是一个特殊的数组。通过添加和删除元素,就可以动态改变数组的长度。 一.优点 1。支持自动改变大小的功能
2。可以灵活的插入元素
3。可以灵活的删除元素
* @author jjj
* 注意,里面的元素是可以重复的,如果元素是new出来的一些对象的话,实际上元素只是对象的引用
*/
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Iterator;
import java.util.List; public class ArrayList类 { /**
* 老紫竹JAVA提高教程(7)-认识List列表之ArrayList<br>
*
* @author 老紫竹 JAVA世纪网(java2000.net)
*
*/ public static void main(String[] args) {
testNormal();
testSpecial();
// 一个最常见的错误
testForProblem();
} public static void testNormal() {
// -------------------------------------------------------
// 声明一个列表
// 允许放入任何数据
// -------------------------------------------------------
ArrayList list = new ArrayList();
// 放入整数
// 当然你用 new Integer(1)也可以
list.add(1);
// 放入字符串
list.add("abc");
// 放入浮点数
list.add(new Float(1.11));
// add会将数据保存到列表的尾部
showList(list); // 1, abc, 1.11] // 下面我们在列表的头部增加数据
list.add(0, 2);
list.add(0, "bcd");
list.add(0, new Double(2.34));
// 列表可以指定插入的位置
// 0 是头部第一个位置,所以数据都逐个放到最前面了
showList(list); // [2.34, bcd, 2, 1, abc, 1.11] // 下面我们插入到我们希望的任何位置
// 当然不能越界,(0 到 list.size()-1)范围内才可以
list.add(1, 3);
list.add(4, "xyz");
// 数据被放到了正确的位置
showList(list); // [2.34, 3, bcd, 2, xyz, 1, abc, 1.11] // -------------------------------------------------------
// 我们有了数据,我们来测试读取数据
// -------------------------------------------------------
// 我们可以通过指定索引的位置,来拿到我们希望的数据
System.out.println(list.get(0)); // 2.34
System.out.println(list.get(4)); // xyz // -------------------------------------------------------
// 测试是否存在某个数据
// -------------------------------------------------------
System.out.println(list.contains("xyz")); // true // 测试是否包含一组数据
Collection c = new ArrayList();
c.add(1);
c.add(2);
System.out.println(list.containsAll(c)); // true
c.add(3);
c.add(4);
// containsAll_1234=false
System.out.println(list.containsAll(c)); // false // -------------------------------------------------------
// 查找某个数据所在的索引位置
// 如果不存在,返回-1
// -------------------------------------------------------
System.out.println(list.indexOf(3)); // 1
System.out.println(list.indexOf("xyz")); // 4
System.out.println(list.indexOf("abcd")); // -1 // -------------------------------------------------------
// 测试删除数据
// 请注意,
// 如果你使用整数(int)数字,则默认调用的是remove(int index);
// 如果你用 long,则会调用 remove(Object obj);
// 所以如果你要删除整数,请使用 remove(new Integer(int));
// -------------------------------------------------------
// 删除索引为1的数据
list.remove(1);
// 索引为1的数据被干掉了
showList(list); // [2.34, bcd, 2, xyz, 1, abc, 1.11] // 删除数字1 和字符串 abc
list.remove(new Integer(1));
list.remove("xyz");
showList(list); // [2.34, bcd, 2, abc, 1.11] // -------------------------------------------------------
// 迭代器的使用
// -------------------------------------------------------
Iterator it = list.iterator();
while (it.hasNext()) {
System.out.print(it.next() + " "); // 2.34 bcd 2 abc 1.11
}
System.out.println(); // -------------------------------------------------------
// 转化为数组
// -------------------------------------------------------
Object[] objs = list.toArray();
for (Object obj : objs) {
System.out.print(obj + " "); // 2.34 bcd 2 abc 1.11
}
System.out.println();
} public static void testSpecial() {
// -------------------------------------------------------
// 测试重复和null
// -------------------------------------------------------
//
List<Integer> list = new ArrayList<Integer>();
list.add(123);
list.add(456);
list.add(123);
list.add(456);
// 数据允许重复
showList(list); // [123, 456, 123, 456] list.add(null);
list.add(789);
list.add(null);
list.add(999);
// 允许放入多个null
showList(list); // [123, 456, 123, 456, null, 789, null, 999] // -------------------------------------------------------
// 测试一下查找最后一次出现的位置
// -------------------------------------------------------
System.out.println(list.indexOf(123)); // 0
System.out.println(list.lastIndexOf(123)); // 2 // -------------------------------------------------------
// 转化为数组
// 记得要转化为Inerger.
// -------------------------------------------------------
Integer[] nums = (Integer[]) list.toArray(new Integer[0]);
// 注意数据里面有null,所以循环变量不要用int 要用Integer
for (Integer num : nums) {
System.out.print(num + " "); // 123 456 123 456 null 789 null 999
}
System.out.println(); } public static void testForProblem() {
// 一些朋友在向循环里向列表增加对象的时候
// 经常忘记初始化,造成最终加入的都是同一个对象
List<MyObject> list = new ArrayList<MyObject>();
MyObject obj = new MyObject();
for (int i = 1; i <= 5; i++) {
obj.setName("Name" + i);
list.add(obj);
}
// 里面的数据都是最后一个
showList(list); // [Name5, Name5, Name5, Name5, Name5] // 正确的做法
List<MyObject> list2 = new ArrayList<MyObject>();
MyObject obj2 = null;
for (int i = 1; i <= 5; i++) {
obj2 = new MyObject();
obj2.setName("Name" + i);
list2.add(obj2);
}
// 里面的数据都是最后一个
showList(list2); // [Name1, Name2, Name3, Name4, Name5]
} /**
* 显示List里面的数据。
*
* @param list
*/
private static void showList(List list) {
System.out.println(Arrays.toString(list.toArray()));
}
} class MyObject {
private String name; public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} /**
* 重写toString方法,输出name
*/
public String toString() {
return name;
}
}
Java-ArrayList的更多相关文章
- Java ArrayList、Vector和LinkedList等的差别与用法(转)
Java ArrayList.Vector和LinkedList等的差别与用法(转) ArrayList 和Vector是采取数组体式格式存储数据,此数组元素数大于实际存储的数据以便增长和插入元素,都 ...
- 浅析 java ArrayList
浅析 java ArrayList 简介 容器是java提供的一些列的数据结构,也可以叫语法糖.容器就是用来装在其他类型数据的数据结构. ArrayList是数组列表所以他继承了数组的优缺点.同时他也 ...
- Java ArrayList中对象的排序 (Comparable VS Comparator)
我们通常使用Collections.sort()方法来对一个简单的数据列表排序.但是当ArrayList是由自定义对象组成的,就需要使用comparable或者comparator接口了.在使用这两者 ...
- Java ArrayList源码剖析
转自: Java ArrayList源码剖析 总体介绍 ArrayList实现了List接口,是顺序容器,即元素存放的数据与放进去的顺序相同,允许放入null元素,底层通过数组实现.除该类未实现同步外 ...
- Java ArrayList 源代码分析
Java ArrayList 之前曾经参考 数据结构与算法这本书写过ArrayList的demo,本来以为实现起来都差不多,今天抽空看了下jdk中的ArrayList的实现,差距还是很大啊 首先看一下 ...
- Java ArrayList trimToSize()
前几天看了Java ArrayList,没有明白trimToSize()这个方法是什么意思,所以看了一下源码并且debug一下自己的一个例子,明白了其中的含义.贴在这里. ArrayList al = ...
- jdk 1.8下 java ArrayList 添加元素解析
转载请注明http://www.cnblogs.com/majianming/p/8006452.html 有人问我,java ArrayList底层是怎么实现的?我就回答数组,他再问我,那它是怎么实 ...
- Java ArrayList【笔记】
Java ArrayList[笔记] ArrayList ArrayList基本结构 ArrayList 整体架构比较简单,就是一个数组结构 源码中的基本概念 index 表示数组的下标,从 0 开始 ...
- JAVA - ArrayList是否会越界?
JAVA - ArrayList是否会越界? ArrayList并发add()可能出现数组下标越界异常. ArrayList是实现了基于动态数组的数据结构. LinkedList是基于链表的数据结构 ...
- 【简易版】Java ArrayList(增删改查)
1.什么是ArrayList ArrayList就是传说中的动态数组,用MSDN中的说法,就是Array的复杂版本,它提供了如下一些好处: (1)动态的增加和减少元素 (2)实现了ICollectio ...
随机推荐
- 边工作边刷题:70天一遍leetcode: day 77
Paint House I/II 要点:这题要区分房子编号i和颜色编号k:目标是某个颜色,所以min的list是上一个房子编号中所有其他颜色+当前颜色的cost https://repl.it/Chw ...
- 边工作边刷题:70天一遍leetcode: day 85-1
Inorder Successor in BST 要点:这题要注意的是如果不是BST,没法从树结构上从root向那边找p,只能遍历.而根据BST,可以只走正确方向 如果不检查right子树,可以从ro ...
- 第51课 C++对象模型分析(下)
1. 单继承对象模型 (1)单一继承 [编程实验]继承对象模型初探 #include <iostream> using namespace std; class Demo { protec ...
- Android自定义进度条颜色
这个没法了只能看源码了,还好下载了源码, sources\base\core\res\res\ 下应有尽有,修改进度条颜色只能找progress ,因为是改变样式,首先找styles.xml ? 1 ...
- Android Studio系列教程五--Gradle命令详解与导入第三方包
Android Studio系列教程五--Gradle命令详解与导入第三方包 2015 年 01 月 05 日 DevTools 本文为个人原创,欢迎转载,但请务必在明显位置注明出处!http://s ...
- static,静态关键字的详解
一,使用static声明属性 class Person{ // 定义Person类 String name ; // 定义name属性,暂时不封装 int age ; // 定义age属性,暂时不封装 ...
- EmberJS路由详解
配置路由器,ember中是根据路径寻找与路由名相对应的模板和控制器的,比如当访问http://localhost:80/这个网址的时候,ember框架会自动寻找与路由名post相对应的PostTemp ...
- 七、Block 封装代码
1.概念:封装代码块,调用的时候使用 2.声明 返回类型(^名字)(参数1,参数2..) = (参数类型 变量1,参数类型, 变量2){ }; int (^Sum)(int,int) = ^(int ...
- Linux Linux共享库
so文件在linux中为共享库,与windows下的dll类似. so文件中的函数可供多个进程调用,最大可能的提供二进制代码复用. 共享库可以使代码的维护工作大大简化,当修正了一些错误或者添加了新特性 ...
- react native 布局注意点
一.react native中很多是ES6语法. 1行.表示是js的严格模式. 'use strict';严格模式中变量必须先声明,然后赋值.定义等:还有就是this的绑定. 2行到8行.导入依赖,可 ...