序列化是指把对象的状态转换成字符串,本质上就是一个byte[ ]数组。 之所以要把Java对象序列化,是因为序列化后可以把byte[ ]保存到文件中,或者把byte[ ]通过网络传输到远程,这样,就相当于把Java对象存储到文件或者通过网络传输出去了。
有序列化,就有反序列化,即把一个二进制内容(也就是byte[ ]数组)变回Java对象。有了反序列化,保存到文件中的byte[ ]数组又可以“变回”Java对象,或者从网络上读取byte[ ]并把它“变回”Java对象。
RegExp,Error对象,undefined值不能序列化和反序列化。
var json_str = '{"name":"zhangsan","sex":"男"}'//是一种有规则的字符串
JSON.stringify(obj) 将对象序列化为Json字符串,只能序列化对象可枚举的自有属性
JSON.parse(jsonStr) 反序列化
将对象转换为字符串的描述,解决对象在io中传递的问题
1. 常规转换
obj.toString()
2. 转换为json字符串
JSON.stringify(obj)
3. 转换为查询字符串
var qs = require('querystring')
qs.stringify(obj)
vi object-json.js
// 将对象转换为JSON字符串
// {"name":"briup","age":12}
var obj = {
name:"briup",
age:12
};
console.log(obj); //object类型打印的结果 {name:'briup',age:12}
// 将对象转换为JSON字符串
var json = JSON.stringify(obj);
console.log(json);//string类型的字符串
// 将JSON字符串转换为对象
var json = '{"name":"briup","age":12}';
var obj = JSON.parse(json);
console.log(obj);