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

C語(yǔ)言常用庫(kù)函數(shù)的使用及模擬實(shí)現(xiàn)詳解例舉

 更新時(shí)間:2022年04月13日 09:09:08   作者:小劉好好學(xué)習(xí)  
C語(yǔ)言庫(kù)函數(shù)是把自定義函數(shù)放到庫(kù)里,是別人把一些常用到的函數(shù)編完放到一個(gè)文件里,供程序員使用,下面讓我們一起來(lái)詳細(xì)了解它

經(jīng)歷了C語(yǔ)言基礎(chǔ)篇的學(xué)習(xí),讓我們來(lái)簡(jiǎn)單了解幾個(gè)C語(yǔ)言的庫(kù)函數(shù)!

1.strlen

字符串已經(jīng) '\0' 作為結(jié)束標(biāo)志,strlen函數(shù)返回的是在字符串中 '\0' 前面出現(xiàn)的字符個(gè)數(shù)(不包 含 '\0' )。

 函數(shù)的模擬實(shí)現(xiàn)

1.計(jì)數(shù)法

int my_strlen(dest)
{
int count=0;
    while(dest)//當(dāng)dest等于'\0'時(shí)停止循環(huán)
{
    count++;
    dest++;
}
return count;
}

2.遞歸法

int my_strlen(char* dest)
{
    int count=0;
    if(*dest!='0')
    {
        dest++;
        count++;
        return my_strlen(dest,count)
    }
    else
    return count;
}

3.指針減指針

int my_strlen(char* dest)
{
    char* arr=dest;//定義一個(gè)新指針指向dest
    while(*arr)//直到arr指向'\0'
    {
    arr++;
    }
    return (arr)-(dest);//指針相減代表兩個(gè)指針之間的元素個(gè)數(shù)
}

2.strcpy

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

會(huì)將源字符串中的 '\0' 拷貝到目標(biāo)空間。

目標(biāo)空間必須足夠大,并且可變以確保能存放源字符串。

 函數(shù)的模擬實(shí)現(xiàn)

char* my_strcpy(char* dest, const char* str)
{
	char* arr1 = dest;
	while ((*dest++ = *str++)!='\0')
	{
		;
	}
	return arr1;
}
int main()
{
	char arr1[] = "***************";
	char arr2[] = "hello word";
	my_strcpy(arr1, arr2);
	printf("%s", arr1);
	return 0;
}

3.strcmp

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

第一個(gè)字符串大于第二個(gè)字符串,則返回大于0的數(shù)字

第一個(gè)字符串等于第二個(gè)字符串,則返回0

第一個(gè)字符串小于第二個(gè)字符串,則返回小于0的數(shù)字

函數(shù)的模擬實(shí)現(xiàn)

int my_strcmp(char* arr1,char* arr2)
{
	while(*arr1 == *arr2)
	{
		if (*arr1 == '\0' && *arr2 == '\0')
		{
			return 0;
		}
		else
		{
			arr1++; arr2++;
 
		}
	}if (*arr1 > *arr2)
	{
		return 1;
	}
	else if (*arr1 < *arr2)
	{
 
		return -1;
	}
}

4.strcat

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

函數(shù)的模擬實(shí)現(xiàn)

char* my_strcat(char* dest, char* str)
{
	char* ret = dest;
	while (*dest)
	{
		dest++;
	}
	while (*dest++=*str++)
	{
		;
	}
	return ret;
}
int main()
{
	char arr1[50] = "hello";
	char arr2[] = "word";
	char* count=my_strcat(arr1, arr2);
	printf("%s", count);
	return 0;
}

5.strstr

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

函數(shù)的模擬實(shí)現(xiàn)

char* my_strstr(char* dest, char* str)
{
	char* arr1 = str;
	char* cur = dest;
	while (*cur)
	{
		str = arr1;
		dest = cur;
		if (*dest != *str)
		{
			dest++;
			str++;
		}
		else if (*dest == *str)
		{
			while (*dest == *str)
			{
				dest++; str++;
 
			}if (*str == '\0')
			{
				return cur;
			}
		}
		cur++;
	}return NULL;
}
int main()
{
	char arr1[] = "abbbcdef";
	char arr2[] = "bbc";
	char* ret=my_strstr(arr1, arr2);
	if (NULL == ret)
	{
		printf("找不到子串\n");
	}
	else
	{
		printf("%s\n", ret);
	}
	return 0;
}

6.strtok

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

strtok函數(shù)的第一個(gè)參數(shù)不為 NULL ,函數(shù)將找到str中第一個(gè)標(biāo)記,strtok函數(shù)將保存它在字符串中的位置。

strtok函數(shù)的第一個(gè)參數(shù)為 NULL ,函數(shù)將在同一個(gè)字符串中被保存的位置開始,查找下一個(gè)標(biāo)記

int main()
{
	char buff[] = "www.aaabbbccc@qq.com";
	char buf[20] = { 0 };
	strcpy(buf, buff);
	char* sep=".@";
	char* str = NULL;
	for (str = strtok(buf, sep); str != NULL; str = strtok(NULL, sep))
			{//NULL是從保存好的位置開始往后找
				printf("%s\n", str);
			}
	return 0;
}

7.字符分類函數(shù)

