亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

c語言重要的字符串與內(nèi)存函數(shù)

 更新時間:2021年09月22日 15:01:00   作者:qq_59078816  
這篇文章主要介紹一些c語言中常用字符串函數(shù)和內(nèi)存函數(shù)的使用和注意事項,并且為了幫助讀者理解和使用,也都模擬實現(xiàn)了他們的代碼,需要的朋友可以參考一下

一.字符串函數(shù)

1. 求字符串長度的strlen

size_t strlen ( const char * str );

  • 字符串以 ‘\0' 作為結(jié)束標(biāo)志,strlen函數(shù)返回的是在字符串中 ‘\0' 前面出現(xiàn)的字符個數(shù)(不包含 ‘\0' )。
  • 參數(shù)指向的字符串必須要以 ‘\0' 結(jié)束。
  • 注意函數(shù)的返回值為size_t,是無符號的。

模擬實現(xiàn)strlen

size_t my_strlen(const char*str)
{ 
  size_t count=0;
  while(*str)
  {
   str++;
   count++;
  }

2.比較字符串大小的strcmp

int strcmp ( const char * str1, const char * str2 );

  • 從str1和str2指向的位置開始比較,如果遇到兩個不相等的字符或者\0函數(shù)結(jié)束并且返回值。
  1. 第一個字符串的字符大于第二個字符串的字符返回 >0的數(shù)字。
  2. 第一個字符串的字符等于第二個字符串的字符返回 =0的數(shù)字。
  3. 第一個字符串的字符小于第二個字符串的字符返回 <0的數(shù)字。

模擬實現(xiàn)strcmp

int my_strcmp(const char*str1,const char*str2)
{
   while (*str1 == *str2)
   {
    if (*str1 && *str2)//判斷'\0'
     return *s2 - *s1;
    *str1++;
    *str2++;
   }//循環(huán)結(jié)束標(biāo)志*str1!=*str2
   return *str2 - *str1;
}

3.復(fù)制字符串的strcpy

char* strcpy(char * destination, const char * source)

拷貝sourcedestination中,返回一個指向dest的char* 的指針。

  • 源字符串必須以 ‘\0' 結(jié)束。
  • 會將源字符串中的 ‘\0' 拷貝到目標(biāo)空間。
  • 目標(biāo)空間必須足夠大,以確保能存放源字符串。
  • 目標(biāo)空間必須可變。

模擬實現(xiàn)strcpy

char *my_strcpy(char *dest, const char*src)
{ 
 char *ret = dest;
 while((*dest++ = *src++))
 {
  ;
 }
 return ret;
}

4.追加字符串的strcat

char * strcat ( char * destination, const char * source );

從dest的末尾 ‘\0'開始添加src直到‘\0'

  • 源字符串必須以 ‘\0' 結(jié)束。
  • 目標(biāo)空間必須有足夠的大,能容納下源字符串的內(nèi)容。
  • 目標(biāo)空間必須可修改。

模擬實現(xiàn)strcat

char* my_strcat(const char* str1, const char* str2)
{
 
  while (*str1) str1++;
  while (*(char*)str1++ = *(char*)str2++) {
   ;
  }
}

5.查找字符串函數(shù)的strstr

char * strstr ( const char *str2, const char * str1);

在str2中查找str1的字符串,如果找到了返回str2中這個字符串的首地址。如果找不到返回NULL。.0

char* my_strstr(const char* str1, const char* str2)
{
 if (!*str2)//判斷字符串是否為空
  return (char*)str1;

  char* ret1= (char*)str1;//將str類型轉(zhuǎn)換
  
  char *cp = ret1;
 while (*ret1)
 {
  cp = ret1;
  char* ret2 =(char*) str2;
  while (*cp== *str2) {//遍歷字符串
           
     if (!*ret2)//判斷str2是否到達(dá)‘0'的位置
      return cp;
     cp++, ret2++;
  }
  ret1++;//循環(huán)結(jié)束沒有返回,從下一個字符開始查找
  if (!*ret1)
   return NULL;
 }
 return NULL;
}

二、內(nèi)存函數(shù)

1.復(fù)制 memcpy,memmove

void * memcpy ( void * destination, const void * source, size_t num );

dest復(fù)制src中num字節(jié)的數(shù)據(jù)。

模擬實現(xiàn)memcpy

void * my_memcpy ( void * dst, const void * src, size_t count)
{
  void * ret = dst;
  while (count--) {
    *(char *)dst = *(char *)src;
    dst = (char *)dst + 1;
    src = (char *)src + 1;
  }
 
  return(ret);
}

·如果dst 和src指向同一個數(shù)組會發(fā)生什么?

int main()
{
 int arr1[10] = { 1,2,3,4,5,6,7,8,9,0 };
 // 預(yù)期結(jié)果       1 2 1 2 3 4 7 8 9 0
 my_memcpy(arr1+2, arr1, 16);

  for (int i = 0; i < 10; i++)
  {
   printf("%d ", arr1[i]);
 }
}

實際為 1 2 1 2 1 2 7 8 9 0
因為到5 6 的時候3 4被改成了1 2 ,5 6也就被改成1 2。
也就是說被復(fù)制的元素在復(fù)制前被改變了,導(dǎo)致復(fù)制結(jié)果失敗。
如果是這樣指向同一個數(shù)組呢?

int main()
{
   int arr1[10] = { 1,2,3,4,5,6,7,8,9,0 };
   my_memcpy(arr1, arr1+2, 16);

    for (int i = 0; i < 10; i++)
    {
     printf("%d ", arr1[i]);
   }
}

復(fù)制結(jié)果沒有問題。

對于這種情況,c語言有一個更強(qiáng)大的函數(shù)memmove.

void * memmove( void * destination, const void * source, size_t num );

  • 與memcpy的功能一樣,但是memmove可以指向同一塊空間。

模擬實現(xiàn)memmove

**void* my_memmove(void* dest, void* src, size_t num)
{
 char* ret = dest;
 //如果指向同一塊空間 判斷地址大小,避免數(shù)據(jù)在被復(fù)制前被改變
 if ( (char*)dest-(char*)src< 0){
  while (num)
  {

   *((char*)dest)++ = *((char*)src)++;
   num--;
  }
 }
 else {
  while(num--){
   *((char*)dest+num) = *((char*)src+num);
  }
 }
 return ret;
}

2.比較 memcmp

int memcmp ( const void * ptr1, const void * ptr2, size_t num );

從ptr1和ptr2的位置開始比較num個字節(jié),當(dāng)兩個字節(jié)數(shù)據(jù)不同時就會返回。

  • ptr1>ptr2 返回值>0;
  • ptr1=ptr2 返回值=0;
  • ptr1<ptr2 返回值<0;

到此這篇關(guān)于c語言重要的字符串與內(nèi)存函數(shù)的文章就介紹到這了,更多相關(guān)c語言的字符串與內(nèi)存函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++深入淺出講解隱藏this指針的用法

    C++深入淺出講解隱藏this指針的用法

    在C++中,每一個對象都能通過this指針來訪問自己的地址。this?指針是所有成員函數(shù)的隱含參數(shù)。因此,在成員函數(shù)內(nèi)部,它可以用來指向調(diào)用對象
    2022-05-05
  • 詳解C標(biāo)準(zhǔn)庫堆內(nèi)存函數(shù)

    詳解C標(biāo)準(zhǔn)庫堆內(nèi)存函數(shù)

    在C/C++語言中,我們知道內(nèi)存分為這幾種:程序全局變量內(nèi)存、棧內(nèi)存、堆內(nèi)存。其中堆內(nèi)存就是通過malloc(new)來分配的內(nèi)存,本文我們來探討一下C標(biāo)準(zhǔn)庫堆內(nèi)存函數(shù)。
    2021-06-06
  • Qt+OpenCV實現(xiàn)目標(biāo)檢測詳解

    Qt+OpenCV實現(xiàn)目標(biāo)檢測詳解

    這篇文章主要介紹了如何利用Qt和OpenCV中自帶xml文件實現(xiàn)目標(biāo)檢測,文中的實現(xiàn)過程講解詳細(xì),感興趣的小伙伴可以動手試一試
    2022-03-03
  • C++ 中靜態(tài)成員函數(shù)與非靜態(tài)成員函數(shù)的區(qū)別

    C++ 中靜態(tài)成員函數(shù)與非靜態(tài)成員函數(shù)的區(qū)別

    這篇文章主要介紹了C++ 中靜態(tài)成員函數(shù)與非靜態(tài)成員函數(shù)的區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • C++ opencv ffmpeg圖片序列化實現(xiàn)代碼解析

    C++ opencv ffmpeg圖片序列化實現(xiàn)代碼解析

    這篇文章主要介紹了C++ opencv ffmpeg圖片序列化實現(xiàn)代碼解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-08-08
  • C/C++百行代碼實現(xiàn)熱門游戲消消樂功能的示例代碼

    C/C++百行代碼實現(xiàn)熱門游戲消消樂功能的示例代碼

    這篇文章主要介紹了C/C++百行代碼實現(xiàn)熱門游戲消消樂功能的示例代碼,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • C++動態(tài)內(nèi)存管理詳解

    C++動態(tài)內(nèi)存管理詳解

    今天小編就為大家分享一篇關(guān)于關(guān)于C++動態(tài)分配內(nèi)存的介紹,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2021-08-08
  • C語言多組輸入使用方法

    C語言多組輸入使用方法

    這篇文章主要給大家介紹了關(guān)于C語言多組輸入使用的相關(guān)資料,在 C語言中可以使用循環(huán)語句來實現(xiàn)多組輸入,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • C語言庫函數(shù)getchar()新見解

    C語言庫函數(shù)getchar()新見解

    用getchar()函數(shù)讀取字符串時,字符串會存儲在輸入緩沖區(qū)中,包括輸入的回車字符,下面這篇文章主要給大家介紹了關(guān)于C語言中g(shù)etchar()的用法以及案例的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • 詳解C語言處理算經(jīng)中著名問題百錢百雞

    詳解C語言處理算經(jīng)中著名問題百錢百雞

    古代的很多數(shù)學(xué)問題都可以用現(xiàn)代的編程語言去嘗試解決,就如本篇,將會帶你通過C語言來解決算經(jīng)中百錢百雞問題,感興趣的朋友來看看吧
    2022-02-02

最新評論