linux内核字符串函数的实现

来源:互联网 发布:mac终端默认路径 编辑:程序博客网 时间:2024/06/10 05:50
公司笔试和面试中常要你编写strcpy/strcmp/memcpy/memcmp/strstr/atoi 等等这样的基础函数的实现。
我想在这儿总结下:(如下代码都是来自最新Linux kernel的库函数)
---------------------------------------------------------------------------------------
  1. //strcpy in linux kernel linux-3.3/linux/lib/string.c
  2. char *strcpy(char *dest, const char *src) { 
  3.          char *tmp = dest; //很多时候可以在这儿对传入参数进行有效检查。内核里面没有这样做。
  4.          while ((*dest++ = *src++) != '\0') 
  5.              /* nothing */; 
  6.     return tmp;
  7.  }
-----------------------------------------------------------------------------------------
  1. int strcmp(const char *cs, const char *ct)
  2.  {
  3.          unsigned char c1, c2;
  4.  
  5.          while (1) {
  6.                  c1 = *cs++;
  7.                  c2 = *ct++;
  8.                  if (c1 != c2)
  9.                          return c1 < c2 ? -: 1;
  10.                  if (!c1)
  11.                          break;
  12.          }
  13.          return 0;
  14.  }
------------------------------------------------------------------------------------------------
  1. void *memcpy(void *dest, const void *src, size_t count)
  2.  {
  3.          char *tmp = dest;
  4.          const char *= src;
  5.  
  6.          while (count--)
  7.                  *tmp++ = *s++;
  8.          return dest;
  9.  }
-----------------------------------------------------------------------------------------------
  1. int memcmp(const void *cs, const void *ct, size_t count) { 
  2.           const unsigned char *su1, *su2; 
  3.           int res = 0; 
  4.        
  5.           for (su1 = cs, su2 = ct; 0 < count; ++su1, ++su2, count--)
  6.                  if ((res = *su1 - *su2) != 0) 
  7.                      break; 
  8.           return res; 
  9. }
-----------------------------------------------------------------------------------------------
  1. char *strstr(const char *s1, const char *s2)
  2.  {
  3.          size_t l1, l2;
  4.  
  5.          l2 = strlen(s2);
  6.          if (!l2)
  7.                  return (char *)s1;
  8.          l1 = strlen(s1);
  9.          while (l1 >= l2) {
  10.                  l1--;
  11.                  if (!memcmp(s1, s2, l2))
  12.                          return (char *)s1;
  13.                  s1++;
  14.          }
  15.          return NULL;
  16.  }
0 0
原创粉丝点击