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 }