2020-7-30 Java集合

2020-7-30 Java集合

一、选择
  1. 下列不属于Collection子接口的是 (B)
    A. List
    B. Map
    C. Queue
    D. Set
  2. 已知ArrayList的对象是list,以下哪个方法是判断ArrayList中是否包含"dodoke"(A)
    A. list.contains(“dodoke”);
    B. list.add(“dodoke”);
    C. list.remove(“dodoke”);
    D. list.remove(“dodoke”);
  3. 下列哪个方法可以获取列表指定位置处的元素(D)
    A. add(E e)
    B. remove()
    C. size()
    D. get(int index)
  4. 下列有关HashSet的描述正确的是(多选)(AC)
    A. HashSet是Set的一个重要实现类
    B. HashSet中的元素无序但可以重复
    C. HashSet中只允许一个null元素
    D. 不适用于存取和查找
  5. 以下关于Set对象的创建错误的是(A)
    A. Set set=new Set();
    B. Set set=new HashSet();
    C. HashSet set=new HashSet();
    D. Set set=new HashSet(10);
  6. 关于Iterator的描述错误的是(D)
    A. Iterator可以对集合Set中的元素进行遍历
    B. hasNext()方法用于检查集合中是否还有下一个元素
    C. next()方法返回集合中的下一个元素
    D. next()方法的返回值为false时,表示集合中的元素已经遍历完毕
  7. 定义一个Worker类,关于hashCode()方法的说法正确的是?(C)
    A. 在Worker类中,hashCode()方法必须被重写
    B. 如果hashCode的值相同,则两个Worker类的对象就认为是相等的
    C. hashCode的值不同时,则两个对象必定不同
    D. 以上说法均正确
  8. 下列相关迭代器描述正确的是(ABC)
    A. Iterator接口可以以统一的方式对各种集合元素进行遍历
    B. hasNext()是Iterator接口的一个方法,是用来检测集合中是否还有下一个元素
    C. next()是Iterator接口的一个方法,是用来返回集合中的下一个元素
    D. hasNext()是Iterator接口的一个方法,是用来返回集合中的下一个元素
  9. HashMap的数据是以key-value的形式存储的,以下关于HashMap的说法正确的是(C)
    A. HashMap中的键不能为null
    B. HashMap中的Entry对象是有序排列的
    C. key值不允许重复
    D. value值不允许重复
  10. 已知HashMap对象,横线处应添加的语句是?(A)
    在这里插入图片描述
    A. hashMap.get(key);
    B. hasMap.getValue();
    C. hashMap.getKey();
    D. hashMap.Value();
  11. 以下关于Set和List的说法,正确的是(C)
    A. Set中的元素是可以重复的
    B. List中的元素是无序的
    C. HashSet中只允许有一个null元素
    D. List中的元素是不可以重复的
二、编程
  1. 使用集合ArrayList对字符串进行存储和管理。
    运行效果图:
    在这里插入图片描述
    任务:
    1. 定义ArrayList对象
    2. 存储学科名称,见运行效果图
    3. 输出集合中元素的个数
    4. 遍历输出集合中的所有元素
      编程:
public class ArrayListDemo {
    public static void main(String[] args) {
        //用ArrayList存储学科的名称
        List list = new ArrayList();
        list.add("语文");
        list.add("数学");
        list.add("英语");
        list.add("化学");
        list.add("物理");
        list.add("生物");
        //输出列表中元素的个数
        System.out.println("列表中的元素的个数为:" + list.size());
        //遍历输出所有列表元素
        for (int i = 0; i < list.size(); i++) {
            System.out.println("第" + (i+1) + "个为" + list.get(i));
        }
    }
}
  1. 定义一个员工信息类Employee,使用ArrayList对员工信息进行添加和显示。
    运行效果图:
    在这里插入图片描述
    任务:
    1、实现员工信息类Employee
    成员变量:编号id(int),姓名name(String),薪资salary(double)
    方法:构造方法和相关的get和set方法
    2、定义三条员工信息添加到ArrayList中
    3、将所有员工的姓名和薪资输出,见效果图
    编程:
package TEST;

public class Employee {
    private int id;
    private String name;
    private double salay;

    public Employee(int id, String name, double salay) {
        this.setId(id);
        this.setName(name);
        this.setSalay(salay);
    }

