职业IT人-IT人生活圈

 找回密码
 成为会员
搜索
查看: 209|回复: 2

一个C语言的面试题

[复制链接]
feiguo 发表于 2011-8-19 08:42 | 显示全部楼层 |阅读模式
可能有一个或者多个答案是正确的

关于下面的C语言代码片段,那个是正确的?
C代码  
int test(char* src) {   
    char dest[1024] = {0};   
    strncpy(dest, src, strlen(src)-1);   
    return 1;   
}  

int test(char* src) {
    char dest[1024] = {0};
    strncpy(dest, src, strlen(src)-1);
    return 1;
}

A. 这段代码没有任何问题
B. 这段代码存在条件竞争漏洞
C. 这段代码存在栈溢出漏洞
D. 这段代码存在堆溢出漏洞



我觉得是C,src超过1024的时候可能造成拷贝到dest时的溢出,而dest是在栈上的。

各位帮忙看看是不是这样的,谢谢。

能文能武 发表于 2011-8-19 08:42 | 显示全部楼层
栈溢出可能

叫我小乖 发表于 2011-8-19 08:42 | 显示全部楼层
zeeeitch 写道
栈溢出可能

那答案B和C呢?
您需要登录后才可以回帖 登录 | 成为会员

本版积分规则

QQ|手机版|小黑屋|网站帮助|职业IT人-IT人生活圈 ( 粤ICP备12053935号-1 )|网站地图
本站文章版权归原发布者及原出处所有。内容为作者个人观点,并不代表本站赞同其观点和对其真实性负责,本站只提供参考并不构成任何投资及应用建议。本站是信息平台,网站上部分文章为转载,并不用于任何商业目的,我们已经尽可能的对作者和来源进行了通告,但是能力有限或疏忽造成漏登,请及时联系我们,我们将根据著作权人的要求立即更正或者删除有关内容。

GMT+8, 2024-5-10 20:26 , Processed in 0.113870 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表