国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

常用字符串和內存函數是如何工作的Do you really know?

ashe / 3102人閱讀

摘要:參數指向的字符串必須要以結束。需要注意的是源字符串必須以結束。會將源字符串中的拷貝到目標空間。目標空間必須足夠大,以確保能存放源字符串。舉例最終字符串函數的模擬實現定義兩個數組,首先遍歷到,然后和函數相似開始拷貝即可。

前言:

C語言中對字符和字符串的處理很是頻繁,但是C語言本身是沒有字符串類型的,字符串通常放在 常量字符串 中或者 字符數組 中。
字符串常量適用于那些對它不做修改的字符串函數.


一、長度不受限制的字符串函數

1.1字符串求長——strlen函數

1.1.1strlen函數的介紹

size_t strlen ( const char * str );

這里我們可以看到strlen函數的返回值是size_t
?:1.字符串已經 ‘/0’ 作為結束標志,strlen函數返回的是在字符串中 ‘/0’ 前面出現的字符個數(不包
含 ‘/0’ )。
?:2.參數指向的字符串必須要以 ‘/0’ 結束。
?:3.注意函數的返回值為size_t,是無符號的( 易錯 )
例子:?

#include #include int main(){	if (strlen("abc") - strlen("abcdef") > 0)	{		printf("hehe/n");	}	else	{		printf("haha/n");	}	return 0;}

這里輸出的結果是hehe,因為返回的是無符號整數,這兩哥字符串無論怎么減都是正數。


1.1.2strlen函數的模擬實現

這里直接計算個數即可,較為簡單,不做贅述。

#include#includesize_t my_strlen(const char* str){	int count = 0;	assert(str != NULL);	while (*str)	{		count++;		str++;	}	return count;}int main(){	char arr[] = "pwh";	int len = my_strlen(arr);	printf("%d", len);	return 0;}

1.2字符串拷貝——strcpy函數

1.2.1strcpy函數的介紹

?:strcpy把含有’/0’結束符的字符串復制到另一個地址空間,返回值的類型為char*。

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

需要注意的是:?
1.源字符串必須以 ‘/0’ 結束。
2.會將源字符串中的 ‘/0’ 拷貝到目標空間。
3.目標空間必須足夠大,以確保能存放源字符串。
4.目標空間必須可變。

為什么返回值為char*

返回strDest的原始值使函數能夠支持鏈式表達式,增加了函數的“附加值”。同樣功能的函數,如果能合理地提高的可用性,也就就更加理想。

int iLength=strlen(strcpy(strA,strB));char * strA=strcpy(new char[10],strB);

舉例:?

char a[10],b[]={"PWH"};//定義字符數組a,bstrcpy(a,b);//將數組b中的PWH復制到數組a中

1.2.2strcpy函數的模擬實現

該代碼與strlen函數類似,只需要注意代碼的嚴謹,源地址的不可變性,拷貝至’/0’,數組空間夠大即可。且一定要是字符數組!

#include#includechar* my_strcpy(char* dest, const char* src){	assert(dest != NULL);	assert(src != NULL);	char* ret = dest;	while (*dest++ = *src++)	{		;	}	return ret;}int main(){	char arr1[] = "abcdefghi";	char arr2[] = "bit";	my_strcpy(arr1, arr2);	printf("%s", arr1);	return 0;}

1.3字符串比較——strcmp函數

1.3.1strcmp函數的介紹

 int strcmp(const char *s1,const char *s2);

?:1.第一個字符串大于第二個字符串,則返回大于0的數字
?:2.第一個字符串等于第二個字符串,則返回0
?:3.第一個字符串小于第二個字符串,則返回小于0的數字
?:注意:
比較的是字符串的ASCII碼值!
從第一個字符開始比較,第一個相等就從第二個字符比較,第一個大于返回正數,小于返回負數;然后從第二個開始比較。

#include#includeint main(){	char* p1 = "abcdef";//6	char* p2 = "aqwer";//5	//if("abcdef"=="sqwer")//比較的是地址,所以肯定不相等	int ret = strcmp(p1, p2);//strcmp比較的是每個字符的ASCII碼值	//從第一個開始比較,第一個相等就從第二個字符比較,第一個大于返回1,小于返回-1;然后從第二個	printf("%d/n", ret);	return 0;}

1.3.2strcmp函數的模擬實現

strcmp函數的實現思路為定義兩個數組,且都為不可變,使用while循環從第一個字符開始比較,如果相等則返回0,如果不相等則繼續比較下個字符,字符地址+1,如果大于,返回正數,小于返回負數。

