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

一篇文章教你自己動手實現(xiàn)C語言庫函數(shù)

 更新時間:2021年09月16日 15:16:52   作者:大桑樹保安隊  
這篇文章主要介紹了C語言庫函數(shù)的相關資料,小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

memmove

函數(shù)聲明

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

函數(shù)作用

將num字節(jié)的值從source指向的位置復制到destination指向的內存塊。復制就像使用了中間緩沖區(qū)一樣進行,從而允許目標和源重疊。

該函數(shù)不檢查source中是否有任何終止的空字符——它總是精確地復制num字節(jié)。

為了避免溢出,目標和源參數(shù)所指向的數(shù)組的大小必須至少為num字節(jié)。
返回destination。

實現(xiàn)memmove

#include <stdio.h>
#include <string.h>
#include <assert.h>
//實現(xiàn)memmove
void* my_memmove(void* dst, const void* src, size_t n)
{
    assert(dst && src);
	char* dst_temp = (char*)dst;
	char* src_temp = (char*)src;
	if (src_temp<dst_temp && src_temp + n>dst_temp)//src在dst前,兩者交錯,需從后往前復制
	{
		while (n)
		{
			*(dst_temp + n - 1 )= *(src_temp + n - 1);
			n--;
		}
	}
	else
	{
		while (n--)
		{
			*dst_temp++ = *src_temp++;
		}
	}
	return dst;
}
int main()
{
	int a[10] = { 0,1,2,3,4,5,6,7,8,9 };
	my_memmove(a+2, a, 4*sizeof(int));
	for (int i = 0; i < 10; ++i)
	{
		printf("%d ", a[i]);
	}
	return 0;
}

在這里插入圖片描述

memcpy

函數(shù)聲明

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

函數(shù)作用

將num個字節(jié)的值從source所指向的位置開始直接復制到destination所指向的內存塊。

該函數(shù)不檢查source中是否有任何終止的空字符——它總是精確地復制num字節(jié)。

為了避免溢出,目標和源參數(shù)所指向的數(shù)組的大小必須至少為num字節(jié),并且不能重疊(對于重疊的內存塊,memmove是一種更安全的方法)。
返回destination。

實現(xiàn)memcpy

//實現(xiàn)memcpy
void* my_memcpy(void* dst, const void* src, size_t n)
{
	assert(dst && src);
	char* dst_temp = (char*)dst;
	char* src_temp = (char*)src;
	while (n--)
	{
		*dst_temp++ = *src_temp++;
	}
	return dst;
}

int main()
{
	int a[10] = { 0,1,2,3,4,5,6,7,8,9 };
	my_memcpy(a+2, a, 4*sizeof(int));
	for (int i = 0; i < 10; ++i)
	{
		printf("%d ", a[i]);
	}
	return 0;
}

在這里插入圖片描述

重疊的區(qū)間將會被提前破壞。

strstr

函數(shù)聲明

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

函數(shù)作用

查找子字符串

返回一個指向str1中第一次出現(xiàn)的str2的指針,如果str2不是str1的一部分,則返回一個空指針。

匹配過程不包括結束空字符,但它在此停止。

實現(xiàn)strstr

/實現(xiàn)strstr
char* my_strstr(const char* mom,const char* son)
{
	char* cp=mom;
	char* i, *j;
	if (*son == '\0')
	{
		return mom;
	}
	while (*cp != '\0')
	{
		i = cp;
		j = son;
		while (i && *i == *j)
		{
			i++;
			j++;
			if (*j == '\0')
				return cp;
		}
		cp++;
	}
	return NULL;
}
int main()
{
	char mom[] = "abcdefghijk";
	char son[] = "ghi";
	printf("%s\n",my_strstr(mom, son));
	return 0;
}

在這里插入圖片描述

strcat

函數(shù)聲明

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

函數(shù)作用

連接字符串

將source字符串的副本粘貼追加到目標字符串。destination中的結束空字符被source中的第一個字符覆蓋,并且在由destination中的兩個字符串聯(lián)形成的新字符串的末尾包含一個空字符。

目標和源不應重疊。
返回destionation。

實現(xiàn)strcat

/實現(xiàn)strstr
char* my_strstr(const char* mom,const char* son)
{
	char* cp=mom;
	char* i, *j;
	if (*son == '\0')
	{
		return mom;
	}
	while (*cp != '\0')
	{
		i = cp;
		j = son;
		while (i && *i == *j)
		{
			i++;
			j++;
			if (*j == '\0')
				return cp;
		}
		cp++;
	}
	return NULL;
}
int main()
{
	char mom[] = "abcdefghijk";
	char son[] = "ghi";
	printf("%s\n",my_strstr(mom, son));
	return 0;
}

在這里插入圖片描述

strcmp

函數(shù)聲明

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

函數(shù)作用

比較字符串str1和字符串str2。

這個函數(shù)開始比較每個字符串的第一個字符。如果它們彼此相等,則繼續(xù)執(zhí)行下面的對,直到字符不同或到達一個終止的空字符為止。

返回值

1)<0 第一個不匹配的字符在ptr1中的值比在ptr2中的值低

2)=0 兩個字符串的內容相等

3)>0 第一個不匹配的字符在ptr1中的值大于ptr2中的值

實現(xiàn)strcmp

