一篇文章教你自己动手实现C语言库函数

memmove

函数声明
void * memmove ( void * destination, const void * source, size_t num );
函数作用

将num字节的值从source指向的位置复制到destination指向的内存块。复制就像使用了中间缓冲区一样进行,从而允许目标和源重叠

该函数不检查source中是否有任何终止的空字符——它总是精确地复制num字节。

为了避免溢出,目标和源参数所指向的数组的大小必须至少为num字节。

返回destination。

实现memmove
#include <stdio.h>
#include <string.h>
#include <assert.h>

//实现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;
}

F97E7FC8-39A1-CF5A-CFCE-8328F8FDC5A6.png


memcpy
函数声明
void * memcpy ( void * destination, const void * source, size_t num );
函数作用

将num个字节的值从source所指向的位置开始直接复制到destination所指向的内存块。

该函数不检查source中是否有任何终止的空字符——它总是精确地复制num字节。

为了避免溢出,目标和源参数所指向的数组的大小必须至少为num字节,并且不能重叠(对于重叠的内存块,memmove是一种更安全的方法)。

返回destination。

实现memcpy
//实现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;
}

09004BA1-F751-C285-5BED-5EB31B5CD36F.png

重叠的区间将会被提前破坏。


strstr
函数声明
char * strstr (char * str1, const char * str2 );
函数作用

查找子字符串

返回一个指向str1中第一次出现的str2的指针,如果str2不是str1的一部分,则返回一个空指针。

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

实现strstr
/实现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;
}

8F6B9B50-5B2B-E5D0-5A75-2CE1F86D57C6.png


strcat
函数声明
char * strcat ( char * destination, const char * source );
函数作用

连接字符串

将source字符串的副本粘贴追加到目标字符串。destination中的结束空字符被source中的第一个字符覆盖,并且在由destination中的两个字符串联形成的新字符串的末尾包含一个空字符。

目标和源不应重叠。

返回destionation。

实现strcat
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;
}

21D6F199-A34C-AEA7-C3B1-78D670E12C0B.png


strcmp
函数声明
int strcmp ( const char * str1, const char * str2 );
函数作用

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

这个函数开始比较每个字符串的第一个字符。如果它们彼此相等,则继续执行下面的对,直到字符不同或到达一个终止的空字符为止。

返回值

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

2)=0 两个字符串的内容相等

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

实现strcmp
int my_strcmp(const char* s1,const char* s2)
{
	while (*s1 == *s2)
	{
		if (*s1 == '\0')
			return 0;
		s1++;
		s2++;
	}
	return *s1 - *s2;
}


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

strcpy
函数声明
char * strcpy ( char * destination, const char * source );
函数作用

复制字符串

将source指向的字符串复制到destination指向的数组中,包括终止空字符(并在此点停止)。

为了避免溢出,destination指向的数组的大小应该足够长,以包含与source相同的字符串(包括结束的null字符),并且不应该在内存中与source重叠。

返回destination。

实现strcpy
//实现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;
}

3528AFC4-8171-3CF7-FE92-774B365C4A9F.png


strlen
函数声明
size_t strlen ( const char * str );
函数作用

获取字符串长度

返回C字符串str的长度。

C字符串的长度由结束空字符决定:C字符串的长度等于字符串开头和结束空字符之间的字符数(不包括结束空字符本身)。

char mystr[100]="test string";

定义了一个长度为100个字符的字符数组,但是用于初始化mystr的C字符串长度只有11个字符。因此,当sizeof(mystr)计算为100时,strlen(mystr)返回11。

实现strlen
//实现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

收藏 (0)
评论列表
正在载入评论列表...
我是有底线的
为您推荐
    暂时没有数据