经典的C笔试,strcpy()有什么隐含的危险?

strcpy()有什么隐含的危险?

这个问题比较正点,笔试过的几个公司没有问到过,网上也没有看到有相关的,我就以我对strcpy的了解来回答的,这个函数的核心是一个循环,条件是源串未结束, 即:当源串出现 '/0'  拷贝结束. 那么,他会有什么危险呢? 请看以下的例子:

char str1[4]={'a','b','c','d'};

char *str2;

strcpy(str2,str1);

编译完全没问题,但是在RH9上运行,报告段错误.

为什么呢? 因为,在str1的最后一个单元填入了的是字符d ,那么,在strcpy的时候,while(*str++)何时能结束????未知,str一直下加,一直加到出现'/0'为止, 不幸的是,一般在很近的地址出现'/0' 的几率是很低的,而且,操作系统他很快就会发现地址的非法访问, OK ,就是这个问题.

这个问题的确比较经典 , 因为他即考了strcpy, 又不是网上到处都看得到的  面了几千次的如何写一个strcpy()出来,他的核心在于应聘者对于C的理解,指针和数组,字符串,这些看起来很普通的问题,往往都可以问到你完全答不上来的地方!  而事实上, 只要点一下, 他的确就是个简单的问题了.

那么,如何解决这个问题呢?  我的想法都被自己否掉了,希望高手赐教.

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值