Table of Contents
Trong các bài viết trước, tôi đã giới thiệu với các bạn ArrayList và Vector trong Java. Trong bài này, chúng ta cùng so sánh sự giống nhau và khác nhau giữa chúng.
1. Giống nhau của ArrayList và Vector
- Cả ArrayList và Vector đều cài đặt interface List.
- HashMap và Hashtable đều duy trì thứ tự chèn của các phần tử.
2. Khác nhau của ArrayList và Vector
| ArrayList | Vector |
| ArrayList là non-synchronized. | Vector là synchronized. |
| ArrayList là nhanh hơn vì nó là non-synchronized. | Vector là chậm hơn ví nó là synchronized. Tức là, trong môi trường đa luồng, các thread giữ nó ở trong trạng thái runnable hoặc non-runnable cho đến khi thread hiện tại giải phóng đối tượng đó. |
| ArrayList được duyệt bởi Iterator. | Vector được duyệt bởi Enumeration và Iterator. |
| Không thể chủ động thay đổi kích thước hiện tại của ArrayList. Kích thước ArrayList chỉ được thay đổi khi thêm hoặc xóa phần tử. | Có thể chủ động thay đổi kích thướng của Vector bằng phương thức setSize(). |
| ArrayList tăng 50% kích thước hiện tại nếu số phần tử vượt quá khả năng chứa của nó. | Vector tăng 100% nghĩa là tăng gấp đôi kích thước hiện tại nếu số phần tử vượt quá khả năng chứa của nó.. |
| Chúng ta có thể làm cho ArrayList đồng bộ bằng cách gọi phương thức: Collections.synchronizedList(); | Vector được đồng bộ nội bộ và không thể hủy đồng bộ hóa. |
| ArrayList được ưa thích trong các ứng dụng đơn luồng (single-thread). Nếu bạn muốn sử dụng HashMap trong ứng dụng đa luồng (mulit-thread), có thể thực hiện bằng cách sử dụng phương thức Collections. synchronizedList(). | Mặc dù Vector có để sử dụng trong các ứng dụng đa luồng (multi-thread), nhưng ngày nay nó ít được sử dụng. Bởi vì, Collections. synchronizedList() là lựa chọn tốt hơn Vector. |
3. Ví dụ duyệt ArrayList sử dụng Iterator
import java.util.ArrayList;
import java.util.Iterator;
public class ArrayIteratorExample {
public static void main(String args[]) {
// creating arraylist
ArrayList<String> arrayList = new ArrayList<String>();
// adding object in arraylist
arrayList.add("Sonoo");
arrayList.add("Michael");
arrayList.add("James");
arrayList.add("Andy");
// traversing elements using Iterator
Iterator<String> itr = arrayList.iterator();
while (itr.hasNext()) {
System.out.println(itr.next());
}
}
}
Kết quả thực thi chương trình trên:
Sonoo Michael James Andy
4. Ví dụ duyệt Vector sử dụng Enumeration
import java.util.Enumeration;
import java.util.Vector;
public class VectorEnumerationExample {
public static void main(String args[]) {
// creating vector
Vector<String> vector = new Vector<String>();
// adding object in vector
vector.add("Sonoo");// method of Collection
vector.addElement("Michael");// method of Vector
vector.addElement("James");
vector.add("Andy");
// traversing elements using Enumeration
Enumeration<String> e = vector.elements();
while (e.hasMoreElements()) {
System.out.println(e.nextElement());
}
}
}
Kết quả thực thi chương trình trên:
Sonoo Michael James Andy
Related posts:
Optional trong Java 8
Java Program to Implement the Edmond’s Algorithm for Maximum Cardinality Matching
Guide to UUID in Java
Anonymous Classes in Java
Comparing Strings in Java
Ways to Iterate Over a List in Java
“Stream has already been operated upon or closed” Exception in Java
Java Program to Create the Prufer Code for a Tree
Hướng dẫn Java Design Pattern – Builder
Java Program to Implement Merge Sort on n Numbers Without tail-recursion
Guide to ThreadLocalRandom in Java
Entity To DTO Conversion for a Spring REST API
What is a POJO Class?
Java Program to Check if it is a Sparse Matrix
Spring Boot - Unit Test Cases
Java Program to Perform Addition Operation Using Bitwise Operators
Difference Between Wait and Sleep in Java
Queue và PriorityQueue trong Java
Java Program to Implement Euler Circuit Problem
Spring WebClient vs. RestTemplate
HttpClient Timeout
Java Program to Implement SynchronosQueue API
So sánh HashMap và HashSet trong Java
Intro to Spring Boot Starters
Introduction to Project Reactor Bus
Hướng dẫn Java Design Pattern – Interpreter
Java Program to Implement Segment Tree
New Features in Java 12
The Difference Between Collection.stream().forEach() and Collection.forEach()
Mảng (Array) trong Java
Guide to the Java Queue Interface
Java Program to Implement a Binary Search Tree using Linked Lists
