stream, formatter, serialize(-)

王朝other·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

移植BT已经进行了两个星期了,还剩下最后一部分代码。深深体会到不同编译器对标准的各行其道给开发人员带来的痛苦。今天的精神状态不是很好,开发思路有点受阻,正好将这段时间的思路做个整理。

前几天看到程序员上有一篇文章讲序列化的,觉得讲得不是很深入。加上自己开发了的基础库也已经进入第二个版本了,也想来说上两句,如有疏漏请指正。

在写之前先解释一下标题的几个概念

stream 凡是可读或者可写的都能称之为流。例如 fstream, memstream, sockstream, databasestream, httpstream, etc.流掌控着数据的来源和去向。

formatter formatter是在流的操作者,它对流的读写加以修饰。他负责流上的数据格式

serialize 序列化是一个大家熟知的概念,它是对象持久化,和对象传输的一个重要手段。记得有句话总结得很好,序列化就是在另一个时间,或者另一个空间,出现这个对象的副本。其实serialize是formatter的一个特例,下文解释。

stream

而程序从数据流向来看

输入 ---> 处理 ----> 输出

用C++来解释就是

istream --> process ----> ostream

现在已经有的stream有

fstream 对文件的操作 ( standard library )

stringstream 对字符串的操作 ( standard library )

sockstream 对网络流的操作 ( socket++: http://www.linuxhacker.at/socketxx )

memstream 对内存的操作 ( ssp: netease p2p platform )

httpstream 对http的数据操作 ( ssp: under developing )

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航