Serialization
Serialization is the process of converting a data structure, such as JavaScript object or array, into a format that can be easily stored.
In JavaScript, the most common serialization format is JSON (JavaScript Object Notation). The JSON format is easy for both human and machine to read and write.
Deserialization
Deserialization is the opposite process of Serialization. It converts data in its serialized format into its original data structure, such as a JavaScript object or array, to make the data usable and accessible in the application.
Types of Serialization formats
JSON Serialization
BSON Serialization
URL Encoding
JSON Serialization
This is most widely used method for serializing and deserializing objects. JSON.stringify()
method is used to convert the Object/array into a string and JSON.parse()
is used to convert them back to array or object format.
const obj = {
name: "abhay",
age: 25,
gender: "male",
}
const seializedObj = JSON.stringify(obj) //output : "{"name":"abhay","age":25,"gender":"male"}"
const deserialedObj = JSON.parse(seializedObj) // output : { name: 'abhay', age: 25, gender: 'male' }
BSON Serialization
BSON (binary-encoded data interchange) is more efficient in terms of storage and transmission in compared to JSON. It extends JSON with additional data types and is typically used in context of MongoDB.
import { BSON, ObjectId } from 'bson';
const data = { _id: new ObjectId(), name: "John", age: 30 }
// serialization
const bytes = BSON.serialize(data);
// Output: <Buffer 2e 00 00 00 07 5f 69 64 00 64 ca 53 01 9d 14 77 b6 a1 a2 89 e4 02 6e 61 6d 65 00 05 00 00 00 4a 6f 68 6e 00 10 61 67 65 00 1e 00 00 00 00>
// deserialization
const doc = BSON.deserialize(bytes);
// Output: {
// _id: new ObjectId("64ca53019d1477b6a1a289e4"),
// name: 'John',
// age: 30
// }
URL Encoding
This is most widely used method for serializing and deserializing data in URL’s. encodeURI()
is used to encode the data and decodeURI()
is used to decode the data passed in URL.
const uri = 'https://xyx.org/?x=шелы';
const encoded = encodeURI(uri);
console.log(encoded);
// output: "https://xyx.org/?x=%D1%88%D0%B5%D0%BB%D0%BB%D1%8B"
console.log(decodeURI(encoded));
// output: "https://xyx.org/?x=шеллы"
Challenges in Serialization
Data Loss
Data Corruption
Format Incompatibility
Data Loss
When data is too large, JSON.stringify
can cause performance issues and even data loss in extreme cases.
Example:
Serializing a huge object can freeze the main thread, causing UI lag in the browser.
If the serialized string is too big, it may exceed memory limits, leads to memory overflow and system crash.
If an object has circular references (where two properties reference each other),
JSON.stringify
will throw an error.
Data Corruption
When dealing with deeply nested objects or large arrays of objects, serialization can lead to data corruption. example If the object is too deep, JavaScript might throw a RangeError: Maximum call stack size exceeded
error
Format Incompatibility
When handling large datasets, format incompatibility can arise due to several reasons. Example: Floating-Point Precision Issues, Character Encoding Differences etc.
Reference
- Muhammad A Faishal “Serialization and Deserialization in JavaScript”