第八:Java集合框架(下)

本文讨论了ArrayList与LinkedList在不同操作场景下的适用性:对于频繁增删的场景推荐使用LinkedList,而对于频繁查找则推荐使用ArrayList。此外,还介绍了System.arraycopy()方法用于数组复制,并对比了ArrayList与Vector的特点。

一.

当需要频繁进行元素的增加和删除时,最好使用LinkedList,因为其不需要元素的移动,只需要改变前后的引用;

当需要频繁进行元素查找时,最好使用ArrayList,因为其底层采用数组实现,数组是连续存放的,查找速度非常快。

二.

System.arraycopy()--------从指定源数组中复制一个数组,复制从指定的位置开始,到目标数组的指定位置结束。

//数组的复制
public class CopyArray {

	public static void main(String[] args) {
		Integer[] a = new Integer[] { 1, 2, 3, 4, 5, 6 };

		Integer[] b = new Integer[a.length * 2];
		System.arraycopy(a, 0, b, 0, a.length);
		b[6] = 7;//可以看着是数组的扩充
		for (Integer integer : b) {
			System.out.println(integer);
		}
	}

}


三.

ArrayList与Vector的区别

1.ArrayList的所有方法都是非同步的(not synchronized)
2.Vector的很多public方法都是同步的(synchronized)

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值