    public Employee() {
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public double getSalay() {
        return salay;
    }

    public void setSalay(double salay) {
        this.salay = salay;
    }
}

public class EmployeeTest {
    public static void main(String[] args) {
	    //定义ArrayList对象
        List list = new ArrayList();
        //创建三个Employee类的对象
        Employee emp1 = new Employee(001, "张三", 5000.0);
        Employee emp2 = new Employee(002, "李四", 5500.0);
        Employee emp3 = new Employee(003, "赵六", 4000.0);
        //添加员工信息到ArrayList中
        list.add(emp1);
        list.add(emp2);
        list.add(emp3);
        //显示员工的姓名和薪资
        System.out.println("员工姓名" + "    " + "员工薪资");
        for (int i = 0; i < list.size(); i++) {
            System.out.println(((Employee) (list.get(i))).getName() + "        " + ((Employee) (list.get(i))).getSalay());
        }
    }
}
  1. 定义一个学生类,使用HashSet对学生类的对象进行管理:执行添加操作,然后解决重复数据的添加问题。
    运行效果图:
    在这里插入图片描述
    任务:
    定义一个学生类Student
    (1)属性为:学号stuId(int),姓名name(String),成绩score(float)
    (2)方法为:构造方法,getter和setter方法,toString方法
    (3)重写hashCode()和equals()方法,equals方法的判断依据是学号和姓名相等
    定义三个Student类的对象,添加到HashSet中
    显示HashSet中元素的内容
    添加一个重复数据到Set中,观察输出结果
    编程:
package TEST;

import java.util.Objects;

public class Student {
    private int stuld;
    private String name;
    private float score;

    public Student(int stuld, String name, float score) {
        this.setStuld(stuld);
        this.setName(name);
        this.setScore(score);
    }

    public Student() {
    }

    public int getStuld() {
        return stuld;
    }

    public void setStuld(int stuld) {
        this.stuld = stuld;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public float getScore() {
        return score;
    }

    public void setScore(float score) {
        this.score = score;
    }

    @Override
    public String toString() {
        return "[" +
                "学号:" + stuld +
                ", 姓名:" + name +
                ", 成绩:" + score +
                "]";
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o.getClass() == Student.class){
            Student stu = (Student)o;
            return stu.getName().equals(name)&&(stu.getStuld()==stuld);
        }
        return false;
    }

    @Override
    public int hashCode() {
        return Objects.hash(stuld, name);
    }
}

package TEST;

import java.util.HashSet;
import java.util.Iterator;
import java.util.Set;

public class StudentTest {
    public static void main(String[] args) {
        //定义三个Student类的对象及一个HashSet类的对象
        Student stu1 = new Student(1,"Willianm",65.0f);
        Student stu2 = new Student(2,"Tom",87.0f);
        Student stu3 = new Student(3,"Lucy",95.0f);
        Set set = new HashSet();
        //将Student类的对象添加到集合中
        set.add(stu1);
        set.add(stu2);
        set.add(stu3);
        //使用迭代器显示Student类的对象中的内容
        Iterator it = set.iterator();
        while (it.hasNext()){
            System.out.println(it.next());
        }
    }
}

  1. 已知如下数据:世界杯冠军及夺冠年份。
    在这里插入图片描述
    将夺冠年份作为key值,冠名队名作为value值,存储至少三条数据到HashMap中,并循环打印输出。
    运行效果图:
    在这里插入图片描述
    任务:
    1、将夺冠年份和冠军队名以key-value形式存储到HashMap中
    2、使用迭代器和EntrySet两种方式遍历输出HashMap中的key和value
    编程:
package TEST;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

public class FootballDemo {
    public static void main(String[] args) {
        //定义HashMap的对象并添加数据
        Map<Integer, String> map = new HashMap();
        map.put(2006,"意大利");
        map.put(2014,"德国");
        map.put(2010,"西班牙");
        //使用迭代器的方式遍历
        Iterator it = map.values().iterator();
        System.out.println("使用迭代器方式进行输出:");
        while (it.hasNext()){
            System.out.print(it.next() + "    ");
        }
        System.out.println();
        //使用EntrySet同时获取key和value
        System.out.println("使用EntrySet进行输出:");
        Set <Entry<Integer, String>> entrySet = map.entrySet();
        for (Entry<Integer, String> entry : entrySet) {
            System.out.print(entry.getKey() + "-");
            System.out.println(entry.getValue());
        }
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值