char* my_strcat(char* dst,const char* src)
{
	assert(dst && src);
	int len1 = strlen(dst);
	char* start = dst + len1;
	while (*start++ = *src++)
	{
		;
	}
	return dst;
}
int main()
{
	char mom[26] ="abcdefg";
	char son[] = "hijk";

	printf("%s\n",my_strcat(mom, son));
	return 0;
}

strcpy

函數(shù)聲明

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

函數(shù)作用

復制字符串

將source指向的字符串復制到destination指向的數(shù)組中,包括終止空字符(并在此點停止)。

為了避免溢出,destination指向的數(shù)組的大小應該足夠長,以包含與source相同的字符串(包括結束的null字符),并且不應該在內存中與source重疊。
返回destination。

實現(xiàn)strcpy

//實現(xiàn)strcpy
char* my_strcpy(char* dst, const char* src)
{
	char* start = dst;
	assert(dst && src);
	while (*dst++ = *src++);
	return start;
}

int main()
{
	char mom[26] ="abcdefg";
	char son[] = "abq";
	my_strcpy(mom, son);
	printf("%s\n",mom);
	return 0;
}

在這里插入圖片描述

strlen

函數(shù)聲明

size_t strlen ( const char * str );

函數(shù)作用

獲取字符串長度

返回C字符串str的長度。

C字符串的長度由結束空字符決定:C字符串的長度等于字符串開頭和結束空字符之間的字符數(shù)(不包括結束空字符本身)。

char mystr[100]="test string";

定義了一個長度為100個字符的字符數(shù)組,但是用于初始化mystr的C字符串長度只有11個字符。因此,當sizeof(mystr)計算為100時,strlen(mystr)返回11。

實現(xiàn)strlen

//實現(xiàn)strlen
size_t my_strlen(const char* str)
{
	size_t len = 0;
	while (*str++)
	{
		len++;
	}
	return len;
}

int main()
{
	char mom[26] ="abcdefg";
	printf("%d\n",my_strlen(mom));
	return 0;
}

output:7

總結

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

相關文章

  • C++實踐分數(shù)類中運算符重載的方法參考

    C++實踐分數(shù)類中運算符重載的方法參考

    今天小編就為大家分享一篇關于C++實踐分數(shù)類中運算符重載的方法參考,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • C++實現(xiàn)一個線程安全的單例工廠實現(xiàn)代碼

    C++實現(xiàn)一個線程安全的單例工廠實現(xiàn)代碼

    這篇文章主要介紹了 C++實現(xiàn)一個線程安全的單例工廠實現(xiàn)代碼的相關資料,需要的朋友可以參考下
    2017-05-05
  • C++容器適配與棧的實現(xiàn)及dequeque和優(yōu)先級詳解

    C++容器適配與棧的實現(xiàn)及dequeque和優(yōu)先級詳解

    這篇文章主要介紹了C++容器適配與棧的實現(xiàn)及dequeque和優(yōu)先級,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-10-10
  • QT基于TCP實現(xiàn)文件傳輸系統(tǒng)

    QT基于TCP實現(xiàn)文件傳輸系統(tǒng)

    這篇文章主要為大家詳細介紹了QT基于TCP實現(xiàn)文件傳輸系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • 一文教你Qt如何操作SQLite數(shù)據(jù)庫

    一文教你Qt如何操作SQLite數(shù)據(jù)庫

    Sqlite 數(shù)據(jù)庫作為 Qt 項目開發(fā)中經常使用的一個輕量級的數(shù)據(jù)庫,可以說是兼容性相對比較好的數(shù)據(jù)庫之一。本文為大家介紹了Qt操作SQLite數(shù)據(jù)庫的具體方法,希望對大家有所幫助
    2023-03-03
  • c語言描述回文數(shù)的三種算法

    c語言描述回文數(shù)的三種算法

    這篇文章主要介紹了c語言描述回文數(shù)的三種算法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • 基于Qt OpenCV實現(xiàn)圖像數(shù)據(jù)采集軟件

    基于Qt OpenCV實現(xiàn)圖像數(shù)據(jù)采集軟件

    這篇文章主要為大家詳細介紹了如何利用Qt+OpenCV實現(xiàn)圖像數(shù)據(jù)采集軟件,文中的示例代碼講解詳細,對我學習或工作有一定參考價值,感興趣的可以了解一下
    2022-07-07
  • C++實現(xiàn)LeetCode(41.首個缺失的正數(shù))

    C++實現(xiàn)LeetCode(41.首個缺失的正數(shù))

    這篇文章主要介紹了C++實現(xiàn)LeetCode(41.首個缺失的正數(shù)),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
    2021-07-07
  • 如何使用arm-none-eabi-gcc編譯器搭建STM32的Vscode開發(fā)環(huán)境

    如何使用arm-none-eabi-gcc編譯器搭建STM32的Vscode開發(fā)環(huán)境

    這篇文章主要介紹了使用arm-none-eabi-gcc編譯器搭建STM32的Vscode開發(fā)環(huán)境,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07
  • C++創(chuàng)建窗口程序的實現(xiàn)示例

    C++創(chuàng)建窗口程序的實現(xiàn)示例

    Windows窗體應用程序是C#語言中的一個重要應用,本文主要介紹了C++創(chuàng)建窗口程序的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01

最新評論