C/C++ 内存块和字符串操作函数

一、 内存块操作:
1. 将dest前面count个字符置为字符c,返回dest的值
void memset ( void *dest,int c,size_t count );

2. 从src复制count字节的字符到dest,返回dest的值。
      如果src和dest出现重叠,函数会自动处理。
void memmove (void *dest,const void *src,size_t count);

3. 从src复制count字节的字符到dest,返回dest的值。
      与memmove功能一样,只是不能处理src和dest出现重叠
void memcpy (void *dest,const void *src,size_t count);

  4. 在buf前面count字节中查找首次出现字符c的位置,
      操作成功则返回buf中首次出现c的位置指针,否则返回NULL。
      找到了字符c或者已经搜寻了count个字节,查找即停止。
void* memchr(const void *buf,int c,size_t count);

5. 从src复制0个或多个字节的字符到dest,
      当字符c被复制或者count个字符被复制时,复制停止。
      如果字符c被复制,函数返回这个字符后面紧挨一个字符位置的指针,否则返回NULL。
void * memccpy(void *dest,const void *src,int c,size_t count);

6. 比较buf1和buf2前面count个字节大小。
      返回值 < 0,表示buf1小于buf2;
      返回值为0,表示buf1等于buf2;
 返回值 > 0,表示buf1大于buf2;
int memcmp(const void *buf1,const void *buf2,size_t count);

7. 比较buf1和buf2前面count个字节。
  与memcmp不同的是它不区分大小写,相同的是返回值。
int memicmp(const void *buf1,const void *buf2,size_t count);

二、字符串操作:
1. 获取字符串长度,字符串结束符NULL不计算在内。
  没有返回值指示操作错误。
size_t strlen(const char *string);

2. 将字符串string中的字符顺序颠倒过来,NULL结束符位置不变。
  返回调整后的字符串的指针
char* strrev(char *string);

3. 将string中所有小写字母替换成相应的大写字母,其它字符保持不变。
  返回调整后的字符串的指针。
char* strupr(char *string);

4. 将string中所有大写字母替换成相应的小写字母,其它字符保持不变。
 返回调整后的字符串的指针。
char* strlwr(char *string);

5. 查找字符c在字符串string中首次出现的位置,NULL结束符也包含在查找中。
 返回一个指针指向字符c在字符串string中首次出现的位置。没有找到,则返回NULL。
char* strchr(const char *string,int c);

6. 查找字符c在字符串string中最后一次出现的位置,
  也就是对string进行反序搜索,包含NULL结束符。
 返回一个指针,指向字符c在字符串string中最后一次出现的位置,
 如果没有找到,则返回NULL。
char* strrchr(const char *string,int c);

7. 在字符串string中查找strSearch子串。
      返回子串strSearch在string中首次出现位置的指针。
  如果没有找到子串strSearch,则返回NULL。
  如果子串strSearch为空串,函数返回string的指针。
char* strstr(const char *string,const char *strSearch);

8. 函数运行中会自己调用malloc函数为复制strSource字符串分配存储空间,
  然后再将strSource复制到分配到的空间中。
  注意要及时释放这个分配的空间。
  返回一个指针指向为复制字符串分配的空间。
 如果分配空间失败,则返回NULL值。
char* strdup(const char *strSource);

9. 将源串strSource添加到目标串strDestination后面,
  并在得到的新串后面加上NULL结束符。
  源串strSource的字符会覆盖目标串strDestination后面的结束符NULL。
  在字符串的复制或添加过程中没有溢出检查,所以要保证目标串空间足够大。
  不能处理源串与目标串重叠的情况。
  函数返回strDestination值。
char* strcat(char *strDestination,const char *strSource);

10. 将源串strSource开始的count个字符添加到目标串strDest后。
    源串strSource的字符会覆盖目标串strDestination后面的结束符NULL。
    如果count大于源串长度,则会用源串的长度值替换count值。
    得到的新串后面会自动加上NULL结束符。
    与strcat函数一样,本函数不能处理源串与目标串重叠的情况。
    函数返回strDestination值。
char* strncat(char *strDestination,const char *strSource,size_t count);

