C++编程思想,在介绍数据封装给了一个CStash的例子,大概的思想是,建立一个struct,来管理一个动态增长的数组。这个数组可以接受任何类型的基本数据类型。包括示例中的int和char,一个能保存多种数据类型的底层数据类型,当然是最小的类型也就是sizeof运算符返回为1的数据类型,综合考虑,原书中给出的unsigned char作为最基本的数据类型。实际上对应于标准的字节数组。对于这个转化过程,我写了一些代码验证了一些问题。顺便复习一下,计算机体系结构中的字节序的问题。
以下是我的CStash实现代码:
#include<iostream>
#include<cstdlib>
using namespace std;
const int increment = 100;
struct CStash
{
int size;//当前元素所占字节数
int quantity;//当前容积(即包含未占用的和已占用的)
int next;//当前元素个数(因为坐标从0开始,所以next实际上等于当前元素个数,又是下一个可以存放的空白位置)
unsigned char *buffer;//字节数组
//初始化
void init(int sz)
{
size = sz;
quantity = 0;
next = 0;
buffer = 0;
cout << "Init......over!" <<endl;
}
//释放内存
void cleanup()
{
if(buffer != 0)
delete []buffer;
cout << "Cleanup......over!" <<endl