头文件如下:

#pragma once
#include <string>
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#include <assert.h>
using namespace std; typedef int BOOL;
#define FALSE 0
#define TRUE 1 typedef unsigned char BYTE;
typedef unsigned int UINT; class MBuffer
{
public:
MBuffer();
MBuffer(const char * other);
MBuffer(const MBuffer& other);
MBuffer(const string& other);
virtual ~MBuffer();
private:
BYTE* m_pBuffer;
UINT m_nBufferSize; BYTE* m_pData;
UINT m_nDataSize; public:
virtual void FreeBuffer();
virtual BOOL AppendData(unsigned char* pData, UINT nDataSize);
virtual BOOL append( char* str,int nSize /*= 0*/ );
virtual BOOL append(const MBuffer &other);
virtual BOOL append(unsigned int value);
virtual void ClearData();
const char* GetData() ;
char* c_str() const;
unsigned long length() const;
virtual void clear();
MBuffer& operator=(const char * other);//赋值操作符重载
MBuffer& operator=(const MBuffer& other);//赋值操作符重载
MBuffer& operator=(const string& other);//赋值操作符重载
BOOL operator==(const MBuffer& other);//赋值操作符重载
char* substr( int nStart,int iSize );
int findlastofindex(char *cStr);
int findlastofindex(char cChr);
bool subbuffer(MBuffer& outBuffer,int istart,int ilen);
private:
virtual BOOL AllocateBuffer(UINT nBufferSize);
virtual BOOL ExtendBuffer(UINT nBufferSize);
virtual BOOL FillData(unsigned char* pData, UINT nDataSize); };

  CPP文件:

#include "MBuffer.h"

