飞秋的不定长度字符串处理方法

本文介绍了一种用于处理不定长字符串的XString类实现。该类通过动态内存分配来支持字符串的添加操作,并提供了获取字符串大小及内容的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

主要用来处理不定长度字符串,飞秋的不定长度字符串处理方法:
#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, n);
  if (!m_x)
  {
   m_x = p;
   return false;
  }

  memcpy(m_x+nOldSize, pData, nLen);
 }
 else
 {
  memcpy(m_x+nOldSize, pData, nLen);
 }

 return true;
} // 飞秋 http://bbs.freeeim.com/ 飞鸽传书

int main(int argc, char* argv[])
{
 XString a;
 for (int i=0; i<100; i++)
 {
  if (! a.AddData("88888888", 8))
  {
   printf("add data failed.\n");
  }
 }

 char *p;
 a.GetData(p);
 printf("%s-%d", p, a.GetSize());
 free(p);
 getchar();
 return 0;
}
// 飞秋 http://bbs.freeeim.com/ 飞鸽传书

### 处理不定长度字符串方法 #### Python中的处理方法 Python 的 `struct` 模块确实存在一些不便之处,尤其是在处理不确定长度的字符串时。为了适应不同长度的字符串,在打包数据前需要先计算字符串的实际长度并将其纳入格式说明符中。例如对于字符串 `'hello'` ,其对应的格式应为 `'5s'` 。如果要处理任意长度的字符串,则可以采用动态构建格式的方式: ```python import struct text = "example" fmt = f"{len(text)}s" packed_data = struct.pack(fmt.encode(), text.encode()) ``` 这种方式能够灵活应对各种长度的输入[^1]。 #### C语言中的解决方案 在C语言里定义字符数组而未明确给出大小的情况下编译器可以根据初始赋值自行决定所需空间量。这使得创建具有特定内容但尺寸可变的数据结构成为可能。下面的例子展示了怎样声明一个由具体成员构成而非预设容量限制的字符序列: ```c char str2[] = {'a', 'b', 'c'}; // 或者更常见的是以null终止符结尾的形式表示字符串 char greeting[] = "Hello"; ``` 当面对完全未知规模的情况时,可以通过分配较大内存区域或者逐步扩展已有的存储区来容纳增长的内容。后者通常涉及重新分配更多资源并将旧有资料复制过去的过程[^2]。 #### 动态管理内存实现自增扩容机制(C++) 针对不断变化的需求场景下高效地管理和调整缓冲区内存是一个重要课题。一种策略是在程序运行期间监控当前占用情况,并适时增加额外的空间供后续追加使用。以下是利用标准库函数完成此功能的一个实例片段: ```cpp size_t arry_size = 10; char* p_str = new char[arry_size]; int count = 0; while (cin.get(temp)) { if (++count >= arry_size) { // 扩展数组大小 char* p_temp = new char[(arry_size *= 2)]; strncpy(p_temp, p_str, count); delete[] p_str; p_str = p_temp; } p_str[count - 1] = temp; } p_str[count] = '\0'; cout << p_str << endl; delete[] p_str; // 清理不再使用的堆内寸 ``` 上述代码通过循环读取用户输入直到结束标志位被触发为止;每当现有容器不足以保存新加入的信息时就会执行一次倍数级别的扩张操作直至满足需求[^3]。 综上所述,无论是静态规划还是按需增量配置都能有效解决不可预见性的字符串长度带来的挑战。选择哪种方式取决于应用场景的具体特点以及性能考量等因素。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值