iscntrl 任何控制字符
isspace空白字符:空格‘ ’,換頁(yè)‘\f’,換行'\n',回車‘\r’,制表符'\t'或者垂直制表符'\v'
isdigit十進(jìn)制數(shù)字 0~9
isxdigit十六進(jìn)制數(shù)字,包括所有十進(jìn)制數(shù)字,小寫字母a~f,大寫字母A~F
islower小寫字母a~z
isupper大寫字母A~Z
isalpha字母a~zA~Z
isalnum字母或者數(shù)字,a~z,A~Z,0~9
ispunct 標(biāo)點(diǎn)符號(hào),任何不屬于數(shù)字或者字母的圖形字符(可打?。?/span>
isgraph
任何圖形字符
isprint任何可打印字符,包括圖形字符和空白字符

8.memcpy&memmove

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

函數(shù)模擬實(shí)現(xiàn) 

void* my_memmove(void* dest,void* str , size_t count)
{
	void* ch = dest;
	if (dest > str)
	{
		while (count--)
		{
			*((char*)dest + count) = *((char*)str + count);
		}
	}
	else
	{
		while (count--)
		{
			*(char*)dest = *(char*)str;
			dest=(char*)dest+1;
			str=(char*)str+1;
		}
	}
}
int main()
{
	int arr1[10] = {1,2,3,4,5,6,7,8,9,10};
	my_memmove(arr1+2, arr1 , 20);
	int sz = sizeof(arr1) / sizeof(arr1[0]);
	for (int i = 0; i < sz; i++)
	{
		printf("%d", arr1[i]);
	}
	return 0;
}

9.memcmp 

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

 函數(shù)模擬實(shí)現(xiàn)

void* my_memcmp(char* arr, char* arr1, int count)
{
	while (count--)
	{
		if (*(char*)arr > *(char*)arr1)
		{
			return 1;
		}
		else if ((*(char*)arr < *(char*)arr1))
		{
			return -1;
		}
		arr++; arr1++;
	}	return 0;
}
int main()
{
	int arr[] = { 1,2,3,4,5 };
	int arr1[] = { 1,2,3,4,4 };
	int ret=my_memcmp(arr, arr1, 20);
	printf("%d", ret);
	return 0;
}

到此這篇關(guān)于C語(yǔ)言常用庫(kù)函數(shù)的使用及模擬實(shí)現(xiàn)詳解例舉的文章就介紹到這了,更多相關(guān)C語(yǔ)言 庫(kù)函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語(yǔ)言面試C++二維數(shù)組中的查找示例

    C語(yǔ)言面試C++二維數(shù)組中的查找示例

    這篇文章主要介紹了C語(yǔ)言面試C++二維數(shù)組中的查找示例,文中給出基本能拿下面試官的操作示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-09-09
  • C++實(shí)現(xiàn)查殼程序代碼實(shí)例

    C++實(shí)現(xiàn)查殼程序代碼實(shí)例

    這篇文章主要介紹了C++實(shí)現(xiàn)查殼程序代碼實(shí)例,有比較詳細(xì)的注釋,包含了對(duì)原理的說(shuō)明,有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2014-10-10
  • C語(yǔ)言中設(shè)置進(jìn)程優(yōu)先順序的方法

    C語(yǔ)言中設(shè)置進(jìn)程優(yōu)先順序的方法

    這篇文章主要介紹了C語(yǔ)言中設(shè)置進(jìn)程優(yōu)先順序的方法,包括setpriority()函數(shù)和getpriority()函數(shù)以及nice()函數(shù),需要的朋友可以參考下
    2015-08-08
  • C++11 中的std::function和std::bind詳解

    C++11 中的std::function和std::bind詳解

    這篇文章主要介紹了C++ 11 std::function和std::bind,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-10-10
  • 一文詳解C++的程序流程控制

    一文詳解C++的程序流程控制

    這篇文章主要介紹了一文詳解C++的程序流程控制,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • C語(yǔ)言實(shí)現(xiàn)掃雷算法簡(jiǎn)易版

    C語(yǔ)言實(shí)現(xiàn)掃雷算法簡(jiǎn)易版

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)掃雷算法簡(jiǎn)易版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • 帶你了解C++的數(shù)組與函數(shù)

    帶你了解C++的數(shù)組與函數(shù)

    這篇文章主要介紹了C++的數(shù)組與函數(shù),包括數(shù)組的初始化等基本知識(shí),需要的朋友可以參考下,希望能給你帶來(lái)幫助
    2021-08-08
  • C++中vector容器的常用操作方法實(shí)例總結(jié)

    C++中vector容器的常用操作方法實(shí)例總結(jié)

    vector容器一般被用作創(chuàng)建動(dòng)態(tài)數(shù)組,動(dòng)態(tài)數(shù)組就像Python中的list結(jié)構(gòu)一樣,可以比普通數(shù)組擁有更豐富操作方法,下面就為大家整理了一些最常用的操作:
    2016-05-05
  • Qt設(shè)計(jì)時(shí)鐘效果

    Qt設(shè)計(jì)時(shí)鐘效果

    這篇文章主要為大家詳細(xì)介紹了Qt設(shè)計(jì)時(shí)鐘效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • C語(yǔ)言實(shí)現(xiàn)猜數(shù)字小游戲的示例代碼

    C語(yǔ)言實(shí)現(xiàn)猜數(shù)字小游戲的示例代碼

    猜數(shù)字小游戲是我們小時(shí)候喜歡我們一個(gè)經(jīng)典小游戲。這篇文章將利用C語(yǔ)言中的循環(huán)語(yǔ)句、分支語(yǔ)句和函數(shù)實(shí)現(xiàn)這一游戲,需要的可以參考一下
    2022-10-10

最新評(píng)論