MBuffer::MBuffer()
{
m_pBuffer = NULL;
m_nBufferSize = 0; m_pData = NULL;
m_nDataSize = 0;
} MBuffer::MBuffer( const char * other )
{
m_pBuffer = NULL;
m_nBufferSize = 0; m_pData = NULL;
m_nDataSize = 0;
if (other != NULL)
{
AppendData((unsigned char*)other,strlen(other));
}
} MBuffer::MBuffer( const MBuffer& other )
{
m_pBuffer = NULL;
m_nBufferSize = 0; m_pData = NULL;
m_nDataSize = 0;
AppendData(other.m_pData,other.m_nDataSize);
} MBuffer::MBuffer( const string& other )
{
FreeBuffer();
AppendData((unsigned char*)other.c_str(),other.length());
} MBuffer::~MBuffer()
{
FreeBuffer();
} void MBuffer::FreeBuffer()
{
if (m_pBuffer == NULL)
return; delete[] m_pBuffer; m_pBuffer = NULL;
m_nBufferSize = 0; m_pData = NULL;
m_nDataSize = 0;
} BOOL MBuffer::AllocateBuffer( UINT nBufferSize )
{
if ( nBufferSize == 0)
return FALSE; FreeBuffer(); m_pBuffer = new BYTE[nBufferSize + 1];
if ( m_pBuffer == NULL)
return FALSE;
m_nBufferSize = nBufferSize;
memset(m_pBuffer,0,nBufferSize + 1);
m_pData = m_pBuffer; return true;
} BOOL MBuffer::ExtendBuffer( UINT nBufferSize )
{
if (nBufferSize <= m_nBufferSize)
return TRUE; return AllocateBuffer(nBufferSize);
} BOOL MBuffer::FillData( unsigned char* pData, UINT nDataSize )
{
if (pData == NULL || nDataSize == 0)
return FALSE; if (m_nBufferSize < nDataSize)
AllocateBuffer(nDataSize); memcpy(m_pBuffer, pData, nDataSize);
m_nDataSize = nDataSize; return TRUE;
} BOOL MBuffer::AppendData( unsigned char* pData, UINT nDataSize )
{
if (nDataSize == 0)
return FALSE; if (!m_pBuffer && !m_nBufferSize)
AllocateBuffer(nDataSize); if ( ( m_nBufferSize - ( m_pData - m_pBuffer)) < ( m_nDataSize + nDataSize))
{
MBuffer bufferTemp;
if (m_nDataSize)
{
if ( bufferTemp.FillData(m_pData, m_nDataSize) == FALSE)
return FALSE;
} unsigned char* pBuffer = NULL;
pBuffer = new BYTE[m_nDataSize + nDataSize + 1];
if ( pBuffer == NULL)
return FALSE; if ( m_pBuffer != NULL)
{
delete [] m_pBuffer;
m_pBuffer = NULL;
} m_pBuffer = pBuffer;
m_pData = pBuffer; m_nBufferSize = m_nDataSize + nDataSize; if (bufferTemp.m_nDataSize)
memcpy( m_pData, bufferTemp.m_pData, bufferTemp.m_nDataSize);
m_pData[m_nDataSize + nDataSize] = '\0';
m_nDataSize = bufferTemp.m_nDataSize;
}
memcpy( m_pData + m_nDataSize, pData, nDataSize);
m_nDataSize += nDataSize; return TRUE;
} void MBuffer::ClearData()
{
m_nDataSize = 0;
m_pData = m_pBuffer;
} const char* MBuffer::GetData()
{
return (char*)m_pData;
} char* MBuffer::c_str() const
{
if (m_pData == NULL || m_nDataSize<=0)
{
return NULL;
}
return (char*)m_pData;
} unsigned long MBuffer::length() const
{
return m_nDataSize;
} MBuffer& MBuffer::operator=( const char * other )
{
FreeBuffer();
if (other)
{
AppendData((unsigned char*)other,strlen(other));
}
return *this;
} MBuffer& MBuffer::operator=( const MBuffer& other )
{
FreeBuffer();
AppendData(other.m_pData,other.m_nDataSize);
return *this;
} MBuffer& MBuffer::operator=( const string& other )
{
FreeBuffer();
AppendData((unsigned char*)other.c_str(),other.length());
return *this;
} void MBuffer::clear()
{
FreeBuffer();
} char* MBuffer::substr( int nStart,int iSize )
{
if (nStart > m_nDataSize || iSize < 0 || iSize > m_nDataSize - nStart)
{
return NULL;
}
char *temp = (char*)malloc(iSize + 1);
memcpy(temp,m_pData + nStart,iSize);
temp[iSize] = '\0';
return temp;
} int MBuffer::findlastofindex( char cChr )
{
if (m_pData == NULL || m_nDataSize < 1)
{
return -1;
}
for (int i = m_nDataSize-1 ;i >=0 ; i--)
{
if (m_pData[i] == cChr)
{
return i;
}
}
return -1;
} int MBuffer::findlastofindex( char *cStr )
{
if (m_pData == NULL || cStr == NULL)
{
return -1;
} int i, s1_len = strlen(cStr), end = m_nDataSize - s1_len;
char* last_index = NULL;
for (i = end - 1; i >= 0; i--)
if (!strncmp((char*)(m_pData + i), cStr, s1_len))
return i;
return -1;
} BOOL MBuffer::append( char* str,int nSize /*= 0*/ )
{
if (nSize == 0)
{
nSize = strlen(str);
}
return AppendData((unsigned char*)str,nSize); } BOOL MBuffer::append( unsigned int value )
{
char cBuf[10]={0};
sprintf(cBuf,"%d",value);
return AppendData((unsigned char*)cBuf,strlen(cBuf)); } BOOL MBuffer::append(const MBuffer &other )
{
return AppendData((unsigned char*)other.c_str(),other.length());
} BOOL MBuffer::operator==( const MBuffer& other )
{
BOOL res = TRUE;
if (m_nDataSize != other.m_nDataSize)
{
return FALSE;
}
if (m_nDataSize<=0)
{
return FALSE;
}
for (int i =0;i<m_nDataSize;i++)
{
if (m_pData[i]!= other.m_pData[i])
{
res = FALSE;
break;
}
}
return res;
} bool MBuffer::subbuffer( MBuffer& outBuffer,int istart,int ilen )
{
if (m_nDataSize < istart + ilen || ilen <=0 || istart <0)
{
return false;
} char *sbfer = new char[ilen+1];
memset(sbfer,0,ilen+1);
memcpy(sbfer,m_pData + istart + 1,ilen -1);
outBuffer = sbfer;
delete sbfer;
return true;
}

  如果有bug还请大家帮忙指正,提出大家的宝贵意见,不断完善~谢谢~

