集合练习——List部分

时间:2021-01-26 23:18:36

利用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_