#include#includeint my_strcmp(const char* str1, const char* str2){	assert(str1 && str2);	//比較	while (*str1 == *str2)	{		if (*str1 == "/0")		{			return 0;//相等		}		str1++;		str2++;	}	if (*str1 > *str2)	{		return 1;//大于	}	else	{		return -1;//小于	}}int main(){	char* p1 = "abcdef";	char* p2 = "abqwe";	int ret = my_strcmp(p1, p2);	printf("ret=%d/n", ret);	return 0;}

1.4字符串連接——strcat函數

1.4.1strcat函數的介紹

char *strcat(char *dest, const char *src);

?:把src所指向的字符串(包括“/0”)復制到dest所指向的字符串后面(刪除dest原來末尾的“/0”)。要保證dest足夠長,以容納被復制進來的*src。*src中原有的字符不變。返回指向dest的指針。
舉例:?

#include #include int main (){   char src[50]="source";    char dest[50]="destination";   strcat(dest, src);   printf("最終字符串:%s", dest);   return 0;}

1.4.1strcat函數的模擬實現

?:定義兩個數組,首先遍歷到’/0’,然后和strcpy函數相似開始拷貝即可。

#include #include char* my_strcat(char *dest, const char *src){    assert(dest && src);    char *tmp = dest;    while (*tmp != "/0")    {    	tmp++;    }           while ((*tmp++ = *src++) != "/0");    return dest;}int main(){    char arr1[10] = "pwh";    char arr2[] = "hxs";    char* arr3 = my_strcat(arr1, arr2);    printf("str1=%s/n", arr1);    printf("str2=%s/n", arr2);    printf("str3=%s/n", arr3);    return 0;}

1.5字符串查找——strstr函數

1.5.1strstr函數的介紹

?:返回字符串中首次出現子串的地址
舉例:

