java基础32 List集合下的ArrayList集合
单例集合体系:
---------| collection 单例集合的根接口
--------------| List 如果实现了list接口的集合类,具备的特点:有序,可重复 注:集合中的有序不是指自然顺序,而是指添加进去的顺序与出来的顺序是一致的
------------------| ArrayList ArrayList底层维护了一个object数组的实现的。(线程不安全),特点:查询速度快,增删速度慢。(有序,可重复)
------------------| LinkedList LinkedList底层是使用链表结构实现的,线程不安全,特点:查询速度慢,增删速度快。(有序,可重复)
------------------| Vector(了解即可) 底层也是维护一个Object数组的实现的,实现与ArrayList是一样的,但是Vector是线程安全的,操作效率低
--------------| Set 如果实现了set接口的集合类,具备的特点:无序,不可重复 注:集合中的无序不是指自然顺序,而是指添加元素进去的顺序与元素出来的顺序是不一致的
------------------| HashSet 底层是用于一个哈希表支持的。线程不安全,特点:存储速度块
------------------| TreeSet 底层是使用红黑树(二叉树)数据结构实现的,线程不同步(即线程不安全),不能在多线程中共享,但可以使用synchroinzedMap()方法来实现同步。特点:会对元素进行排序存储(按自然顺序)
双例集合体系:
----------| Map 双例集合的根接口。如果是实现了Map接口的集合类,具备的特点:存储的数据都是以键值对形式存在的,键不可重复,值可以重复
--------------| HashMap 底层是基于哈希表实现的,HashMap允许键和值为null,线程不安全,特点:存储速度块
--------------| TreeMap 基于红黑数(二叉树)数据结构实现的,线程不同步(即线程不安全),特点:会对元素经行排序存储
--------------| HashTable(了解即可) 线程安全
1、ArrayList集合
ArrayList一些常用方法几乎和collection集合一样的
2、 ArrayList集合的特有迭代器
listIterator():
返回列表中的列表迭代器
2、ArrayList集合的优点 (ArrayList集合就是传说中的动态数组)
2.1、动态的增加和减少元素
2.2、实现了ICollection和IList接口
2.3、灵活的设置数组的大小
3、ArrayList与Vector的区别
相同点:ArrayList与Vector底层都是使用Object数组实现的.
不同点:
1.ArrayList是线程不同步的,操作效率高;Vector是线程同步的,操作效率低
2.ArrayList是jdk1.2出现的,Vector是jdk1.0出现的
4、实例
例1
package com.dhb.collection; import java.util.ArrayList;
import java.util.Iterator; /**
* @author DSHORE / 2018-5-16
*
*/
public class Demo5 {
public static void main(String[] args) {
//创建ArrayList集合
ArrayList<Object> list = new ArrayList<Object>();
//添加
list.add("张三");
list.add("李四");
list.add("王五");
list.add("赵六");
list.add(,"老七");//跟下标插入元素
System.out.println(list);//返回值:[张三, 老七, 李四, 王五, 赵六];说明“老七”把“李四”替换了
ArrayList<Object> list2 = new ArrayList<Object>();
list2.add("安其拉");
list2.add("亚瑟");
list2.add("赵云");
list.addAll(list2);//把list2集合中的数据添加到list集合中
System.out.println(list);//返回值:[张三, 老七, 李四, 王五, 赵六, 安其拉, 亚瑟, 赵云] //获取迭代器
Iterator<Object> it = list.listIterator();
while (it.hasNext()) { //hasNext()和next()都是迭代器(listIterator)下面的方法
Object o = it.next();
System.out.print(o+",");//返回值:张三,老七,李四,王五,赵六,安其拉,亚瑟,赵云,
}
}
}
例2
package com.dhb.collection; import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
import java.util.Scanner; /**
* @author DSHORE / 2018-5-17
*
*/
/*
* 3:使用集合实现注册登陆功能,
* 第一步: 提示用户选择功能, A(注册) B(登陆) 。 要求: 功能选择 的时候要忽略大小写。
* 注册:
* 1. 提示用户输入注册的账号(数字)与密码,如果输入账号已经存在集合中,提示用户重新输入。
* 注册完毕之后,把集合中的所有用户信息打印出来。
* 登陆:
* 提示用户输入登陆的账号与密码,如果账号与密码这个用户已经存在集合中,那么登陆成功,否则登陆失败。
* */ class User{
int id;//账号
String passWord;//密码
public User() {
}
public User(int id, String passWord) {
super();
this.id = id;
this.passWord = passWord;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getPassWord() {
return passWord;
}
public void setPassWord(String passWord) {
this.passWord = passWord;
}
@Override
public String toString() {
return "User [id=" + id + ", passWord=" + passWord + "]";
}
}
public class Demo14 {
//static:把sc和coll共享了
static Scanner sc = new Scanner(System.in);//创建一个扫描器
static Collection<User> coll = new ArrayList<User>();//创建一个ArrayList集合 父类的引用类型指向子类的对象(多态)
public static void main(String[] args) {
while(true){
System.out.println("请选择功能: A(注册账号) B(登录系统) C(退出系统)");
String option = sc.next();//option:选择 ; 扫描你输入的选项,这里用next就好。用nextInt:说明接收类型是int类型.
if("A".equalsIgnoreCase(option)){//equalsIgnoreCase:忽略大小写;即:你输入小写a或大写A,都是相等的。好比:验证码
reg();//注册账号
}else if("B".equalsIgnoreCase(option)){
login();//登录系统
}else if("C".equalsIgnoreCase(option)){
System.out.println("已成功退出系统!");
System.exit();//退出虚拟机(退出系统)
//break;
}else {
System.out.println("您的输入有误,请重新输入您的选项!");
}
}
}
//登录
private static void login() {
System.out.println("请输入您的账号:");
int id = sc.nextInt();//扫描你输入的账号。因为id是int类型,所以next后面要加Int
System.out.println("请输入您的密码:");
String passWord = sc.next();//扫描你输入的密码。因为不是int类型,所以不用加Int
//遍历集合中的元素,并查看该用户是否存在
Iterator<User> it = coll.iterator();//获取迭代器
boolean flag = false;//标记
while (it.hasNext()){//遍历出所有元素;it.hasNext():判断集合中是否还有下一个元素。有 则返回值为true
User u= (User) it.next();//遍历下一个元素
if(u.id == id && u.passWord.equals(passWord)){
flag = true;
//System.out.println("登录成功...");
}/*else {
System.out.println("账号或密码错误,请重新登录!");
}*/
if(flag == true){
System.out.println("登录成功...");
}else{
System.out.println("账号或密码错误,请重新登录!");
}
}
// if(!coll.contains(id)){//如果coll集合不包含id,说明该账号不存在
// System.out.println("账号不存在!");
// }
}
//注册
private static void reg() {
User user = null;
while (true) {
System.out.println("请输入账号:");
int id = sc.nextInt();
user = new User(id,null);//这里只需要判断id(账号) //将账号放到u对象里面
if(coll.contains(user)){
System.out.println("该账号已存在,请重新输入!");
}else {
break;//退出循环
}
}
System.out.println("请输入密码:");
String passWrod = sc.next();
user.setPassWord(passWrod);//将密码放到u对象里面
coll.add(user);//把u对象存储到ArrayList集合中去;这样做的目的是:保障当前注册的账号和密码的内存地址一致
System.out.println("注册成功...");
System.out.println("当前注册人员的账号:"+user.getId());
}
}
原创作者:DSHORE 作者主页:http://www.cnblogs.com/dshore123/ 原文出自:http://www.cnblogs.com/dshore123/p/9052617.html 欢迎转载,转载务必说明出处。(如果本文对您有帮助,可以点击一下右下角的 推荐,或评论,谢谢!) |
java基础32 List集合下的ArrayList集合的更多相关文章
- Java基础语法(自定义类、ArrayList集合)
Java基础语法 今日内容介绍 u 自定义类 u ArrayList集合 第1章 引用数据类型(类) 1.1 引用数据类型分类 提到引用数据类型(类),其实我们对它并不陌生,如使用过的Scanner类 ...
- Java基础六(自定义类、ArrayList集合)
今日内容介绍1.自定义类型的定义及使用2.自定义类的内存图3.ArrayList集合的基本功能4.随机点名器案例及库存案例代码优化 ###01引用数据类型_类 * A: 数据类型 * a: java中 ...
- Java基础学习(四)-- 接口、集合框架、Collection、泛型详解
接口 一.接口的基本概念 关键字为:Interface,在JAVA编程语言中是一个抽象类型,是抽象方法的集合.也是使用.java文件编写. 二.接口声明 命名规范:与类名的命名规范相同,通常情况下 ...
- java基础29 迭代器 listIterator() 及各种遍历集合的方法
listIterator() 迭代器包含了 Iterator() 迭代器中的所有方法. 1.ListIterator的常用方法 hasPrevious() :判断是否还有上一个元素,有则返回true ...
- 深入理解java集合框架之---------Arraylist集合
ArrayList简介 ArrayLIst是动态数组,用MSDN的说法就是Array的复杂版本,它提供了动态的增加和减少元素,实现了Collection和List接口,可以灵活的设置数组的大小,要注意 ...
- 黑马程序员——JAVA基础之Collections和Arrays,数组集合的转换
------- android培训.java培训.期待与您交流! ---------- 集合框架的工具类: Collections : 集合框架的工具类.里面定义的都是静态方法. Col ...
- java集合 collection-list-ArrayList 去除ArrayList集合中的重复元素。
import java.util.*; /* 去除ArrayList集合中的重复元素. */ class ArrayListTest { public static void sop(Object o ...
- JavaSE入门学习7:Java基础语法之语句(下)
继续接着Java基础语法来:JavaSE入门学习5:Java基础语法(一)和JavaSE入门学习6:Java基础语法(二). 语句 Java经常使用的3种循环:while.do...while,for ...
- 深入理解java集合框架之---------Arraylist集合 -----添加方法
Arraylist集合 -----添加方法 1.add(E e) 向集合中添加元素 /** * 检查数组容量是否够用 * @param minCapacity */ public void ensur ...
随机推荐
- 部署puppet master/agent模型
自己画的一个简单的架构图 agent端每隔30分钟到master端请求与自己相关的catalog. 各节点时间要同步. 依赖DNS,各节点能通过主机名能解析. 1.同步时间 # yum install ...
- ElasticStack系列之十二 & 搜索结果研究
问题 使用 ElasticSearch 做搜索 时,比如用户输入 --> 柠檬,搜出来的结果 --> 柠檬汽水,柠檬味牙膏等在前面,真正想要的水果那个 柠檬 在后面.已经在中文分词中加了 ...
- Java基础之疑难知识点
问题列表: 1. Java中子类中可以有与父类相同的属性名吗? 2. Java中子类继承了父类的私有属性及方法吗? 3. Java中抽象类到底能不能被实例化? 1. Java中子类中可以有与父类相同的 ...
- linux(ubuntu) 常用指令
1.新建文件夹 mkdir mkdir test 2.进入文件夹 cd cd test 3.创建/修改文件 vim vim a.txt 如果不存在a.txt,就会新增a.txt; 如果存在,则修改 先 ...
- memset函数使用详解
1.void *memset(void *s,int c,size_t n) 总的作用:将已开辟内存空间 s 的首 n 个字节的值设为值 c. 2.例子#include void main(){cha ...
- [LeetCode] 329. Longest Increasing Path in a Matrix ☆☆☆
Given an integer matrix, find the length of the longest increasing path. From each cell, you can eit ...
- 2017 10.25 NOIP模拟赛
期望得分:100+40+100=240 实际得分:50+40+20=110 T1 start取了min没有用,w(゚Д゚)w O(≧口≦)O T3 代码3个bug :数组开小了,一个细节没注意, ...
- ZeroMQ API(七) 安全
1.无安全性:zmq_null(7) 1.1 名称 zmq_null - 没有安全性或机密性 1.2 概要 NULL机制由ZMTP 3.0规范定义:http://rfc.zeromq.org/spec ...
- SXOI2018 游记
noilinux@Capella:~$ cd /Memories/ noilinux@Capella:/Memories$ rm *SXOI* rm:是否删除有写保护的普通文件 "SXOI2 ...
- 半小时让你成为EXCEL高手