中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

C語言字符串函數與內存函數怎么用

發布時間:2022-04-24 10:28:12 來源:億速云 閱讀:127 作者:iii 欄目:開發技術

這篇“C語言字符串函數與內存函數怎么用”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“C語言字符串函數與內存函數怎么用”文章吧。

strlen

獲取字符串長度。

strlen - size_t strlen( const char *string );

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

2.參數指向的字符串必須要以’\0’結束。

3.注意函數的返回值為size_t,是無符號的(易錯)

C語言字符串函數與內存函數怎么用

strlen模擬實現

//size_t strlen(const char *string);
#include<stdio.h>
#include<assert.h>
size_t my_strlen(const char* str)
{
	assert(str != NULL);
	int count = 0;
	while (*str)
	{
		count++;
		str++;
	}
	return count;
}
int main()
{
	int len = my_strlen("abcedfg");
	printf("%d\n", len);
	return 0;
}

strcpy

復制一個字符串

strcpy - char *strcpy( char *strDestination, const char *strSource );

1.源字符串必須以&rsquo;\0&rsquo;結束。

2.會將源字符串中的&rsquo;\0&rsquo;拷貝到目標空間。

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

4.目標空間必須可變。

strcpy的模擬實現

#include<stdio.h>
#include<assert.h>
char* my_strcpy(char* dest, const char* src)
{
	assert(dest && src);
	char* ret = dest;
	//將src指向的字符串拷貝到dest指向的空間中,包括'\0'
	while (*dest++ = *src++)
		;
	//返回目的地空間的起始地址
	return ret;
}
int main()
{
	//char* arr1 = "abcdefghi";//err  目標空間必須可變
	char arr1[] = "abcdefghi";
	//char arr2[] = { 'h','e','l','l','o' };//err  源字符串必須以'\0'結尾
	char arr2[] = "hello";
	my_strcpy(arr1, arr2);
	printf(arr1);
	return 0;
}

strcat

字符串追加

strcat - char *strcat( char *strDestination, const char *strSource );

1.源字符串必須以&rsquo;\0&rsquo;結束。

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

3.目標空間必須可修改。

4.不能自己給自己追加。

strcat的模擬實現

#include<stdio.h>
#include<assert.h>
char* my_strcat(char* dest, char* src)
{
	char* ret = dest;
	assert(dest && src);
	//1.找到目的字符串中的'\0'
	while (*dest)
		dest++;
	//2.追加
	while (*dest++ = *src++)
		;
	return ret;
}
int main()
{
	char arr1[37] = "hello";
	char arr2[] = "world";
	my_strcat(arr1, arr2);//在arr1后面追加arr2
	printf("%s\n", arr1);
	return 0;
}

strcmp

字符串比較

C語言字符串函數與內存函數怎么用

strcmp模擬實現

#include<stdio.h>
#include<assert.h>
int my_strcmp(const char* str1, const char* str2)
{
	assert(str1 && str2);
	while (*str1 == *str2)
	{
		if (*str1 == '\0')
		{
			return 0;//相等
		}
		str1++;
		str2++;
	}
	return *str1 - *str2;
}
int main()
{
	char* p1 = "abcdef";
	char* p2 = "abqjf";
	int ret = my_strcmp(p1, p2);
	printf("%d\n", ret);
	return 0;
}

strncpy

將一個字符串中的字符復制到另一個字符串中。

strncpy - char *strncpy( char *strDest, const char *strSource, size_t count );

1.拷貝count個字符從源字符串到目標空間。

2.如果源字符串的長度小于count,則拷貝完源字符串之后,在目標的后邊追加0,直到count個。

strncpy模擬實現

char* my_strncpy(char* dest, const char* src, size_t count)
{
	char* ret = dest;
	while (count && (*dest++ = *src++))
	{
		count--;
	}
	if (count)
	{
		while (--count)
		{
			*dest++ = '\0';
		}
	}
	return ret;
}
int main()
{
	char arr1[20] = { 0 };
	char arr2[] = "hey";
	my_strncpy(arr1, arr2, 6);
	printf(arr1);
	return 0;
}

strncat

字符串的附加字符。

strncat - char *strncat( char *Dest, const char *Source, size_t count );

strncat模擬實現

char* my_strncat(char* dest, const char* src, size_t count)
{
	char* ret = dest;
	while (*dest++)
		;
	dest--;
	while (count--)
	{
		if (!(*dest++ = *src++))
		{
			return ret;
		}
	}
	*dest = '\0';
	return ret;
}
int main()
{
	char arr1[37] = "hello";
	char arr2[] = "world";
	my_strncat(arr1, arr2, 7);
	puts(arr1);
	return 0;
}

strncmp

比較兩個字符串的字符。

strncmp - int strncmp( const char *string1, const char *string2, size_t count );

1.比較到出現一個字符不一樣或者一個字符串結束或者count個字符串全部比較完。

C語言字符串函數與內存函數怎么用

C語言字符串函數與內存函數怎么用

strstr

查找子字符串

strstr - char *strstr( const char *string, const char *strCharSet );

1.每個函數都返回一個指向strCharSet在string中首次出現的指針,如果strCharSet沒有在string中出現,則返回NULL。如果strCharSet指向長度為0的字符串,則函數返回string。

strstr模擬實現

