结合框架的体系结构:

一、List(列表)

1. List的特点

(1)List是元素有序并且可以重复的集合,称为序列

(2)List可以精确的控制每个元素的插入位置,或删除某个位置的元素

(3)List的两个主要实现类是ArrayList和LinkList

2. ArrayList的特点

(1)ArrayList底层是由数组实现的

(2)动态增长,以满足应用程序的需求

(3)在列比饿哦尾部插入或删除数据非常有效

(4)更适合查找和更新元素

(5)ArrayList中的元素可以为null

以下是通过例题演示常用方法的使用:

在ArrayList中存储并操作字符串信息

例一需求:用ArrayList存储编程语言的名称并输出,名称报告Java,C,C++,Go,Swift

package com.mpp.set;

import java.util.ArrayList;
import java.util.List; public class ListDemo1 {
public static void main(String[] args) {
List list = new ArrayList();
list.add("java");
list.add("python");
list.add("c");
list.add("swift"); //输出list中的元素个数
System.out.println(list.size());
//遍历输出所有变成语言
for(int i=0;i<list.size();i++){
System.out.print(list.get(i)+" ");
}
System.out.println();
//移除Python
// list.remove(1); //根据indexof移除
list.remove("python"); //根据元素内容移除
for(int i=0;i<list.size();i++){
System.out.print(list.get(i)+" ");
} }
}

在ArrayList中添加自定义的类的对象

例二需求:公告管理,公告的添加和显示,在指定位置处插入公告,删除公告,修改公告

  公告类属性:编号id,标题title,创建人creator,创建时间createTime

  公告类方法:构造方法,获取和设置属性值的方法(get/set方法)

公告类的代码:

package com.mpp.set;

import java.util.Date;

public class Notice {
//属性:id,title,crator,creatTime
private int id;
private String title;
private String creator;
private Date createTime; public Notice(){} //无参构造 //带参构造
public Notice(int id,String title,String creator,Date createTime){
super();
this.id = id;
this.title = title;
this.creator = creator;
this.createTime = createTime;
} public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public String getTitle() {
return title;
} public void setTitle(String title) {
this.title = title;
} public String getCreator() {
return creator;
} public void setCreator(String creator) {
this.creator = creator;
} public Date getCreateTime() {
return createTime;
} public void setCreateTime(Date createTime) {
this.createTime = createTime;
}
}

公告管理类的代码:package com.mpp.set;

package com.mpp.set;

import com.sun.tools.corba.se.idl.constExpr.Not;

import java.util.ArrayList;
import java.util.Date; public class NoticeTest {
public static void main(String[] args) {
//创建notice的对象,生成三条公告
Notice no1 = new Notice(1,"hello word!","admin",new Date());
Notice no2 = new Notice(2,"交作业!","teacher",new Date());
Notice no3 = new Notice(3,"考勤通知","teacher",new Date()); //添加公告
ArrayList noList = new ArrayList();
noList.add(no1);
noList.add(no2);
noList.add(no3); //显示公告
System.out.println("公告的内容为:");
for(int i=0;i<noList.size();i++){
Notice notice = (Notice)(noList.get(i));
System.out.println(i+1+":"+notice.getTitle());
} System.out.println("************************"); //在第一条公告后面添加一条新公告
Notice no4 = new Notice(4,"在线编辑器可以使用了","admin",new Date());
noList.add(1,no4);
System.out.println("公告的内容为:");
for(int i=0;i<noList.size();i++){
Notice notice = (Notice)(noList.get(i));
System.out.println(i+1+":"+notice.getTitle());
} System.out.println("************************"); //删除公告
noList.remove(2);
System.out.println("公告的内容为:");
for(int i=0;i<noList.size();i++){
Notice notice = (Notice)(noList.get(i));
System.out.println(i+1+":"+notice.getTitle());
} System.out.println("************************"); //修改公告
no4.setTitle("修改title:python在线编译器可以使用了");
noList.set(1,no4); //我发现有没有这一行都不影响修改后的list的显示
System.out.println("公告的内容为:");
for(int i=0;i<noList.size();i++){
Notice notice = (Notice)(noList.get(i));
System.out.println(i+1+":"+notice.getTitle());
}
}
}

