VS2019中关于strcpy函数运行出错

使用C++编写程序出现的小错误,简单记录一下,以防将来遗忘!!!

使用C++写了一个结构体,然后使用strcpy函数对结构体中的成员赋值,如下所示:

#include <iostream>
#include <cstring>
 
using namespace std;
 
// 声明一个结构体类型 Books 
struct Books
{
   char  title[50];
   char  author[50];
   char  subject[100];
   int   book_id;
};
 
int main( )
{
   Books Book1;        // 定义结构体类型 Books 的变量 Book1
   Books Book2;        // 定义结构体类型 Books 的变量 Book2
 
   // Book1 详述
   strcpy( Book1.title, "C++ 教程");
   strcpy( Book1.author, "Runoob"); 
   strcpy( Book1.subject, "编程语言");
   Book1.book_id = 12345;
 
   // Book2 详述
   strcpy( Book2.title, "CSS 教程");
   strcpy( Book2.author, "Runoob");
   strcpy( Book2.subject, "前端技术");
   Book2.book_id = 12346;
 
   // 输出 Book1 信息
   cout << "第一本书标题 : " << Book1.title <<endl;
   cout << "第一本书作者 : " << Book1.author <<endl;
   cout << "第一本书类目 : " << Book1.subject <<endl;
   cout << "第一本书 ID : " << Book1.book_id <<endl;
 
   // 输出 Book2 信息
   cout << "第二本书标题 : " << Book2.title <<endl;
   cout << "第二本书作者 : " << Book2.author <<endl;
   cout << "第二本书类目 : " << Book2.subject <<endl;
   cout << "第二本书 ID : " << Book2.book_id <<endl;
 
   return 0;
}

运行后竟然报错,
在这里插入图片描述
在这里插入图片描述

仔细看了报错提示:

error C4996: ‘strcpy’: This function or variable may be unsafe. Consider using strcpy_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.

尝试把代码中的strcpy函数换成strcpy_s函数,完美解决!

引用\[1\]:在C++,使用strcpy函数将一个字符串复制到数组时,需要注意数组的大小。如果数组的大小不足以容纳被复制的字符串,就会导致栈溢出的问题。在上面的代码,定义了多个大小为size的int16_t数组,但是没有给出size的具体值。如果size的值过大,超过了栈的容量,就会导致程序以异常方式退出。因此,在使用strcpy函数时,需要确保目标数组的大小足够大,能够容纳被复制的字符串。\[1\] 引用\[2\]:在C++,数组是在编译时就确定大小的,而指针所指向的字符串可以在运行时赋值。在栈上的数组比指针所指向的字符串的存取速度更快。因此,在上面的代码,定义了多个大小为size的int16_t数组,这些数组是在编译时就确定大小的。\[2\] 引用\[3\]:关于strcpy函数的使用,需要注意的是,如果被复制的字符串的长度大于目标数组的大小,就会造成缓冲区溢出的问题。这样会导致程序运行出错。在C++,存在一些类似strcpy的标准函数,如strcat、sprintf、vsprintf、gets、scanf等,它们也有可能存在缓冲区溢出的问题。为了避免这种问题,可以使用更加安全的函数,如strncpy、strncat、snprintf、sscanf等,这些函数可以在函数名后加上_s来表示。在使用这些函数时,需要严格检查输入的长度和缓冲区的长度,以确保不会发生缓冲区溢出的情况。\[3\] 综上所述,如果在C++使用strcpy函数将字符串复制到数组时,需要确保目标数组的大小足够大,能够容纳被复制的字符串,以避免栈溢出的问题。此外,还需要注意使用安全的函数来处理字符串操作,以防止缓冲区溢出的情况发生。 #### 引用[.reference_title] - *1* *2* [C++ main() 函数定义数组闪退__问题分析&解决过程](https://blog.csdn.net/weixin_41521681/article/details/105490431)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [c++什么时候数组溢出_一文理解缓冲区溢出](https://blog.csdn.net/weixin_39859988/article/details/109906854)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值