python的序列化和反序列化之pickle
pickle模块实现了用于序列化和反序列化Python对象结构的二进制协议。 “Pickling”是将Python对象层次结构转换为字节流的过程, “unpickling”是反向操作,从而将字节流(来自二进制文件或类似字节的对象)转换回对象层次结构。
pickle是python特有的,只能用于python,不能拓展到其他语言,序列化的结果是字节类型,也可以在协议选项中选择二进制;json则类似于一种通用的模块,在其他语言中也可正常使用,序列化的结果是字符串。
pickle.dumps(object):将对象序列化,相当于json.dumps(object)
pickle.loads(object):将对象反序列化,相当于json.loads(object)
pickle.dump(object, file)、pickle.load(object, file)是对文件进行的操作,具体使用方法可以自行查询。
问题描述:
使用pickle序列化和反序列化进行socket传输时,发送方可以正常执行,接收方报错:_pickle.UnpicklingError: pickle data was truncated
通信双方代码:
@发送方
connection, address = sock.