你的位置:首页 > Java教程

[Java教程]集合练习——List部分


利用ArrayList

1、存储多个员工信息,包括工号,姓名,年龄,入职时间,逐条打印所有员工姓名,并输出员工个数。

package CollectionPart;import java.util.ArrayList;import java.util.List;public class ArrayListPractise_1 {    public static void main(String[] args) {        Employee_1 e1 = new Employee_1("dept1_001", "lifei", 24, "2016-03-28");    Employee_1 e2 = new Employee_1("dept1_002", "li2fe", 23, "2015-01-22");    Employee_1 e3 = new Employee_1("dept1_003", "lifei3", 28, "2016-02-05");    Employee_1 e4 = new Employee_1("dept2_001", "lif4i", 25, "2017-03-28");        List<Employee_1> myList1 = new ArrayList();    myList1.add(e1);    myList1.add(e2);    myList1.add(e3);    myList1.add(e4);        for (Employee_1 employee_1 : myList1) {      System.out.println(employee_1.getEmployeeName());    }    System.out.println("员工总个数为:"+myList1.size());      }}

package CollectionPart;public class Employee_1 {    private String employeeId;  private String employeeName;  private int employeeAge;  private String employeeHireDate;  /*  这里就存储成String 类型,在 数据库里面设置成 date格式。  然后 利用Date today = new Date();  SimpleDateFormat fm = new SimpleDateFormat("YYYY-MM-dd");  来做  */  public String getEmployeeId() {    return employeeId;  }  public void setEmployeeId(String employeeId) {    this.employeeId = employeeId;  }  public String getEmployeeName() {    return employeeName;  }  public void setEmployeeName(String employeeName) {    this.employeeName = employeeName;  }  public int getEmployeeAge() {    return employeeAge;  }  public void setEmployeeAge(int employeeAge) {    this.employeeAge = employeeAge;  }  public String getEmployeeHireDate() {    return employeeHireDate;  }  public void setEmployeeHireDate(String employeeHireDate) {    this.employeeHireDate = employeeHireDate;  }  @Override  public String toString() {    return "Employee_1 [employeeId=" + employeeId + ", employeeName=" + employeeName + ", employeeAge="        + employeeAge + ", employeeHireDate=" + employeeHireDate + "]";  }  public Employee_1(String employeeId, String employeeName, int employeeAge, String employeeHireDate) {    super();    this.employeeId = employeeId;    this.employeeName = employeeName;    this.employeeAge = employeeAge;    this.employeeHireDate = employeeHireDate;  }  public Employee_1() {    super();  }  }

 

练习2:

当有员工入职时添加,员工信息,当有员工离职时,删除该信息。

示例代码:【有bug,在 输入日期的时候,没等到输入日期,就直接询问是否还有入职的同志】

下面算是 为 解决 ConcurrentModificationException 提出了一个 方案。就是 得到 当前元素的 下标然后再删除。下面的代码没有怎么写注释,如果有问题的话欢迎讨论。

package CollectionPart;import java.util.ArrayList;import java.util.List;import java.util.Scanner;public class ArrayListPractise_2 {    public static void main(String[] args) {    ArrayListPractise_2 ap2 = new ArrayListPractise_2();        List<Employee_1> myList = new ArrayList();    System.out.println("是否有员工入职?");    Scanner in = new Scanner(System.in);    String string = in.nextLine();    while(string.equals("是")){      System.out.println("请输入员工的编号");      String id = in.nextLine();      System.out.println("请输入员工的姓名");      String name = in.nextLine();      System.out.println("请输入员工的年龄");      int age = in.nextInt();      System.out.println("请输入员工的入职时间");      String hireDate = in.nextLine();      System.out.println("?");      Employee_1 e1 = new Employee_1(id, name, age, hireDate);      myList.add(e1);      System.out.println("是否还有新员工入职?");      string = in.nextLine();    }            System.out.println("共有员工:"+myList.size()+"人");        List<Employee_1> newList =null;    System.out.println("是否有员工离职?");    string = in.nextLine();    while(string.equals("是")){      System.out.println("该员工的姓名是");      String name = in.nextLine();      newList = ap2.deleteFromTheList(myList,name);      System.out.println("是否还有员工离职?");      string = in.nextLine();    }    for (Employee_1 employee_1 : newList) {      System.out.println("员工人数为:"+newList.size());    }      }  private List<Employee_1> deleteFromTheList(List<Employee_1> myList, String name) {    int index = 0;    boolean hasTheElement = false;     for(int i = 0; i<myList.size();i++){      if(myList.get(i).getEmployeeName().equals(name)){        index = i;        hasTheElement = true;      }    }    if(!hasTheElement){      System.out.println("不存在此元素");    }else{      myList.remove(index);    }    return myList;  }}

ArrayList 和 LinkedList 分别在什么时候使用?

ArrayList,在遍历元素和随机访问元素时效率会比较高,在插入删除操作情况下效率会比较低

LinkedList,在插入和删除时效率会比较高,但是在 查找时效率会比较低

 

与一个 很相像的比较 Vector。

两者 拥有的方法是一样的。就是一个镜像一样的存在。唯一区别在于同异步。

Vector是线程安全的,也就是说,在多线程操作的时候他仍然是可靠地,当A个线程对其进行操作的时候,其他任何线程不允许访问,当A线程完成访问以后,其他线程获得访问该集合的权限。而对于ArrayList来说,他是线程不安全的,就是 在线程A在访问ArrayList的时候,别的线程也可以访问的,这样就会不安全。

那么为什么不安全的反而应用更广,因为多个线程可以访问,那么执行效率就高,访问速度就快,所以 在效率上ArrayList扳回一城,在两者的取舍过程中,大家倾向于效率,所以 ArrayList更加火爆。

同样的 既然牵扯到了这个 问题 那就 连带说一下 Stringbuffer 和 StringBuilder

两者 也是镜像般存在的。

StringBuffer 是线程安全的。StringBuilder 是不安全的。

但是 在使用上,我们利用StringBuffer更多一些。猜想,因为 异步的关系,我们希望得到更加靠谱的字符串。如果考虑到正确性的问题还是需要为stringBuilder加上同步锁。所以就干脆直接使用StringBuffer了。

此处为引用:

这个 参考 百度知道的一个文献吧:

1. 在执行速度方面的比较:StringBuilder > StringBuffer  
2. StringBuffer与StringBuilder,他们是字符串变量,是可改变的对象,每当我们用它们对字符串做操作时,实际上是在一个对象上操作的,不像String一样创建一些对象进行操作,所以速度就快了。
3. StringBuilder:线程非安全的
  StringBuffer:线程安全的
当我们在字符串缓冲去被多个线程使用是,JVM不能保证StringBuilder的操作是安全的,虽然他的速度最快,但是可以保证StringBuffer是可以正确操作的。当然大多数情况下就是我们是在单线程下进行的操作,所以大多数情况下是建议用StringBuilder而不用StringBuffer的,就是速度的原因。

对于三者使用的总结:1.如果要操作少量的数据用 = String
       2.单线程操作字符串缓冲区 下操作大量数据 = StringBuilder
       3.多线程操作字符串缓冲区 下操作大量数据 = StringBuffer

引用结束。
附网址链接:http://zhidao.baidu.com/link?url=NdcmurUXZeD30zVPk5o---5Gj0WmSR-9whPpal4Ln_mWC6E1gIq41Ndk3N7QI3APLGOabr7QNNh_T6fGYypHM_