超牛牪犇Java之List特有方法&LinkList和ArrayList

一.List特有方法

add(int index,Object obj)

set(index,obj)

get(int index)

remove(int index)

List list = new ArrayList();
	list.add("a");
	list.add("b");
	list.add("c");
	list.add("d");
	//添加
	//不要超出集合的元素个数(size)
	list.add(0, "x");
	System.out.println(list);
	//设置元素(替换该位置的元素)
	list.set(3, "w");
	System.out.println(list);
	//获取下标处的元素
	Object object = list.get(0);
	System.out.println(object);
	//删除(返回的是删除的元素)
	Object obj = list.remove(0);
	System.out.println(obj);
	//利用get方法遍历集合
	for (int i = 0; i < list.size(); i++) {		
		System.out.println(list.get(i));
}

注意:

List list = new ArrayList();
list.add(111);
list.add(222);
list.add(333);
//删除111这个元素
//系统会当做下标来处理
//没有对这个数进行自动装箱
list.remove(0);
System.out.println(list);

Vector了解一下:

//创建一个Vector(JDK1.0出来的  掌握遍历方法)
	Vector vector = new Vector();
	vector.addElement("a");
	vector.addElement("b");
	vector.addElement("c");
	vector.addElement("d");
	//遍历这个集合
	Enumeration elements = vector.elements();
	while (elements.hasMoreElements()) {
		System.out.println(elements.nextElement());
        }
什么时候使用ArrayList 什么时候使用LinkList?

先要知道两者的特点:

 ArrayList特点:

 查询快 增删慢

 用数组实现的

 查询按下标查询

 增删时  把要删除或增加的元素 后面的所有元素

 向前移动或者向后移动

 LinkList特点:

 查询慢 增删快

 链表实现的

 查询:先看这个元素 离哪一端近 就从哪一端开始一个一个向后(向前)查询 直到找到为止

 增加:链表中的元素 要保证能找到自己的上一个和下一个元素 需要保存上一个和下一个元素的地址

 只要保存了地址 就能找到元素 就相当于插入到了链中 后面的元素不会发生改变

用addFirst模拟入栈出栈:
//队列结构 先进先出
//栈结构 先进后出
//模拟出栈(删除元素)   入栈(添加元素)
		
LinkedList linkedList = new LinkedList();
linkedList.addFirst("a");
linkedList.addFirst("b");
linkedList.addFirst("c");
//出栈 按顺序从栈顶一个一个出
while (!linkedList.isEmpty()) {
	Object o1 = linkedList.removeFirst();
	System.out.println(o1);
	System.out.println(linkedList);
}




  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值