二、Set(集合)

1.Set的特点

  (1)Set是元素无序并且不可以重复的集合, 被称为集

2.HashSet的特点

  (1)HashSet是Set的一个重要实现类,称为哈希集

  (2)HashSet中的元素无序并且不可以重复

  (3)HashSet中只允许一个null元素

  (4)具有良好的存取和查找性能

注意:在Set显示所有元素需要用到Iterator(迭代器),迭代器有以下特点:

  (1)Iterator接口可以以统一的方式对各种集合元素进行遍历

  (2)hasNext()方法检测集合中是否还有下一个元素

  (3)next()方法返回集合中的下一个元素

以下是通过例题演示常用方法的使用:

在HashSet中存储并操作字符串信息

例一需求:用HashSet存储多个标识颜色的英文单词,并输出,比如:blue,red,black,yellow等等

package com.mpp.set;

import java.util.HashSet;
import java.util.Iterator;
import java.util.Set; public class WordDemo {
public static void main(String[] args) {
//将英文档次添加到HashSet中
Set set = new HashSet();
//向集合中添加元素
set.add("red");
set.add("blue");
set.add("black");
set.add("yellow");
set.add("white");
//显示集合的内容
System.out.println("集合中的元素为:");
Iterator it = set.iterator(); //放进迭代器,使用迭代器遍历显示元素
//遍历迭代器并输出元素
while(it.hasNext()){
System.out.print(it.next()+ " ");
}
// set.add("green"); //set是无序的,所以插入就是增加
System.out.println();
set.add("red"); //set不允许插入重复元素,插入失败,但是不会报错
it = set.iterator();
System.out.println("插入重复元素后:");
while(it.hasNext()){
System.out.print(it.next()+ " ");
}
}
}

运行结果如下:

集合中的元素为:
red blue white black yellow
插入重复元素后:
red blue white black yellow

在HashSet中添加自定义的类的对象

例二需求:宠物猫信息管理

添加和显示宠物猫信息

查找某只宠物猫的信息并输出

修改宠物猫的信息

删除宠物猫的信息

宠物猫的属性:name,month,species

宠物猫的方法:构造方法,获取和设置属性值的方法(get/set),其他方法

Cat类:

package com.mpp.set;

public class Cat {
private String name; //名字
private int mounth; //年龄
private String species;//品种 public Cat(String name,int mounth,String species){
super();
this.setName(name);
this.setMounth(mounth);
this.setSpecies(species);
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getMounth() {
return mounth;
} public void setMounth(int mounth) {
this.mounth = mounth;
} public String getSpecies() {
return species;
} public void setSpecies(String species) {
this.species = species;
}
}

 CatTest类:

package com.mpp.set;

import javax.swing.text.html.HTMLDocument;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Set; public class CatTest {
public static void main(String[] args) {
//定义宠物猫对象
Cat cafe = new Cat("cafe",12,"英短");
Cat milk = new Cat("milk",1,"蓝猫");
//将宠物猫对象放入HashSet中
Set set = new HashSet();
set.add(cafe);
set.add(milk); //显示宠物猫的信息
Iterator it = set.iterator();
while(it.hasNext()){
System.out.println(it.next());
}
}
}

运行结果:

com.mpp.set.Cat@610455d6
com.mpp.set.Cat@511d50c0

这里显示的是对象再内存中的地址信息,因此我们需要在Cat类中重写toString方法

    //toString方法重写
@Override
public String toString(){
return "[姓名:"+name+",年龄:"+mounth+",品种:"+species+"]";
}

再次运行结果:

