Author: bakari Date: 2012/8/9
近两年好多的IT公司喜欢拿一些库函数来考,string函数库当然是首选,除此之外,像qsort,STL里的函数也经常火。虽然这些函数咋一看很简单,但有一些细节问题还是很能说明问题,这些细节问题往往就是公司最看重的。吾将之整理作为总结和共享。
下面是我写的代码与源码作的一些比较,均已严格测试通过,分别以“string 之”系列述之。
1 /*******************************************************
2 * strlen
3 * two versions
4 * recursion not use local variable
5 *******************************************************/
6
7 //不使用局部变量(递归求长度)
8 size_t Mystrlen(const char *str){
9 if(*str == '\0')
10 return 0;
11 return strlen(str+1)+1;
12 }
13
14 //用变量辅助
15 size_t Mystrlen(const char *str){
16 int nLen = 0;
17 while(*str ++ != '\0') ++nLen;
18 return nLen;
19 }
20
21 /*********************************************/
22 /* this is source code */
23 size_t Mystrlen(const char *str){
24 const char *repStr = str;
25 for(; *str != '\0'; str ++);
26 return str - repStr;
27 }