91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C語言的一些重要字符串與內存函數是怎樣的

發布時間:2021-09-24 17:03:44 來源:億速云 閱讀:144 作者:柒染 欄目:開發技術

本篇文章為大家展示了C語言的一些重要字符串與內存函數是怎樣的,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

    一.字符串函數

    1. 求字符串長度的strlen

    size_t strlen ( const char * str );

    • 字符串以 ‘\0' 作為結束標志,strlen函數返回的是在字符串中 ‘\0' 前面出現的字符個數(不包含 ‘\0' )。

    • 參數指向的字符串必須要以 ‘\0' 結束。

    • 注意函數的返回值為size_t,是無符號的。

    模擬實現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函數結束并且返回值。

    1 第一個字符串的字符大于第二個字符串的字符返回 >0的數字。

    2 第一個字符串的字符等于第二個字符串的字符返回 =0的數字。

    3 第一個字符串的字符小于第二個字符串的字符返回 <0的數字。

    模擬實現strcmp

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

    3.復制字符串的strcpy

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

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

    • 源字符串必須以 ‘\0' 結束。

    • 會將源字符串中的 ‘\0' 拷貝到目標空間。

    • 目標空間必須足夠大,以確保能存放源字符串。

    • 目標空間必須可變。

    模擬實現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' 結束。

    • 目標空間必須有足夠的大,能容納下源字符串的內容。

    • 目標空間必須可修改。

    模擬實現strcat

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

    5.查找字符串函數的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類型轉換
    	 char *cp = ret1;
    	while (*ret1)
    	{
    		cp = ret1;
    		char* ret2 =(char*) str2;
    		while (*cp== *str2) {//遍歷字符串
    		   if (!*ret2)//判斷str2是否到達‘0'的位置
    			   return cp;
    		   cp++, ret2++;
    		}
    		ret1++;//循環結束沒有返回,從下一個字符開始查找
    		if (!*ret1)
    			return NULL;
    	}
    	return NULL;
    }

    二、內存函數

    1.復制 memcpy,memmove

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

    dest復制src中num個字節的數據。

    模擬實現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指向同一個數組會發生什么?

    int main()
    {
    	int arr1[10] = { 1,2,3,4,5,6,7,8,9,0 };
    	// 預期結果       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。

    也就是說被復制的元素在復制前被改變了,導致復制結果失敗。

    如果是這樣指向同一個數組呢?

    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]);
       }
    }

    復制結果沒有問題。

    對于這種情況,c語言有一個更強大的函數memmove.

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

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

    模擬實現memmove

    **void* my_memmove(void* dest, void* src, size_t num)
    {
    	char* ret = dest;
    	//如果指向同一塊空間 判斷地址大小,避免數據在被復制前被改變
    	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個字節,當兩個字節數據不同時就會返回。

    • ptr1>ptr2 返回值>0;

    • ptr1=ptr2 返回值=0;

    • ptr1<ptr2 返回值<0;

    與strcmp實現類似,這里就不實現了

    上述內容就是C語言的一些重要字符串與內存函數是怎樣的,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    故城县| 尼玛县| 上杭县| 分宜县| 会昌县| 常熟市| 韩城市| 郴州市| 屯留县| 公安县| 沽源县| 太仓市| 阳新县| 久治县| 商水县| 昭苏县| 龙岩市| 个旧市| 左云县| 绥中县| 宁都县| 廉江市| 东源县| 陆川县| 桂阳县| 谷城县| 克什克腾旗| 鹿泉市| 靖州| 水富县| 美姑县| 吉隆县| 菏泽市| 来凤县| 铜山县| 元阳县| 景德镇市| 北辰区| 陆河县| 黄骅市| 东山县|