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:
Một số nguyên tắc, định luật trong lập trình
Collect a Java Stream to an Immutable Collection
Java InputStream to Byte Array and ByteBuffer
Guide to Java OutputStream
Check if there is mail waiting
Java Program to Create a Balanced Binary Tree of the Incoming Data
Spring Data JPA Delete and Relationships
Deploy a Spring Boot App to Azure
Spring MVC Async vs Spring WebFlux
A Guide to Concurrent Queues in Java
Java Program to Construct an Expression Tree for an Postfix Expression
A Guide to the ResourceBundle
@Order in Spring
Server-Sent Events in Spring
wait() and notify() Methods in Java
String Operations with Java Streams
Using Custom Banners in Spring Boot
Quick Guide to @RestClientTest in Spring Boot
Java Program to Use rand and srand Functions
Guide to the Synchronized Keyword in Java
Java Program to Implement Dijkstra’s Algorithm using Queue
REST Web service: Tạo ứng dụng Java RESTful Client với Jersey Client 2.x
How to Change the Default Port in Spring Boot
CyclicBarrier in Java
Java Program to Implement Meldable Heap
Hướng dẫn sử dụng luồng vào ra ký tự trong Java
Java Program to Perform the Sorting Using Counting Sort
Spring Boot - Flyway Database
Jackson – Decide What Fields Get Serialized/Deserialized
Spring Boot Application as a Service
Understanding Memory Leaks in Java
Java Program to Implement ConcurrentLinkedQueue API