[姓名:cafe,年龄:12,品种:英短]
[姓名:milk,年龄:1,品种:蓝猫]

添加重复的宠物猫数据

Cat类不变,CatTest类的代码修改如下:

package com.mpp.set;

import javax.swing.text.html.HTMLDocument;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Set; public class CatTest {
public static void main(String[] args) {
//定义宠物猫对象
Cat cafe = new Cat("cafe",12,"英短");
Cat milk = new Cat("milk",1,"蓝猫");
//将宠物猫对象放入HashSet中
Set set = new HashSet();
set.add(cafe);
set.add(milk); //显示宠物猫的信息
Iterator it = set.iterator();
while(it.hasNext()){
System.out.println(it.next());
} //再添加一个与milk属性一样的猫
Cat milk01 = new Cat("milk",1,"蓝猫");
set.add(milk01);
System.out.println("添加重复数据,milk01:");
it = set.iterator();
while(it.hasNext()){
System.out.println(it.next());
}
}
}

运行结果:

[姓名:cafe,年龄:12,品种:英短]
[姓名:milk,年龄:1,品种:蓝猫]
添加重复数据,milk01:
[姓名:cafe,年龄:12,品种:英短]
[姓名:milk,年龄:1,品种:蓝猫]
[姓名:milk,年龄:1,品种:蓝猫]

这里的运行结果,添加重复的宠物猫信息添加成功了

再次修改Cat类的代码,重写hashCode和equals方法,CatTest类代码不动:

package com.mpp.set;

public class Cat {
private String name; //名字
private int mounth; //年龄
private String species;//品种 public Cat(String name,int mounth,String species){
super();
this.setName(name);
this.setMounth(mounth);
this.setSpecies(species);
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getMounth() {
return mounth;
} public void setMounth(int mounth) {
this.mounth = mounth;
} public String getSpecies() {
return species;
} public void setSpecies(String species) {
this.species = species;
} //toString方法重写
@Override
public String toString(){
return "[姓名:"+name+",年龄:"+mounth+",品种:"+species+"]";
} @Override
public int hashCode(){
final int prime = 31;
int result = 1;
result = prime * result + mounth;
result = prime * result +((name == null)?0:name.hashCode());
result = prime * result +((species == null)?0:species.hashCode());
return result;
} @Override
public boolean equals(Object obj){
if(this==obj){ //判断对象是都相等,相等则返回true,不用继续比较属性
return true;
}
if(obj.getClass()==Cat.class){ //判断obj是是不是Cat的对象
Cat cat = (Cat)obj;
return cat.getName().equals(name)&&(cat.getMounth()==mounth)&&(cat.getSpecies().equals(species));
}
return false;
}
}

运行结果:

[姓名:milk,年龄:1,品种:蓝猫]
[姓名:cafe,年龄:12,品种:英短]
添加重复数据,milk01:
[姓名:milk,年龄:1,品种:蓝猫]
[姓名:cafe,年龄:12,品种:英短]

查找宠物猫信息:

第一种:通过对象名查找

第二种:通过宠物猫的名字查找

在CatTest增加代码:

//重新插入一个新宠物猫
Cat cafe02 = new Cat("cafe2.0",2,"中华田园猫");
set.add(cafe02);
System.out.println("添加cafe2.0后的宠物猫信息");
it = set.iterator();
while(it.hasNext()){
System.out.println(it.next());
} //在集合中查找cafe的信息并输出,第一种方法:使用对象名去查找
if(set.contains(cafe)){
System.out.println("cafe找到了");
System.out.println(cafe);
}
else{
System.out.println("cafe没找到");
} //通过宠物猫的名字查找,遍历set中的元素,取出name,和要查找的宠物名对比
System.out.println("通过宠物猫名字查找:");
boolean flag = false;
Cat c= null;
it = set.iterator();
while(it.hasNext()){
c = (Cat)(it.next());
if(c.getName().equals("cafe")){
flag = true;
break;
}
}
if(flag){
System.out.println("cafe找到了");
System.out.println(c);
}
else{
System.out.println("cafe没找到");
}

