linux内核字符串函数的实现

公司笔试和面试中常要你编写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.  }
-----------------------------------------------------------------------------------------------
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值