3.3 序列化与反序列化
Blob是计算实体,它对应的存储实体是BlobProto,定义在caffe.proto中。
BlobProto仅需要转移Blob的shape、data、diff三者即可,相关代码在FromProto、ToProto中。
Proto的使用规则需要参考Google Buffer Protocol提供的开发文档,~Link~
这里列出一些基本规则:
访问:
I、optional类型,内容,变量名()
II、repeated类型,内容,变量名(index)
III、repeated类型,大小,变量名_size()
修改:
I、repeated类型,添加元素,add_变量名(数据)
II、任意类型,修改,set_变量名()/set_变量名(index)
III、任意类型,获取修改型访问指针,mutable_变量名()
注:这是Google Buffer Protocol规范性的体现,所有访问方法尾部都被打上了const,为常成员函数。
比如ToProto这句: proto->mutable_shape()->add_dim(shape_[index])
如果把mutable_shape()换成shape()是错误的,因为shape()返回const指针,锁住了其成员变量的修改。
IV、任意类型,清空/初始化,clear_变量名()