int main(){	char* p1 = "abcdefghi";	char* p2 = "defq";	char* ret = strstr(p1, p2);//查找第一次出現的位置	if (ret == NULL)	{		printf("子串不存在/n");	}	else	{		printf("%s/n", ret);	}	return 0;}

1.5.1strstr函數的模擬實現

思路:
盡量不要讓p1,p2走,這樣無法記住它的位置
當相等時,cur作為一個大前提,先在cur的位置使用s1 s2進行查找,如果沒找到,cur++,從下一個字符查找。
這里定義了cur s1 s2,這樣可以互不干擾,然后s1重新等于cur,從此位置++。

char* my_strstr(const char* p1, const char* p2){	assert(p1 != NULL);	assert(p2 != NULL);	//這樣寫可以互不干擾,適用于比較復雜的場景	char* s1 = p1;	char* s2 = p2;	char* cur =(char*) p1;	if (*p2 == "/0")	{		return p1;	}	while (*cur)	{		s1 = cur;		s2 = (char*)p2;		while (*s1 && *s2 && (*s1 == *s2))		{			s1++;			s2++;		}		if (*s2 == "/0")		{			return cur;		}		cur++;	}	return NULL;}int main(){	char* p1 = "abbbcdef";	char* p2 = "bbc";	char* ret = my_strstr(p1, p2);//查找第一次出現的位置	if (ret == NULL)	{		printf("子串不存在/n");	}	else	{		printf("%s/n", ret);	}	return 0;}

二、長度受限制的字符串函數

2.1strncpy函數

char * strncpy ( char * destination, const char * source, size_t num );

2.1.1與strcpy的區別

?:拷貝num個字符從源字符串到目標空間。
?:如果源字符串的長度小于num,則拷貝完源字符串之后,在目標的后邊追加0,直到num個。
?:strncpy越界之后,拷貝完畢會把數組后面的內容全部變為0。

2.1.2strncpy函數的模擬實現

只需要在strcpy基礎上加一個n的限制條件即可。

#include#includechar*my_strncpy(char*dest, const char*src, size_t n){	assert(dest != NULL);	assert(src != NULL);	char*ret = dest;	while (n)	{		*dest = *src;		src++;		dest++;		n--;	}	return ret;} int main(){	char arr1[20] = "hxs";	char arr2[20]= "pwh";	int n = 0;	printf("請輸入需要拷貝的字符個數:/n");	scanf("%d", &n);	char*ret = my_strncpy(arr1,arr2,n);	printf("%s/n", ret);	return 0;}

2.2strncat函數

2.2.1與strncat的區別

?:strncat越界之后,追加完畢后依舊會自動添加’/0’,但和strncpy區別在于,不會把數組后面的元素變為0

2.2.1strncat函數的模擬實現

先遍歷到目標字符串/0處,加一個n的限制條件即可。

#include #include char* my_strncat(const char* dest, const char* src,unsigned n){	assert(dest && src);	char* tmp = dest;	while (*tmp != "/0")	{		tmp++;	}	while (n)	{		*tmp = *src;		tmp++;		src++;		n--;	};	return dest;}int main(){	char arr1[10] = "pwh";	char arr2[10] = "hxs";	int n = 0;	printf("請輸入你要拷貝的字符個數");	scanf("%d", &n);	my_strcat(arr1, arr2,n);	printf("arr1=%s/n", arr1);	return 0;}

2.3strncmp函數

2.3.1與strcmp的區別

?:比較的字符數可控。

2.3.2strncmp函數的模擬實現

沒什么好說的,就是很簡單!這里用for循環更加方便一些。

#include#includeint my_strncmp(const char* str1, const char* str2,unsigned n){	assert(str1 && str2);	//比較	unsigned i = 0;	for (i = 0; i < n - 1 && *str1 && *str2; i++)	{		if (*str1 != *str2)		{			break;		}		str1++;		str2++;	}	return (*str1 - *str2);}int main(){	char* p1 = "abcdef";	char* p2 = "abqwe";	int n = 0;	printf("請輸入要檢驗的字符數");	scanf("%d", &n);	int ret = my_strcmp(p1, p2,n);	printf("ret=%d/n", ret);	return 0;}

三、內存函數

內存函數可以對任意類型的值操作,而字符串函數只能對字符串操作!

3.1memcpy函數

3.1.1memcpy函數的介紹

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

?:1.函數memcpy從source的位置開始向后復制num個字節的數據到destination的內存位置。
?:2.這個函數在遇到 ‘/0’ 的時候并不會停下來。
?:3.如果source和destination有任何的重疊,復制的結果都是未定義的。

3.1.2memcpy函數的模擬實現

將所傳入的指針強制類型轉換為char*類型,這樣可以對于各種類型的數據進行操作,其余過程和strncpy函數比較相似。

struct S{	char name[20];	int age;};void my_memcpy(void* dest, const void* src, size_t num)//void類型不可解引用也不能算術運算{	assert(dest);	assert(src);	void* ret = dest;	while (num--)	{		*(char*)dest = *(char*)src;		++(char*)dest;		++(char*)src;	}	return dest;}int main(){	struct S arr3[] = { {"張三",20},{"李四",30} };	struct S arr4[3] = { 0 };	my_memcpy(arr4, arr3, sizeof(arr3));	//char *dest, const char*src	//memcpy(arr2, arr1, sizeof(arr1));	printf("%d", arr4->age);	return 0
            
                     
             
               

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/120810.html

相關文章

  • 【Java系列】從JVM角度深度解析Java核心類String不可變特性

    摘要:性能,大量運用在哈希的處理中,由于的不可變性,可以只計算一次哈希值,然后緩存在內部,后續直接取就好了。這是目前的一個底層字節碼的實現,那么是不是沒有使用或者的必要了呢。 凱倫說,公眾號ID: KailunTalk,努力寫出最優質的技術文章,歡迎關注探討。 1. 前言 最近看到幾個有趣的關于Java核心類String的問題。 String類是如何實現其不可變的特性的,設計成不可變的好處...

    afishhhhh 評論0 收藏0
  • 這5篇文章將使你成為一個Angular Change Detection專家。

    摘要:編寫工作首先介紹了一個稱為的內部組件表示,并解釋了變更檢測過程在視圖上運行。本文主要由兩部分組成第一部分探討錯誤產生的原因,第二部分提出可能的修正。它對我意義重大,它能幫助其他人看到這篇文章。 在過去的8個月里,我大部分空閑時間都是reverse-engineering Angular。我最感興趣的話題是變化檢測。我認為它是框架中最重要的部分,因為它負責像DOM更新、輸入綁定和查詢列表...

    Coly 評論0 收藏0
  • 《JavaScript Web應用開發》作者Nicolas:恰巧,愛好變職業(圖靈訪談)

    摘要:本文僅用于學習和交流目的,不得用于商業目的。今年,我們依然會組織。隨著語言的發展,這種情況將不再適用。本系列主要討論如何獲得這些高度模塊化的應用程序。這一系列內的后續圖書會討論測試及部署等內容。更多精彩,加入圖靈訪談微信 本文僅用于學習和交流目的,不得用于商業目的。非商業轉載請注明作譯者、出處,并保留本文的原始鏈接:http://www.ituring.com.cn/art... 訪談...

    wawor4827 評論0 收藏0

發表評論

0條評論

ashe

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<