重写String类,也有些区别,供参考的更多相关文章

  1. C++ string 类重写

    (我们知道学习C++时,在学习完C的基础内容后最先上手的就是C++的string类来学习字符串处理的内容,这里我们通过重写string类来重新认识字符串处理的内容) 1.树立string类主要函数,确 ...

  2. StringBuffer类和String类(原文地址 : http://www.cnblogs.com/springcsc/archive/2009/12/03/1616330.html)

    StringBuffer类和String一样,也用来代表字符串,只是由于StringBuffer的内部实现方式和String不同,所以StringBuffer在进行字符串处理时,不生成新的对象,在内存 ...

  3. java中String与StringBuilder的区别

    相信大家对 String 和 StringBuffer 的区别也已经很了解了,但是估计还是会有很多同志对这两个类的工作原理有些不清楚的地方,今天我在这里重新把这个概念给大家复习一下,顺便牵出 J2SE ...

  4. 2019第十届蓝桥杯C++B组题解(赛后重写的,不确保答案正确性,仅供参考)

    先说一下这次的感受吧,我们考场比较乱,开始比赛了,还有的电脑有故障,(向这些人发出同情),第一次认真参加比赛,真正比赛的时候感觉没有那么正式,很乱,各种小问题,(例如博主就没找到题目在哪里,找到后又不 ...

  5. NPOI导入导出EXCEL通用类,供参考,可直接使用在WinForm项目中

    以下是NPOI导入导出EXCEL通用类,是在别人的代码上进行优化的,兼容xls与xlsx文件格式,供参考,可直接使用在WinForm项目中,由于XSSFWorkbook类型的Write方法限制,Wri ...

  6. java equals和==区别及string类的说明

    一.equals和==的区别 1.1.equals之string字符串的比较 1.1.1.源码如下图 if (this == anObject) {            return true;  ...

  7. Java中String类两种实例化的区别(转)

    原文:http://blog.csdn.net/wangdajiao/article/details/52087302 一.String类的第一种方式 1.直接赋值 例:String str = &q ...

  8. String类和StringBuffer类的区别

    首先,String和StringBuffer主要有2个区别: (1)String类对象为不可变对象,一旦你修改了String对象的值,隐性重新创建了一个新的对象,释放原String对象,StringB ...

  9. Java基础(32):String与StringBuilder、StringBuffer的区别(String类)

    在Java中,除了可以使用 String 类来存储字符串,还可以使用 StringBuilder 类或 StringBuffer 类存储字符串,那么它们之间有什么区别呢? String 类具有是不可变 ...

随机推荐

  1. 归并树 划分树 可持久化线段树(主席树) 入门题 hdu 2665

    如果题目给出1e5的数据范围,,以前只会用n*log(n)的方法去想 今天学了一下两三种n*n*log(n)的数据结构 他们就是大名鼎鼎的 归并树 划分树 主席树,,,, 首先来说两个问题,,区间第k ...

  2. Fedora22没有i18n文件

    今天想修改Fedora22的系统语言,发现/etc/sysconfig/没有i18n 解决方法: dnf install system-config-language.noarch -y system ...

  3. $().text() 和 $().html()

    1:性能 stackflow:http://stackoverflow.com/questions/1910794/what-is-the-difference-between-jquery-text ...

  4. ./configure 时候报错c++ 编译器不能执行

    ./configure时报错:configure: error: C++ compiler cannot create executables .哎,今天重装测试服务器上的系统,设置好IP可以远程访问 ...

  5. python登陆教务管理系统

    想试着模拟登陆一些网站,这次先拿学校的教务管理系统练练手,写一下登陆的流程. 1.我们登陆的url:http://222.195.8.201,但我们所填的密码不是提交到这个页面上去,检查一下页面代码 ...

  6. QuickTime 专业版 pro 注册码

    打开QuickTime Player下拉编辑菜单--选偏好设置--注册 Name: Dawn M Fredette Key: 4UJ2-5NLF-HFFA-9JW3-X2KV 重新启动 QuickTi ...

  7. 变量数据是怎么进ARM中的RAM中?

    这篇文章 是从网上复制过来的.觉得不错,分享给大家.原文地址:http://eetrend.com/forum/100028828 ARM的体系结构有很多很多介绍的地方,从其7种模式到CPSR状态寄存 ...

  8. 郁闷~win7无法进行局域网访问解决

    win7无法进行局域网访问解决 公司里经常会使用网络共享的文件服务器,但是用win7的那伙计,在输入帐号和密码后却提示密码错误,试验了多次都是如此. 经过网上搜索文章及自己的研究最后发现这是由于win ...

  9. cf A. Down the Hatch!

    http://codeforces.com/contest/332/problem/A #include <cstdio> #include <iostream> #inclu ...

  10. hdu Number Sequence

    这道题是寻找规律.别的方法一般都是超时. #include <cstdio> #include <cstring> #include <algorithm> usi ...