strcpy引起的内存溢出

项目中有一段代码调用函数C_DataBaseInterface::BulkExecSql,函数部分代码如下:

 

 

这是一个库函数,但是在调用这个库函数中的BulkExecSql函数时发生了coredump,跟进代码时发现函数coredump发生在函数执行完成时,就是在函数返回时发生了coredump,在进一步检查程序时发现strcpy(tablename,strstr(sql,"FROM")+5);这句话似乎存在隐患,因为char tablename[50]="";但是sql的长度可能远远超过50,在实际测试中发现并不是每次都会发生coredump,取决于sql的长度,但是似乎在sql在100以内是可以的,太长就会出现coredump,那么现在问题基本可以定位,就是因为这次的strcpy引起了内存溢出,strcpy将tablename后的内存覆盖,那么本来存放的程序信息被覆盖,导致在返回时出错,进而coredump。

现在的问题是超过不多是没有关系的,可能要研究研究编译的内存是如何存放的,有空继续研究研究

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值