一 概述
假设存在串T = "",S = "HelloWorld?",W = "we"。
StrAssign(&T,chars):赋值操作。把串T赋值为chars。
StrCopy(&T,S):复制操作。由串S复制得到串T。
StrEmpty(S):判空操作。若S为空串,则返回TRUE,否则返回FALSE。
StrLength(&S):求串长。返回串S的元素个数。
DestroyString(&S):销毁串。将串S销毁(回收存储空间)。
ClearString(&S):清空操作。将S清为空串。
concat(&T,S1,S2):串联接。用T返回由S1和S2联接而成的新串。执行联接操作的时候会存在存储空间扩展的问题,所以需要注意存储空间变化的问题。
二 实现串存储结构的两种方式
//静态数组定义串,静态数组实现定长顺序存储,当有关静态数组实现的代码执行成功后,其所占的空间会自动被回收。
struct{
char ch[MAXLEN]; //每个分量存储一个字符串。
int length; //串的实际长度。
}SString;
//动态数组定义串,动态数组实现是基于堆分配存储,当有关动态数组的代码执行完之后,堆空间需要通过free()函数手动回收。
struct{
char *ch;
int length;
}HString;
暂时复习总结至此,待续