欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一篇文章帶你了解C語言的一些重要字符串與內(nèi)存函數(shù)

 更新時間:2021年09月22日 15:12:02   作者:qq_59078816  
這篇文章主要介紹了C語言字符函數(shù)、內(nèi)存函數(shù) 功能,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

一.字符串函數(shù)

1. 求字符串長度的strlen

size_t strlen ( const char * str );

  • 字符串以 ‘\0' 作為結(jié)束標志,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é)束標志*str1!=*str2
   return *str2 - *str1;
}

3.復制字符串的strcpy

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

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

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

模擬實現(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é)束。
  • 目標空間必須有足夠的大,能容納下源字符串的內(nèi)容。
  • 目標空間必須可修改。

模擬實現(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是否到達‘0'的位置
			   return cp;
		   cp++, ret2++;
		}
		ret1++;//循環(huán)結(jié)束沒有返回,從下一個字符開始查找
		if (!*ret1)
			return NULL;
	}
	return NULL;
}

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

1.復制 memcpy,memmove

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

dest復制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 };
	// 預期結(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。

也就是說被復制的元素在復制前被改變了,導致復制結(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]);
   }
}

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

對于這種情況,c語言有一個更強大的函數(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ù)在被復制前被改變
	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é),當兩個字節(jié)數(shù)據(jù)不同時就會返回。

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

與strcmp實現(xiàn)類似,這里就不實現(xiàn)了

總結(jié)

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • C語言指針的長度和類型深入分析

    C語言指針的長度和類型深入分析

    這篇文章主要介紹了C語言指針的長度和類型,針對常見的各個類型進行了相對詳細的分析,需要的朋友可以參考下
    2014-09-09
  • C++string字符串拼接遇到的問題及解決

    C++string字符串拼接遇到的問題及解決

    這篇文章主要介紹了C++string字符串拼接遇到的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • C++實現(xiàn)商店倉庫管理系統(tǒng)

    C++實現(xiàn)商店倉庫管理系統(tǒng)

    這篇文章主要為大家詳細介紹了C++實現(xiàn)商店倉庫管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • C++中mutable與volatile的深入理解

    C++中mutable與volatile的深入理解

    這篇文章主要給的阿加介紹了關(guān)于C++中mutable與volatile的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-11-11
  • QT連接Mysql數(shù)據(jù)庫的實現(xiàn)步驟

    QT連接Mysql數(shù)據(jù)庫的實現(xiàn)步驟

    本文主要介紹了QT連接Mysql數(shù)據(jù)庫的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06
  • C/C++內(nèi)存泄漏原因分析與應對方法

    C/C++內(nèi)存泄漏原因分析與應對方法

    內(nèi)存泄漏會導致當前應用程序消耗更多的內(nèi)存,使得其他應用程序可用的內(nèi)存更少了,那么為什么會內(nèi)存泄漏,我們應該怎樣應對內(nèi)存泄漏,所以接下來就給大家詳細介紹一下C++內(nèi)存泄漏原因分析與應對方法,需要的朋友可以參考下
    2023-07-07
  • C++中的重載、覆蓋、隱藏介紹

    C++中的重載、覆蓋、隱藏介紹

    這篇文章主要介紹了C++中的重載、覆蓋、隱藏介紹,需要的朋友可以參考下
    2015-04-04
  • C語言中sizeof函數(shù)踩過的坑總結(jié)

    C語言中sizeof函數(shù)踩過的坑總結(jié)

    sizeof是C語言的一種單目操作符,如C語言的其他操作符++、--等。它并不是函數(shù)。sizeof操作符以字節(jié)形式給出了其操作數(shù)的存儲大小。操作數(shù)可以是一個表達式或括在括號內(nèi)的類型名。操作數(shù)的存儲大小由操作數(shù)的類型決定
    2022-04-04
  • C++實現(xiàn)雷霆戰(zhàn)機可視化小游戲

    C++實現(xiàn)雷霆戰(zhàn)機可視化小游戲

    這篇文章主要為大家詳細介紹了C++實現(xiàn)雷霆戰(zhàn)機可視化小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • 從C語言過渡到C++之基本變化

    從C語言過渡到C++之基本變化

    在之前的C++代碼訓練營系列中,我試圖用完成具體項目的方式給大家介紹C++,但后來大家反饋說這樣從C過渡到C++有點跟不上。于是我又專門設(shè)計了這個《從C到C++》的過渡專題,我準備通過10篇文章介紹一下C++和C的重要區(qū)別。
    2017-07-07

最新評論