引入泛型(<Cat>)的概念后删除数据,代码如下:

package com.mpp.set;

import javax.swing.text.html.HTMLDocument;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Set; public class CatTest {
public static void main(String[] args) {
//定义宠物猫对象
Cat cafe = new Cat("cafe",12,"英短");
Cat milk = new Cat("milk",1,"蓝猫");
//将宠物猫对象放入HashSet中
Set<Cat> set = new HashSet<Cat>(); //<Cat>泛型,限制加入hashset中的元素都得是Cat类型
set.add(cafe);
set.add(milk); //显示宠物猫的信息
Iterator<Cat> it = set.iterator();
while(it.hasNext()){
System.out.println(it.next());
} //再添加一个与milk属性一样的猫
Cat milk01 = new Cat("milk",1,"蓝猫");
set.add(milk01);
System.out.println("添加重复数据,milk01:");
it = set.iterator();
while(it.hasNext()){
System.out.println(it.next());
} //重新插入一个新宠物猫
Cat cafe02 = new Cat("cafe2.0",2,"中华田园猫");
set.add(cafe02);
System.out.println("添加cafe2.0后的宠物猫信息");
it = set.iterator();
while(it.hasNext()){
System.out.println(it.next());
} //在集合中查找cafe的信息并输出,第一种方法:使用对象名去查找
if(set.contains(cafe)){
System.out.println("cafe找到了");
System.out.println(cafe);
}
else{
System.out.println("cafe没找到");
} //通过宠物猫的名字查找,遍历set中的元素,取出name,和要查找的宠物名对比
System.out.println("通过宠物猫名字查找:");
boolean flag = false;
Cat c= null;
it = set.iterator();
while(it.hasNext()){
c = (it.next());
if(c.getName().equals("cafe")){
flag = true;
break;
}
}
if(flag){
System.out.println("cafe找到了");
System.out.println(c);
}
else{
System.out.println("cafe没找到");
} //删除cafe02的信息并重新输出
for(Cat cat:set){
if("cafe2.0".equals(cat.getName())){
set.remove(cat);
}
}
System.out.println("删除cafe2.0后的数据:");
for(Cat cat:set){
System.out.println(cat);
} //删除集合中的所有宠物猫信息
System.out.println("删除所有宠物猫信息");
boolean flag1 = set.removeAll(set);
if(set.isEmpty()){ //这里可以通过判断flag1是否为空和set.isEmpty()两种办法来判断是否删除完数据
System.out.println("猫都没了");
}
else{
System.out.println("猫还在---");
}
}
}

注意:set.remove(set)  这里的第二个set可以是set的一个子集

三、Map

1. Map的特点

(1)Map中的数据是以键值对的形式存储的

(2)k-v以Entry类型的对象实例存在

(3)可以通过key值快速地查找value

(4)一个映射不能包含重复的键

(5)每个键最多只能映射到一个值

2. HashMap的特点

(1)基于哈希表的Map接口的实现

(2)允许使用null值和null键

(3)key值不允许重复

(4)HashMap中的Entry对象是无序排列的

以下是通过例题演示常用方法的使用:

在HashMap中存储并操作字符串信息

例一需求:完成一个类似字典的功能

  将单词以及单词的注释存储到HashMap中

  显示HashMap中的内容

  查找某个单词的注释并显示

package com.mpp.set;

import java.util.*;

