C语言学习之我见-strcat()字符拼接函数(有缺陷)
2024-10-19 19:47:47
strcat()函数,用于两个字符串的拼接。
(1)函数原型:
char * strcat(char *Dest,const char * Source);
(2)头文件:
#include <string.h>
(3)功能:
将const char * Source所指代的字符串,拼接到char *Dest后面。不会做溢出检查。
(4)基础实例代码
char a[30] = "zobol";
char b[30] = "的魔法小屋";
strcat(a,b);
printf("%s\n",a);
(5)输出情况
(6)基础实例代码2
for(int i=0;i<30;++i)
{
printf("%d ",a[i]);//进行一个循环输出,以整数形式因为很多数值没有可显示的asicc码 )
}
for(int i=0;i<30;++i)
{
printf("%d ",b[i]);
}
strcat(a,b); //进行一个拼接
for(int i=0;i<30;++i)
{
printf("%d ",a[i]);
}
(7)输出情况:
(8)问题1:如果char *Dest对应的字符串没有足够位置容纳const char * Source的字符串怎么办?
回答:C语言没有给出办法,无论空间够不够都会进行强制拼接,因此会产生越界溢出,影响其他区域的数据。因此使用要小心。
char a[10] = "zobol"; //容量不够,至少需要15+1
char b[10] = "的魔法小屋";
strcat(a,b);
(9)问题2:如果const char * Source、char *Dest不是字符串,而只是字符数组,会怎么样?
回答:const char * Source指向的是一个字符数组,没有关系,函数会自动读取到数组结束。char *Dest结果类似问题1
char a[30] = "zobol";
char b[10] = "的魔法小屋";//没有空间给'0'
strcat(a,b);
最新文章
- 数据结构笔记--栈的总结及java数组实现简单栈结构
- Hide JSP error icons in Eclipse
- Java(六)——抽奖系统
- ACM/ICPC 之 判别MST唯一性-Kruskal解法(POJ1679)
- 小项目特供 简易迷宫(基于Java)
- Selenium实战脚本集(4)--简单的开发者头条客户端
- java 执行command
- poj1113Wall(凸包)
- UILabel的简单用法和实际操作
- unity基本操作二
- GAC write failed when upgrade with InstallShield
- tomcat7 https 成功测试
- 使用device.js检测设备并实现不同设备展示不同网页
- CentOS DNS resolv重启无效的解决方法
- Java Web 部署到Tomcat
- QT直接支持GB18030,附它对此编码的一堆相关文档描述
- 数据的ID名生成新的引用索引树
- JAVAEE——Mybatis第一天:入门、jdbc存在的问题、架构介绍、入门程序、Dao的开发方法、接口的动态代理方式、SqlMapConfig.xml文件说明
- 洛谷1027 Car的旅行路线
- Mybatis使用动态代理实现拦截器功能