模拟实现字符串函数(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;
}
相关推荐
MCU_wb36 分钟前
RT Thread Studio创建CAN工程代码
c语言
一韦以航.1 小时前
C【指针】详解(上)
c语言·数据结构·c++·算法
wangjialelele2 小时前
git工作原理、个人使用到多人协作开发与git FLOW模型
c语言·c++·git·团队开发·个人开发
君义_noip2 小时前
信息学奥赛一本通 1640:C Looooops
c语言·数论·信息学奥赛·csp-s
iCxhust2 小时前
__acrtused 是什么
c语言·c++·单片机·嵌入式硬件·微机原理
程序员zgh3 小时前
CMake 项目构建工具介绍
c语言·开发语言·c++·编辑器
量子炒饭大师3 小时前
一天一个计算机知识——【编程百度】向上取整
c语言·数据结构·c++·git·github
烛衔溟3 小时前
C语言图论:最短路径算法
c语言·算法·图论·dijkstra·bellman-ford·最短路径
烛衔溟3 小时前
C语言图论:最小生成树算法
c语言·算法·图论·最小生成树·kruskal·prim
喵了meme4 小时前
C语言实战3
c语言·开发语言