public class DictionaryDemo {
public static void main(String[] args) {
//定义一个HashMap的对象
Map<String,String> animal = new HashMap<String,String>();
System.out.println("请输入三组单词对应的注释,并存放到HashMap中");
Scanner console = new Scanner(System.in);
//添加数据
int i = 0;
while(i<3){
System.out.println("请输入key值:");
String key = console.next();
System.out.println("请输入value值:");
String value = console.next();
animal.put(key,value);
i++;
}
//打印输出value的值(直接使用迭代器)
System.out.println("使用迭代器输出所有value:");
Iterator<String> it = animal.values().iterator();
while (it.hasNext()){
System.out.print(it.next()+" ");
}
System.out.println(); //打印输出key和value的值
//通过entrySet方法
System.out.println("通过entrySet得到k-v:");
Set<Map.Entry<String,String>> entrySet = animal.entrySet();
for(Map.Entry<String,String> entry:entrySet){
System.out.print(entry.getKey()+"-");
System.out.print(entry.getValue());
System.out.println();
} //通过单词找到注释并输出
//使用keySet方法
System.out.println("请输入要查找的单词:");
String strSearch =console.next();
//1. 取到keySet
Set<String> keySet = animal.keySet();
//2.遍历keySet
for(String key:keySet){
if(strSearch.equals(key)){
System.out.println("找到了!键值对为:"+key+animal.get(key));
break;
}
}
}
}

在HashMap中添加自定义的类的对象

例二需求:商品信息管理

  使用HashMap对商品信息进行管理

    其中key为商品编码,value为商品对象

  对HashMap中的商品信息进行增删改查操作

商品信息类

属性:商品编号,名称,价格

方法:构造方法,获取和设置属性值的方法,其他方法

商品类:

package com.mpp.set;

public class Goods {
private String id;
private String name;
private double price; public String getId() {
return id;
} public String getName() {
return name;
} public double getPrice() {
return price;
} public void setId(String id) {
this.id = id;
} public void setName(String name) {
this.name = name;
} public void setPrice(double price) {
this.price = price;
} public Goods(String id,String name,double price){
this.id = id;
this.name = name;
this.price = price;
} public String toString(){
return "商品编号:"+id+",商品名称:"+name+",商品价格:"+price;
} }

商品信息类:

package com.mpp.set;

import java.util.*;

public class GoodsTest {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
//定义HashMap对象
Map<String,Goods> goodsMap = new HashMap<String,Goods>();
System.out.println("请输入三条商品信息:");
int i= 0;
while(i<3){
System.out.println("请输入第"+(i+1)+"条商品信息:");
System.out.println("请输入商品编号:");
String goodsId = sc.next();
//判断商品编号id是否已存在
if(goodsMap.containsKey(goodsId)){
System.out.println("商品编号已存在!请重新输入!");
continue;//结束当前循环,进入下一次循环
}
System.out.println("请输入商品名称:");
String goodsName = sc.next();
System.out.println("请输入商品价格:");
double goodsPrice = 0;
try{
goodsPrice = sc.nextDouble();
}
catch (InputMismatchException e){
System.out.println("商品价格的格式不正确,请输入数值型数据!");
sc.nextInt(); //如果没有这一句,出现异常时,这里输入的价格直接变成下一个输入的商品编号
continue;
} Goods goods = new Goods(goodsId,goodsName,goodsPrice);
//将商品信息添加到HashMap中
goodsMap.put(goodsId,goods);
i++;
}
//比那里Map,输出商品信息
System.out.println("商品的全部信息为:");
Iterator<Goods> itGoods = goodsMap.values().iterator();
while(itGoods.hasNext()){
System.out.println(itGoods.next());
}
}
}

