模擬實現不受限制的字串函式--C語言版

每天和鍵盤在一起發表於2023-05-18

C語言中提供了許多十分好用的庫函式,一旦我們掌握了它們,我們使用C語言寫程式碼就會變得更加得心應手。


1.strlen

strlen函式就是計算字串的長度的,它會一直讀取到\0,它的返回值就是在字串中'\0' 前面出現的字元個數(不包括\0)。 而瞭解strlen的實現原理也會讓我們更好的理解程式碼


//模擬實現strlen

// 計算器版本

//#include<stdio.h>

//#include<assert.h>

//int my_strlen(const char *str)

//{

//  assert(str);

//  int count = 0;

//  while (*str++ != 0)

//  {

//    count++;

//  }

//  return count;

//}

//

//int main()

//{

//  char arr[] = {"abcdef"};

//  int ret = my_strlen(arr);

//  printf("%d", ret);

//  return 0;

//}



當然,strlen絕對不止這一種寫法,如果各位想看,可以移步 strlen的三種模擬實現方法


2.stccpy

strcpy是將字串b複製到字串a上,其中源字串必須要以\0結束,並且目標字串必須要有足夠大的空間


#include<stdio.h>

#include<string.h>

void mine_strcpy(char* dest, char* sou)

{

  while (*dest++ = *sou++)//當sou將\0傳給dest時,while裡面的值是0,自動結束了迴圈---既copy了\0

                          //又使迴圈停止

  {

    ;

  }

}

int main()

{

  char arr1[] = "aaaaaaaaaaaaaa";

  char arr2[] = "hello";

  mine_strcpy(arr1, arr2);

  printf("%s\n", arr1);

  return 0;

}


3.strcat

strcat是字串追加函式,目標字串必須要有足夠大的空間去容納原字串,並且原字串必須要以\0結尾 strcat的模擬實現:首先需要找到目標字串的\0位置,接著要在\0的位置,將要複製的字串複製過去即可。


#include<stdio.h>

#include<string.h>

#include<assert.h>

char* my_strcat(char* dest, const char* src)

{

   assert(dest && src);

   char* ret = dest;

   //1.找到目標字串的\0

   while (*dest)

   {

      dest++;

   }

   //2.接著追加過去(包括\0)(就是strcpy的思路)

   while (*dest++ = *src++)

   {

      ;

   }

   return ret;

}

int main()

{

   char arr1[50] = {"stay foolish,"};

   char arr2[20] = {"stay hungry"};

   //my_strcat(arr1, arr2);

   printf("%s", my_strcat(arr1, arr2));//鏈式訪問

   return 0;

}


4.strcmp

strcmp就是比較兩個字串的大小 strcmp的實現思路就是一個一個字元的進行比較,知道找到不一樣的或者全部一樣的為止


//模擬實現strcmp

#include<stdio.h>

#include<assert.h>

int my_strcmp(const char* p,const char* q)

{

  assert(p && q);

  while (*p == *q)

  {

    if (*p == '\0')//*q也為'\0'

    {

      return 0;

    }

    p++;

    q++;

  }

  //if (*p > *q)

  //  return 1;

  //else

    //return -1;

  return  *p - *q;

}

int main()

{

  char p[] = "abcd";

  char q[] = "abe";

  int ret = my_strcmp(p, q);

  if (ret > 0)

    printf("p>q\n");

  else if (ret < 0)

    printf("p<q\n");

  else

    printf("p==q\n");

  return 0;

}


以上介紹的都是長度不受限制等函式, 歡迎關注,感謝大家的支援!


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/70030112/viewspace-2953163/,如需轉載,請註明出處,否則將追究法律責任。

相關文章