Nói về Serialization trong Java

Serialization là một khái niệm giúp chúng ta có thể chuyển đổi trạng thái của một Java object thành một định dạng nào đó để Java object này có thể được lưu trữ ở đâu đó và sau đó, nó sẽ được sử dụng bởi một tiến trình khác.

Thông thường, khi sử dụng Serialization, Java object của chúng ta sẽ được chuyển đổi qua byte streams và chúng ta có thể lưu byte stream này trong bộ nhớ, trên ổ đĩa, truyền qua mạng đến một server nào đó hoặc cũng có thể lưu chúng vào database.

Và khi một tiến trình khác sử dụng một Java object đã được Serialization, nó sẽ chuyển đổi định dạng đã Serialization về trạng thái của Java object ban đầu. Nhờ vậy, tiến trình đó có thể sử dụng lại Java object của chúng ta.

Để cho một object có thể sử dụng Serialization được, chúng ta phải cho object của chúng ta hiện thực một interface với tên gọi là java.io.Serializable. Interface này không có bất kỳ một phương thức nào cần hiện thực cả các bạn ạ!

Để các bạn có thể hiểu rõ hơn, mình sẽ làm một ví dụ để minh chứng những điều mình vừa nói nhé!

Ví dụ ở đây, mình có một đối tượng là Student:

Vì mình muốn sử dụng Serialization nên mình sẽ hiện thực interface Serializable cho đối tượng Student như sau:

Như các bạn thấy, mình đã thêm một biến tên là serialVersionUID trong object Student của mình. Mục đích của biến này là để chắc chắn trước và sau khi chuyển đổi, lớp Student của chúng ta là một đấy các bạn.

OK, bây giờ chúng ta sẽ viết code để chuyển đổi đối tượng Student và lưu byte streams của nó vào một tập tin nào đó xem thử nhé!

Bây giờ, một tập tin đã được tạo và nếu bạn kiểm tra tập tin mà bạn đã lưu đối tượng Student của chúng ta, bạn sẽ thấy nội dung giống giống như sau:

Vậy làm thế nào để tiến trình khác có thể sử dụng tập tin mình đã tạo trong ví dụ trên để sử dụng, chúng ta viết code tiếp nhé!

Kết quả:

Như bạn thấy trước và sau khi chuyển đổi, đối tượng Student của mình vẫn có những thông tin mà chúng ta đã lưu trước đó.

4.7/5 - (15 bình chọn)

11 thoughts on “Nói về Serialization trong Java

  1. Bài viết cung cấp cái nhìn tổng quan cho các bạn mới học Java.
    Cũng không có nhiều website/blog cho các bạn học Java tham khảo bằng tiết Việt, cảm ơn sự nỗ lực của bạn Khanh rất nhiều.
    Mình xin bổ sung một vài ý nếu như bạn muốn bài viết của mình rõ ràng và chính xác hơn.
    Hầu hết đều đã được đề cập trong java docs của Serializable này
    Mình lấy của Jdk 1.7 làm ví dụ: https://docs.oracle.com/javase/7/docs/api/java/io/Serializable.html
    +/ Trong ví dụ, việc class được serialize/deserialze thành công là do bản thân class cùng với các field (String, int) default đã được implement Serializable rồi, Và Java sẽ tự động xử lý việc này. Nếu không sẽ có lỗi lúc serialize/deseriaize
    +/ Việc specific 1 biến serialVersionUID nhằm để xác nhận lại object lúc gửi/nhận tương thích với quá trình serialization.
    > The serialization runtime associates with each serializable class a version number, called a serialVersionUID, which is used during deserialization to verify that the sender and receiver of a serialized object have loaded classes for that object that are compatible with respect to serialization. If the receiver has loaded a class for the object that has a different serialVersionUID than that of the corresponding sender’s class, then deserialization will result in an InvalidClassException. A serializable class can declare its own serialVersionUID explicitly by declaring a field named “serialVersionUID” that must be static, final, and of type long

      1. Cảm ơn bạn đã nhắc nhở, chắc mình bỏ sót phần đó, vì trong phần comment có bạn hỏi về cái version này.
        Về phần forums thì mình ngại đăng ký 😀
        Anw, đi comment dạo này cũng hay 🙂

  2. Em chào anh, a có thể chỉ cho e cách ghi file mà trong đối tượng chứa 1 đối tượng khá không ạ
    ví dụ như là class này ạ e cám ơn
    public class Student{
    private String name;
    private int age;
    private Address address;
    }

    1. Nếu bạn dùng IntelliJ IDE có cài SonarLint plugin thì ở trường hợp này, SonarLint sẽ đưa ra cảnh báo đối với field address:
      Fields in a “Serializable” class should either be transient or serializable. (https://rules.sonarsource.com/java/RSPEC-1948)
      Khi serialize Student thì field Address có thể được serialize theo (nếu class Address implement Serializable) hoặc không (đặt private transient Address address).

  3. anh có thể giải thích dùm em cú pháp (Student) được thêm vào hàng bên dưới này có ý nghĩa là gì được không ạ? Chỗ này em chưa hiểu lắm. Em cảm ơn ạ!
    student = (Student) oos.readObject();

    1. À, cái này là đoạn code sẽ đưa cái Object lấy được từ phương thức readObject() về đối tượng Student đó em. Còn gọi là cast đối tượng.
      Em nên tìm tòi thêm những kiến thức Java cơ bản nhé!

Add Comment