首页技术serialize serialize翻译

serialize serialize翻译

编程之家2026-06-19666次浏览

大家好,关于serialize很多朋友都还不太明白,今天小编就来为大家分享关于serialize翻译的知识,希望对各位有所帮助!

serialize serialize翻译

PHP序列化数据存储在数据库中使用json还是serialize好

1)空间的比较

serialize在编码后大概是json的1.5倍。

原因:

serialize后字符串包含了子串的长度,这可能是速度方面的优化,但是测试结果不尽人意。

serialize有更加详细的类型区分,而json只有四种类型,并且是以简单的符号表示。

2)速度的比较

serialize serialize翻译

在较小数据的情况下, serialize比json快数量级。

在大数据量的情况下,json比serialize稍微差一点

3)处理对象

json无法处理对象方法等数据。

4)使用范围

在前后端交互一般都使用JSON,另外,目前JSON只支持UTF-8编码的数据。

序列化使用serialize,特别是对象的存储。这是其存在的意义。

与对象无关的数据存储可以使用json,如包含大量数字的数组等。

这篇博客概括满全面:

java序列化Protostuff和Serializable的区别

序列化就是将Java Object转成byte[];反序列化就是将byte[]转成Java Object。

Java自带序列化机制java.io.Serializable

标识一个对象需要系列化,该对象类型需要实现 Serializable接口。

1,序列化的类型和反序列化的类型的序列化ID必须一致(远程信息交换时)。

2,静态数据不会被序列化,Transient关键字修饰的字段不会被序列化。

3,对象序列化存储时,两次存储相同值对象会有优化(第二次对象写入会只存储引用)。

Protostuff是一个序列化库,支持一下序列化格式:

protobuf

protostuff(native)

graph(protostuff with support for cyclic references. See Serializing Object Graphs)

json

smile(binary json useable from the protostuff-json module)

xml

yaml(serialization only)

kvp(binary uwsgi header)

序列化

@SuppressWarnings("unchecked")

public static<T> byte[] serialize(T obj){

Class<T> cls=(Class<T>) obj.getClass();//获得对象的类;

LinkedBuffer buffer= LinkedBuffer.allocate(LinkedBuffer.DEFAULT_BUFFER_SIZE);//使用LinkedBuffer分配一块默认大小的buffer空间;

try{

Schema<T> schema= getSchema(cls);//通过对象的类构建对应的schema;

return ProtostuffIOUtil.toByteArray(obj, schema, buffer);//使用给定的schema将对象序列化为一个byte数组,并返回。

} catch(Exception e){

throw new IllegalStateException(e.getMessage(), e);

} finally{

buffer.clear();

}

}

反序列化

public static<T> T deserialize(byte[] data, Class<T> cls){

try{

T message= objenesis.newInstance(cls);//使用objenesis实例化一个类的对象;

Schema<T> schema= getSchema(cls);//通过对象的类构建对应的schema;

ProtostuffIOUtil.mergeFrom(data, message, schema);//使用给定的schema将byte数组和对象合并,并返回。

return message;

} catch(Exception e){

throw new IllegalStateException(e.getMessage(), e);

}

}

优缺点比较:

优点缺点

Serializable使用方便,可序列化所有类速度慢,占空间

Protostuff速度快,基于protobuf需静态编译

servlet怎么解析jquery通过serialize提交的表单

下面是服务器端的jsp代码:

与JQuery中其他方法一样,serialize()方法也是作用于一个JQuery对象,它能够将DOM元素内容序列化为字符串,用于ajax请求。通过使用serialize()方法,可以提交本页面的所有域,代码如下:

当单击“提交”按钮后,所有属于form1的表单元素都能提交到后台,即使在表单中再增加字段,脚本仍然能够使用,并且不需要做其他多余工作。

用字符串方式时,需要注意对字符编码(中文问题),如果不希望编码带来麻烦,可以使用serialize()方法,它会自动编码。

因为serialize()方法作用于JQuery对象,所以不光只有表单能使用它,其他选择器选取的元素也都能使用它,如以下JQuery代码:

$(":checkbox,:radio").serialize()

把复选框和单选框的值序列化为字符串形式,只会将选中的值序列化。

在JQuery中还有一个与serialize()类似的方法--serializeArray(),该方法不是返回字符串,而是将DOM元素序列化后,返回JSON格式的数据。JQuery代码如下:

var fields=$(":checkbox,:radio").serializeArray()

console.log(fields);//用FireBug输出

$.param()方法是serialize()方法的核心,用来对一个数组或对象按照key/value进行序列化。

比如将一个普通的对象序列化:

var obj={a:1,b:2,c:3}

var k=$.param(obj)

alert(k);//输出a=1&b=2&c=3

关于serialize的内容到此结束,希望对大家有所帮助。

frequency函数使用 frequency函数下拉错误ai换脸视频(如何用AI换脸合成一个视频)