模拟实现字符串函数(6):strncat

1.函数介绍

翻译一下:就是当源字符串长度小于num时会只追加源字符串的最大长度,大于num时正常追加

2.思路分析

1.首先将dest的指针保留用于返回,随后遍历到dest的末尾;

2.判断一下num是否大于src的长度,如果小于的话,将src遍历追加完即可。

复制代码
char* my_strncat(char* dest, char* src, size_t num)
{
	char* ret = dest;
	while (*dest)
	{
		dest++;
	}
	//源字符串长度大于num
	if (strlen(src) >= num)
	{
		while (num--)
		{
			*dest++ = *src++;
		}
	}
	else
	{
		while (*src != '\0')
		{
			*dest++ = *src++;
		}

	}
	return ret;
}

int main()
{
	char str1[30] = "abcdefghij";
	char str2[] = "aaattttt";
	my_strncat(str1, str2, 5);
	printf("%s\n", str1);
	return 0;
}
相关推荐
橘色的喵5 小时前
现代 C++17 相比 C 的不可替代优势
c语言·c++·现代c++·c++17
浅念-5 小时前
C/C++内存管理
c语言·开发语言·c++·经验分享·笔记·学习
Mr YiRan5 小时前
函数指针与指针运算
c语言
敲皮裤的代码9 小时前
《C语言》深入理解指针(4)
c语言
J-TS10 小时前
线性自抗扰控制LADRC
c语言·人工智能·stm32·单片机·算法
A9better10 小时前
C++——指针与内存
c语言·开发语言·c++·学习
坚持编程的菜鸟10 小时前
互质数的个数
c语言·算法
浅念-12 小时前
C++ 模板初阶:从泛型编程到函数模板与类模板
c语言·开发语言·数据结构·c++·笔记·学习
DevilSeagull12 小时前
C语言: C语言内存函数详解
c语言·开发语言·算法
你怎么知道我是队长13 小时前
C语言---排序算法8---递归快速排序法
c语言·算法·排序算法