
Java集合ArrayList
发布日期:2021-05-07 14:43:32
浏览次数:14
分类:技术文章
本文共 3682 字,大约阅读时间需要 12 分钟。
目录
1 ArrayList类概述【理解】
什么是集合
提供一种存储空间可变的存储模型,存储的数据容量可以发生改变
ArrayList集合的特点
底层是数组实现的,长度可以变化
泛型的使用
用于约束集合中存储元素的数据类型
2 ArrayList类常用方法【应用】
2.1 构造方法
2.2 成员方法
2.3 示例代码
public class ArrayListDemo02 {public static void main(String[] args) {//创建集合ArrayListarray = new ArrayList ();//添加元素array.add("hello");array.add("world");array.add("java");//public boolean remove(Object o):删除指定的元素,返回删除是否成功// System.out.println(array.remove("world"));// System.out.println(array.remove("javaee"));//public E remove(int index):删除指定索引处的元素,返回被删除的元素// System.out.println(array.remove(1));//IndexOutOfBoundsException// System.out.println(array.remove(3));//public E set(int index,E element):修改指定索引处的元素,返回被修改的元素// System.out.println(array.set(1,"javaee"));//IndexOutOfBoundsException// System.out.println(array.set(3,"javaee"));//public E get(int index):返回指定索引处的元素// System.out.println(array.get(0));// System.out.println(array.get(1));// System.out.println(array.get(2));//System.out.println(array.get(3)); //?????? 自己测试//public int size():返回集合中的元素的个数System.out.println(array.size());//输出集合System.out.println("array:" + array);}}
3 ArrayList存储字符串并遍历【应用】
3.1 案例需求
创建一个存储字符串的集合,存储3个字符串元素,使用程序实现在控制台遍历该集合
3.2 代码实现
/*思路:1:创建集合对象2:往集合中添加字符串对象3:遍历集合,首先要能够获取到集合中的每一个元素,这个通过get(int index)方法实现4:遍历集合,其次要能够获取到集合的长度,这个通过size()方法实现5:遍历集合的通用格式*/public class ArrayListTest01 {public static void main(String[] args) {//创建集合对象ArrayListarray = new ArrayList ();//往集合中添加字符串对象array.add("刘正风");array.add("左冷禅");array.add("风清扬");for(int i=0; i
4 ArrayList存储学生对象并遍历【应用】
4.1 案例需求
创建一个存储学生对象的集合,存储3个学生对象,使用程序实现在控制台遍历该集合
4.2 代码实现
//遍历集合,其次要能够获取到集合的长度,这个通过size()方法实现// System.out.println(array.size());//遍历集合的通用格式/*思路:1:定义学生类2:创建集合对象3:创建学生对象4:添加学生对象到集合中5:遍历集合,采用通用遍历格式实现*/public class ArrayListTest02 {public static void main(String[] args) {//创建集合对象ArrayListarray = new ArrayList<>();//创建学生对象Student s1 = new Student("林青霞", 30);Student s2 = new Student("风清扬", 33);Student s3 = new Student("张曼玉", 18);//添加学生对象到集合中array.add(s1);array.add(s2);array.add(s3);//遍历集合,采用通用遍历格式实现for (int i = 0; i < array.size(); i++) {Student s = array.get(i);System.out.println(s.getName() + "," + s.getAge());}}}
5 ArrayList存储学生对象并遍历升级版【应用】
5.1 案例需求
创建一个存储学生对象的集合,存储3个学生对象,使用程序实现在控制台遍历该集合
学生的姓名和年龄来自于键盘录入
5.2 代码实现
/*思路:1:定义学生类,为了键盘录入数据方便,把学生类中的成员变量都定义为String类型2:创建集合对象3:键盘录入学生对象所需要的数据4:创建学生对象,把键盘录入的数据赋值给学生对象的成员变量5:往集合中添加学生对象6:遍历集合,采用通用遍历格式实现*/public class ArrayListTest {public static void main(String[] args) {//创建集合对象ArrayListarray = new ArrayList ();//为了提高代码的复用性,我们用方法来改进程序addStudent(array);addStudent(array);addStudent(array);//遍历集合,采用通用遍历格式实现for (int i = 0; i < array.size(); i++) {Student s = array.get(i);System.out.println(s.getName() + "," + s.getAge());}}/*两个明确:返回值类型:void参数:ArrayList array*/public static void addStudent(ArrayList array) {//键盘录入学生对象所需要的数据Scanner sc = new Scanner(System.in);System.out.println("请输入学生姓名:");String name = sc.nextLine();System.out.println("请输入学生年龄:");String age = sc.nextLine();//创建学生对象,把键盘录入的数据赋值给学生对象的成员变量Student s = new Student();s.setName(name);s.setAge(age);//往集合中添加学生对象array.add(s);}}
6 ArrayList 与 Vector 区别
相同点:
都实现了 List 接口,允许元素重复和为 null 值。
底层都是数组,我们可以按位置索引出某个元素
不同点:
ArrayList 是非同步的,在线程上不安全而 Vector 集合给它的每个 API 都套上了
synchronized,所以 Vector 线程上是安全的。
在添加元素实现扩容的时候,ArrayList 集合存储空间是增长为原来的 1.5 倍。而 Vecto 集合是存储空间增加为原来的 2 倍
PS:其实不考虑线程问题,他两没啥区别。
7 往 ArrayList 集合加入一万条数据,应该怎么提高效率?
ArrayList 的构造方法有三种。当数据量比较大,这里又已经明确是一万条了,我们应该在
初始化的时候就给它设置好容量。
ArrayList 默认容量是 10,如果初始化时一开始指定了容量,或者通过集合作为元素,则容
量为指定的大小或参数集合的大小。每次扩容为原来的 1.5 倍 ,如果使用无参构造器初始容
量只有 10,后面要扩容,扩容又比较伤性能,因为涉及到数组的复制和移动,将原来的数
组复制到新的存储区域中去。
发表评论
最新留言
网站不错 人气很旺了 加油
[***.192.178.218]2025年04月02日 22时17分28秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
1137 第 N 个泰波那契数(迭代、记忆性递归)
2019-03-04
279 完全平方数(dfs)
2019-03-04
279 完全平方数(bfs)
2019-03-04
865 具有所有最深结点的最小子树(递归)
2019-03-04
738 单调递增的数字(找出逆序的位置)
2019-03-04
410 分割数组的最大值(二分查找、动态规划)
2019-03-04
875 爱吃香蕉的珂珂(二分查找)
2019-03-04
693 交替位二进制数(位运算)
2019-03-04
450 删除二叉搜索树中的节点(递归删除节点)
2019-03-04
769 最多能完成排序的块(分析)
2019-03-04
542 01 矩阵(单源bfs、多源bfs)
2019-03-04
1679 K 和数对的最大数目(使用字典对余数分组、排序 + 双指针)
2019-03-04
python测试代码耗时
2019-03-04
桌面图标的自动排列图标
2019-03-04
121 买卖股票的最佳时机(寻找数组中单调递增的序列中最小数字与最大数字--单调栈)
2019-03-04
第十一届蓝桥杯python组第二场省赛-数字三角形
2019-03-04
蓝桥杯四平方和(暴力)
2019-03-04
递归生成重复元素的全排列
2019-03-04
手机号码(数位dp-dfs)
2019-03-04
算法训练 Anagrams问题
2019-03-04