码迷,mamicode.com
首页 > 编程语言 > 详细

Java集合类之Hashtable

时间:2016-04-02 00:52:34      阅读:210      评论:0      收藏:0      [点我收藏+]

标签:

package com.test;
import java.util.*;

public class Demo7_3 {

    public static void main(String[] args) {
        // TODO Auto-generated method stub

        Emp emp1 = new Emp("s001", "aaa", 12.3f);
        Emp emp2 = new Emp("s002", "bbb", 5.3f);
        Emp emp3 = new Emp("s003", "李逵", 52f);

        //创建一个HashTable对象
        //HashMap和HashTable的用法完全一致
        /*
         * Hashtable是线程同步的会去锁当1号进程访问而是,2号要等待,安全但会导致速度变慢
         * HashMap是异步的不安全,但速度较快
         *一个线程的应选用HashMap,因为不会存在同步,一般只有做服务器时,才要求同步
         */
        Hashtable ht = new Hashtable();
        ht.put("s001", emp1);
        System.out.println(ht.get("s001"));
//        //放空值Hashtable会出现异常
//        ht.put(null, null);
//        System.out.println("测试:"+ht.get(null));
        HashMap hm = new HashMap();
        //HashMap可以放空值
        hm.put(null, null);
        System.out.println("测试"+hm.get(null));
        
        
    }
}

//雇员管理类
class EmpManage {
    private ArrayList al = null;

    // 构造函数最主要的作用就是初始化成员变量
    public EmpManage() {
        al = new ArrayList();
    }

    // 加入员工
    public void addEmp(Emp emp) {
        al.add(emp);
    }

    // 根据员工号显示该员工的相关信息
    public void showInfo(String empNo) {
        // 遍历整个ArrayList
        for (int i = 0; i < al.size(); i++) {
            // 取出Emp对象
            Emp emp = (Emp) al.get(i);

            // 比较编号
            if (emp.getEmpNo().equals(empNo)) {
                System.out.println("找到该员工,他的信息是");
                System.out.println("编号=" + empNo);
                System.out.println("名字=" + emp.getName());
                System.out.println("工资=" + emp.getSal());
            }
        }
    }

    // 修改工资
    public void updateSal(String empNo, float newSal) {
        for (int i = 0; i < al.size(); i++) {
            Emp emp = (Emp) al.get(i);
            if (emp.getEmpNo().equals(empNo)) {
                // 修改薪水
                emp.setSal(newSal);
            }
        }
    }

    // 删除员工
    public void delEmp(String empNo) {
        for (int i = 0; i < al.size(); i++) {
            Emp emp = (Emp) al.get(i);
            if (emp.getEmpNo().equals(empNo)) {
                // 两种删除方式都可以
                al.remove(i);
                // al.remove(emp);
            }
        }
    }
}

//雇员类
class Emp {

    // 学号
    private String empNo;
    private String name;
    private float sal;

    // 构造函数
    public Emp(String empNo, String name, float sal) {
        super();
        this.empNo = empNo;
        this.name = name;
        this.sal = sal;
    }

    public String getEmpNo() {
        return empNo;
    }

    public void setEmpNo(String empNo) {
        this.empNo = empNo;
    }

    public String getName() {
        return name;
    }

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

    public float getSal() {
        return sal;
    }

    public void setSal(float sal) {
        this.sal = sal;
    }

}

 

Java集合类之Hashtable

标签:

原文地址:http://www.cnblogs.com/litao0505/p/5346745.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!