集合之ArrayList,HashSet,HashMap的更多相关文章

  1. Java基础知识强化之集合框架笔记64:Map集合之ArrayList嵌套HashMap

    1. ArrayList集合嵌套HashMap集合并遍历.  需求:         假设ArrayList集合的元素是HashMap.有3个.         每一个HashMap集合的键和值都是字 ...

  2. 【java基础】java集合之HashTable,HashSet,HashMap

    [一]HashSet (1)HashSet内部维护的是一个HashMap,具体原理见java集合之HashMap [二]HashTable (1)HashTable内部维护的是一个Entry的数组.E ...

  3. 线程不安全(Arraylist,HashSet,HashMap)和写时复制

    package com.yangyuanyuan.juc1205; import java.util.List; import java.util.Map; import java.util.Set; ...

  4. ArrayList,Vector,HashMap,HashSet,HashTable之间的区别与联系

    在编写java程序中,我们最常用的除了八种基本数据类型,String对象外还有一个集合类,在我们的的程序中到处充斥着集合类的身影!java中集合大家族的成员实在是太丰富了,有常用的ArrayList. ...

  5. LinkedList,ArrayList,Vector,HashMap,HashSet,HashTable之间的区别与联系

    在编写java程序中,我们最常用的除了八种基本数据类型,String对象外还有一个集合类,在我们的的程序中到处充斥着集合类的身影!java中集合大家族的成员实在是太丰富了,有常用的ArrayList. ...

  6. 基于散列的集合 HashSet\HashMap\HashTable

    HashSet\HashMap\HashTable 1 基于散列的集合 2 元素会根据hashcode散列,因此,集合中元素的顺序不一定与插入的顺序一致. 3 根据equals方法与hashCode方 ...

  7. List集合与Set集合(ArrayList,LinkedList,Vector,HashSet,LinkedHashSet,可变参数)

    List集合介绍及常用方法 import java.util.ArrayList; import java.util.Iterator; import java.util.List; /* java. ...

  8. Java 集合系列 16 HashSet

    java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java ...

  9. 【java集合系列】---HashSet

    在前面的博文中,小编主要简单介绍了java集合中的总体框架,以及list接口中典型的集合ArrayList和LinkedList,接着,我们来看set的部分集合,set集合和数学意义上的集合没有差别, ...

随机推荐

  1. (2)struts2配置祥解

    struts工作流程 反射 : 1.构造对象使用构造器 //类似为Servlet public class AddAction { public AddAction(){ System.out.pri ...

  2. iOS数据持久化存储之属性列表

    属性列表(plist) iOS提供了一种plist格式的文件(属性列表)用于存储轻量级的数据,属性列表是一种XML格式的文件,拓展名为plist.如果对象是NSString.NSDictionary. ...

  3. C语言实现队列(纯C)

    1. [代码][C/C++]代码 #include <stdio.h>#include <stdlib.h>#define ElemType int #define Statu ...

  4. LightOJ 1070 Algebraic Problem:矩阵快速幂 + 数学推导

    题目链接:http://lightoj.com/volume_showproblem.php?problem=1070 题意: 给你a+b和ab的值,给定一个n,让你求a^n + b^n的值(MOD ...

  5. Nginx中如何限制某个IP同一时间段的访问次数

    如何设置能限制某个IP某一时间段的访问次数是一个让人头疼的问题,特别面对恶意的ddos攻击的时候.其中CC攻击(Challenge Collapsar)是DDOS(分布式拒绝服务)的一种,也是一种常见 ...

  6. ef 多个模块,通过程序集映射entity,指定对应的repository

    在Entity Framework repository下加两个方法: public virtual T GetByEntityName(object id, string EntityTypeNam ...

  7. dead reckoning variation

    Targeting A target is a structure of information that describes the state, and change of state, of a ...

  8. jquery新添加元素无法删除

    $("body").on('click',".delic",function(){ $(this).parent().remove(); })

  9. ZOJ1905Power Strings (KMP||后缀数组+RMQ求循环节)

    Given two strings a and b we define a*b to be their concatenation. For example, if a = "abc&quo ...

  10. ACM学习历程—Hihocoder 1178 计数(位运算 && set容器)(hihoCoder挑战赛12)

    时间限制:10000ms 单点时限:1000ms 内存限制:256MB   描述 Rowdark是一个邪恶的魔法师.在他阅读大巫术师Lich的传记时,他发现一类黑魔法来召唤远古生物,鱼丸. 魔法n能召 ...