11. 复制源串strSource到目标串strDestination所指定的位置,包含NULL结束符。
  不能处理源串与目标串重叠的情况,函数返回strDestination值。
char* strcpy(char *strDestination,const char *strSource);

12. 将源串strSource开始的count个字符复制到目标串strDestination所指定的位置。
    如果count值小于或等于strSource串的长度,不会自动添加NULL结束符到目标串中。
    如果count大于strSource串的长度时,
    则将strSource用NULL结束符填充补齐count个字符,复制到目标串中。
    不能处理源串与目标串重叠的情况,函数返回strDestination值。
char* strncpy(char *strDestination,const char *strSource,size_t count);

13. 将string串的所有字符设置为字符c,遇到NULL结束符停止。
    函数返回内容调整后的string指针。
char* strset(char *string,int c);

14. 将string串开始count个字符设置为字符c,
    如果count值大于string串的长度,将用string的长度替换count值。
    函数返回内容调整后的string指针。
char* strnset(char *string,int c,size_t count);

15. 查找任何一个不包含在strCharSet串中的字符 (字符串结束符NULL除外)
    在string串中首次出现的位置序号。
    返回一个整数值,指定在string中全部由characters中的字符组成的子串的长度。
    如果string以一个不包含在strCharSet中的字符开头,函数将返回0值。
size_t strspn(const char *string,const char *strCharSet);

16. 查找strCharSet串中任何一个字符在string串中首次出现的位置序号,
    包含字符串结束符NULL。
    返回一个整数值,指定在string中全部由非characters中的字符组成的子串的长度。
    如果string以一个包含在strCharSet中的字符开头,函数将返回0值。
size_t strcspn(const char *string,const char *strCharSet);

17. 查找任何一个不包含在strCharSet串中的字符 (字符串结束符NULL除外)
    在string串中首次出现的位置指针。
    返回一个指针,指向非strCharSet中的字符在string中首次出现的位置。
char* strspnp(const char *string,const char *strCharSet);

18. 查找strCharSet串中任何一个字符在string串中首次出现的位置,
    不包含字符串结束符NULL。
    返回一个指针指向strCharSet中任一字符在string中首次出现的位置。
    如果两个字符串参数不含相同字符,则返回NULL值。
char* strpbrk(const char *string,const char *strCharSet);

19. 比较字符串string1和string2大小。
    返回值 < 0,表示string1小于string2;
    返回值为0,表示string1等于string2;
    返回值 > 0,表示string1大于string2;
int strcmp(const char *string1,const char *string2);

20. 比较字符串string1和string2大小,和strcmp不同,比较的是它们的小写字母版本。
    返回值与strcmp相同。
int stricmp(const char *string1,const char *string2);

21. 等价于stricmp函数,只是提供一个向后兼容的版本。
int strcmpi(const char *string1,const char *string2);

22. 比较字符串string1和string2大小,只比较前面count个字符。
    比较过程中任何一个字符串的长度小于count,则count将被较短的字符串的长度取代。
    此时如果两串前面的字符都相等,则较短的串要小。
    返回值< 0,表示string1的子串小于string2的子串;
    返回值为0,表示string1的子串等于string2的子串;
    返回值> 0,表示string1的子串大于string2的子串;
int strncmp(const char *string1,const char *string2,size_t count);

23. 比较字符串string1和string2大小,只比较前面count个字符。
  与strncmp不同的是,比较的是它们的小写字母版本。
  返回值与strncmp相同。
int strnicmp(const char *string1,const char *string2,size_t count);

24. 在strToken 串中查找下一个标记,
     strDelimit字符集则指定了在当前查找调用中可能遇到的分界符。
     返回一个指针指向在strToken中找到的下一个标记。
     如果找不到标记,就返回NULL值。
     每次调用都会修改strToken内容,用NULL字符替换遇到的每个分界符。
char* strtok(char *strToken,const char *strDelimit);
char input[16] = "abc,d";
char *p = NULL;

p = strtok(input, ",");

if (p)
      printf("%sn", p);

p = strtok( NULL, ",");

if (p)
      printf("%sn", p);

return 0;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值