C++不定長文字列の比較的合理的かつ簡単な解決方法
1886 ワード
これは飛秋の時に使ったコードを書いて、前回送ったバージョンは少し問題があって、完璧ではありませんて、今回テストを経てそれに修正して、基本的に使用することができると感じて、もしあなたが自分で書きたくないならば、それは私のコードを使うことができます.
私のコードは100%完璧とは言えませんが、メモリの漏洩は最小限です.また、何か足りないことがあったら、メッセージをください.感謝にたえない.
私のコードは100%完璧とは言えませんが、メモリの漏洩は最小限です.また、何か足りないことがあったら、メッセージをください.感謝にたえない.
// testrealloc.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include
#include
#include
#define XString_LENGTH 1024 //
class XString
{
char *m_x;
unsigned int m_size;
public:
XString();
~XString();
unsigned int GetSize();
unsigned int GetData(char *&pData);
bool AddData(char *pData, unsigned int nLen);
};
XString::XString()
{
m_size = 0;
m_x = (char*)malloc(XString_LENGTH);
}
XString::~XString()
{
if (m_x)
{
free(m_x);
m_x = NULL;
}
}
unsigned int XString::GetSize()
{
return m_size;
}
unsigned int XString::GetData(char * &pData)
{
pData = (char*)malloc(m_size+1);
if (!pData)
return 0;
memcpy(pData, m_x, m_size);
pData[m_size] = NULL;
return m_size+1;
}
bool XString::AddData(char *pData, unsigned int nLen)
{
if (nLen <= 0)
return false;
if (! pData)
return false;
unsigned nOldSize = m_size;
m_size += nLen;
if (m_size > XString_LENGTH)
{
// int n = m_size - XString_LENGTH;
char *p = m_x;
m_x = (char*)realloc(m_x, m_size);
if (!m_x)
{
m_x = p;
return false;
}
memcpy(m_x+nOldSize, pData, nLen);
// m_x[m_size]=NULL;
// printf("%s-%d
", m_x, m_size);
// getchar();
}
else
{
memcpy(m_x+nOldSize, pData, nLen);
}
return true;
}
void k() // http://bbs.freeeim.com/
{
XString a;
for (int i=0; i<3000; i++)
{
if (! a.AddData("88888888", 8))
{
printf("add data failed.
");
}
}
getchar();
}
int main(int argc, char* argv[])
{
for(int i=0; i<100; i++)
{
k();
}
getchar();
return 0;
}