模拟实现strncpy,strncat ,strncmp (C语言)

1、模拟实现strncpy

(1)函数原型:char * strncpy(char *s1,char *s2,size_t n);

(2)函数功能:将字符串s2中最多n个字符复制到字符数组s1中,返回指向s1的指针。

代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <assert.h>

char* my_strncpy(char* s1,const char* s2, size_t n)
{
	char* ret = s1;
	while (n && (*s1++ = *s2++))
	{
		n--;
	}
	if (n)
	{
		while (--n)
		{
			*s1 = 0;
		}
	}
	return ret;
}


int main()
{
	char arr1[8] = {"abcdefg"};
	char arr2[4] = {"ddd"};
	
	printf ("%s\n", strncpy(arr1, arr2, 4));
	//printf ("%s\n", my_strncpy(arr1, arr2, 4));

	return 0;
}

运行结果:
这里写图片描述

2、模拟实现strncat

strncat():char * strncat(char * dest,const char * src,int count)

函数原型:strncat与strcat不同的是多了参数count,用来控制源字符串连接在目标字符串的字符个数, strncat把源字符串指向的字符的前n个字,符添加到dest结尾处(覆盖原dest结尾处的’\0’),并添加新的’\0’

注意:两个函数在使用的时候都要让dest有足够的空间来存放连接后的字符串,不然会造成越界访问的问题,导致程序崩溃,
同时这里的dest和src不能发生内存重叠。

代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

char* my_strncat(char* dest, const char* str, size_t count)
{
	char *ret = dest;
	while (*dest++)
		;
	dest--;//dest指向'\0'

	while(count--)
		if (!(*dest++ = *str++))
			return ret;
	*dest = '\0';
	return ret;
}


int main()
{
	char arr1[14] = {"abcdefg"};
	char arr2[7] = {"hji"};

	//printf ("%s\n", strncat(arr1, arr2, 2));

	printf ("%s\n", my_strncat(arr1, arr2, 2));

	system ("pause");
	return 0;
}

运行结果:
这里写图片描述

3、模拟实现strncmp

**函数原型:int strncmp(char *str1, char *str2, int count); **

函数功能:

如果前count字节完全相等,返回值就=0;
如果在前count字节比较过程中,出现str1[n]与str2[n]不等,则返回(str1[n]-str2[n])。

代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int my_strncmp(const char* str1, const char* str2, size_t count)
{
	if(!count)//如果count=0, 直接返回零
	{
		return 0;
	}
	while(--count && *str1 && (*str1==*str2))
	{
		str1++;
		str2++;
	}
	return *str1-*str2;
}

int main()
{
	char arr1[] = {"abcge"};
	char arr2[] = {"abcef"};

	printf ("%d\n", my_strncmp(arr1, arr2, 6));

	system ("pause");
	return 0;
}

运行结果:
这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值