C语言中常用的字符串函数源码.pdf

  1. 1、本文档共37页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C语言中常用的字符串函数源码

strtok (分解字符串为一组字符串。):位操作与空间压缩实现strtok 1/3 char * mystrtok(char * _Str, const char * _Delim); 函数可以用于分解字符串,最近看了 下这个函数的源代码,其中有 1. unsigned char map[3 ]; . 3. // Clear control map 4. for (int count = 0; count 3 ; count++) 5. { 6. map[count] = 0; 7. } 8. 9. 10. // Set bits in delimiter table 11. do 1 . { 13. map[*delim 3] |= (1 (*delim 7)); 14. } while (*delim++); 这段代码非常有意思, 一眼可能不明白,为什么用个 unsigned char map[3 ]; 数组来保存分隔 字符。下面的 map[*delim 3] |= (1 (*delim 7)); 更加有点古怪。在网上查了下,并没 有文章来解释,因此写篇博客来解释说明下。 这个长为 32 的数组 (unsigned char map[3 ])与后面的左移,右移操作看起来迷惑,其实如果 看过 《位操作之基础篇》中的“3、位操作与空间压缩”便不难想到,这里其实是个位操作的空间压缩 技巧。 因此 char 类型的数据只会从 0 到 255,因此建立一个哈希表来记录哪些字符要分割,需要则标记为 1,否则标记为 0,然后在分隔字符串时,就能直接判断字符串的该位置是否要分割。 详细请见 mystrtok 的实现。 1. /* . * char * mystrtok(char * _Str, const char * _Delim); 3. * 分解字符串为一组字符串。_Str为要分解的字符串,_Delim为分隔符字符串。 4. */ 5. #define _CRT_SECURE_NO_WARNINGS 6. #includestdio.h 7. #includestdlib.h 8. #includestring.h 9. 10. #define STRING_MAX_SIZE 10 4 11. 1 . char * mystrtok(char * _Str, const char * _Delim); 13. 14. char * mystrtok(char * _Str, const char * _Delim) 15. { 16. unsigned char * str; //存储当前分割出来的字符串 17. const unsigned char * delim = (const unsigned char *)_Delim; //分割字符串 18. static unsigned char * _Token = NULL; //分割后的字符串 19. //注意这里使用了static类型,实际的strtok函数出于线程安全会使用TLS 0. 1. //由于char类型占一个字节取值范围为0~ 55 . //所以可以打个map[ 55]这样的哈希表, 3. //但是为了节约内存,可以通过位操作,一个char类型有8位,也就是说可存储8个char类型字节,那 strtok (分解字符串为一组字符串。):位操作与空间压缩实现strtok 2/3 最终只需要map[3 ],足足节约了 3个字节。 4. unsigned char map[3 ]; 5. 6. //置空map[3 ] 7. for (int count = 0; count 3 ; count++)

文档评论(0)

yaocen + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档