#include<stdio.h>
#include<assert.h>
char* my_strstr(const char* str1, const char* str2)
{
	assert(str1 && str2);
	char* cur = (char*)str1;
	char* s1, * s2;
	if (!*str2)
		return ((char*)str1);
	while (*cur)
	{
		s1 = cur;
		s2 = (char*)str2;
		while (*s1 && *s2 && !(*s1 - *s2))
		{
			s1++;
			s2++;
		}
		if (!*s2)
			return cur;
		cur++;
	}
	return NULL;
}
int main()
{
	char* p1 = "aqqqcdef";
	char* p2 = "qqc";
	char* ret = my_strstr(p1, p2);
	if (ret == NULL)
		printf("字串不存在\n");
	else
		printf("%s\n", ret);
	return 0;
}

strtok

切割字符串,查找字符串中的下一個令牌

strtok - char * strtok ( char * str, const char * sep );

1.sep參數是個字符串,定義了用作分隔符的字符集合。

2.第一個參數指定一個字符串,它包含了0個或者多個由sep字符串中一個或者多個分隔符分割的標記。

3.strtok函數找到str中的下一個標記,并將其用&rsquo;\0&rsquo;結尾,返回一個指向這個標記的指針。(注:strtok函數會改變被操作的字符串,所以在使用

strtok函數切分的字符串一般都是臨時拷貝的內容并且可修改)。

4.strtok函數的第一個參數不為NULL,函數將找到str中第一個標記,strtok函數將保存它在字符串中的位置。

5.strtok函數的第一個參數為NULL,函數將在同一個字符串中被保存的位置開始,查找下一個標記。

6.如果字符串中不存在更多的標記,則返回NULL指針。

int main()
{
	char arr[] = "hyr@baidu.com";
	char* p = "@.";
	char buf[1024] = { 0 };
	strcpy(buf, arr);
	char* ret = NULL;
	for (ret = strtok(arr, p);ret != NULL;ret = strtok(NULL, p))
	{
		printf("%s\n", ret);
	}
	return 0;
}

strerror

獲取系統錯誤消息(strerror)或打印用戶提供的錯誤信息。

strerror - char *strerror( int errnum );

1.返回錯誤碼所對應的錯誤信息。

2.errno是一個全局的錯誤碼的變量,當C語言的庫函數在執行過程中發生了錯誤,就會把對應的錯誤碼賦值到errno中。

#include<stdio.h>
#include<string.h>
#include<errno.h>//必須包含的頭文件
int main()
{
	FILE* pf = fopen("unexist.ent", "r");
	if (pf == NULL)
	{
		printf("Error opening file unexist.ent:%s\n", strerror(errno));
		//errno: Last error number
		return 0;
	}
	//....
	return 0;
}

tolower\toupper

int tolower ( int c) ; - 大寫字母轉化為小寫字母

int toupper ( int c) ; - 小寫字母轉化為大寫字母

C語言字符串函數與內存函數怎么用

memcpy

在緩沖區之間復制字符

memcpy - void * memcpy ( void * dest, const void * source, size_t num );

1.函數memcpy從source的位置開始向后復制num個字節的數據到destation的內存位置。

2.這個函數在遇到\0的時候并不會停下來。

3.如果source和destion有任何的重疊,復制的結果都是未定義的。

memcpy模擬實現

#include<stdio.h>
#include<assert.h>
struct Stu
{
	char name[20];
	int age;
};
void* my_memcpy(void* dest, const void* src, size_t num)
{
	assert(dest && src);
	void* ret = dest;
	while (num--)
	{
		*((char*)dest) = *((char*)src);
		++(char*)dest;
		++(char*)src;
	}
	return ret;
}
int main()
{
	struct Stu arr1[] = { {"zhangsan",13},{"lisi",17} };
	struct Stu arr2[3] = { 0 };
	my_memcpy(arr2, arr1, sizeof(arr1));
	return 0;
}

memmove

將一個緩沖區移動到另外一個緩沖區

memmove - void *memmove( void *dest, const void *src, size_t count );

1.和memcpy的差別就是memmove函數處理的源內存塊和目標內存塊是可以重疊的。

2.如果源空間和目標空間出現重疊,就得使用memmove函數處理。

memmove模擬實現

C語言字符串函數與內存函數怎么用

#include<stdio.h>
#include<assert.h>
void* my_memmove(void* dest, const void* src, size_t count)
{
	assert(dest && src);
	void* ret = dest;
	if (dest < src)
	{
		while (count--)
		{
			*(char*)dest = *(char*)src;
			++(char*)dest;
			++(char*)src;
		}
	}
	else
	{
		while (count--)
		{
			*((char*)dest + count) = *((char*)src + count);
		}
	}
	return ret;
}
int main()
{
	int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
	//將1,2,3,4,5數據拷貝到3,4,5,6,7空間上去
	my_memmove(arr + 2, arr, 20);
	for (int i = 0;i < 10;i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

memcmp

比較兩個緩沖區間的字符

memcmp - int memcmp( const void *buf1, const void *buf2, size_t count );

1.比較從buf1和buf2指針開始的count個字節

C語言字符串函數與內存函數怎么用

C語言字符串函數與內存函數怎么用

memset

將緩沖區設定為指定的字符

menset - void *memset( void *dest, int c, size_t count );

以上就是關于“C語言字符串函數與內存函數怎么用”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

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

AI

离岛区| 修文县| 阿勒泰市| 来安县| 武夷山市| 宜城市| 马山县| 井研县| 琼结县| 连平县| 富川| 潮州市| 三江| 崇仁县| 澄江县| 无锡市| 青铜峡市| 威海市| 晋宁县| 北宁市| 措勤县| 喀喇沁旗| 台山市| 五家渠市| 东辽县| 双辽市| 呼玛县| 南乐县| 邓州市| 应城市| 涿州市| 铜川市| 清新县| 乐亭县| 贵南县| 广饶县| 凤阳县| 贞丰县| 永修县| 平山县| 新宁县|