手机版
你好,游客 登录 注册
背景:
阅读新闻

处理C语言之vfprintf的段错误

[日期:2013-07-01] 来源:CSDN  作者:hongchangfirst [字体: ]

C语言的段错误想必是每个人都遇到过,整理一下,以供学习之用。
 
今天我执行了一个程序,运行了很长时间后,段错误了,我定位了一下,原来是fprintf的问题,具体是vfprintf的问题。
 
Program received signal SIGSEGV, Segmentation fault. 0x0098735e in vfprintf () from /lib/libc.so.6
 

调用栈为:
 
#0  0x0098735e in vfprintf () from /lib/libc.so.6
 #1  0x0098e3cf in fprintf () from /lib/libc.so.6
 将fprintf换成printf就没有问题了。
 
我开始认为是长度问题,导致溢出,后来我组合了各种方案,发现不是长度问题,原来是一个特殊的字符序列导致的问题,这个罪魁祸首就是%20这个字符串,它会导致vfprintf不正常运行。%20其实就是空格的url编码。
 
上述主要是因为可变参数列表和格式化字符串的特性导致的,如%20s序列,它会认为是一个字符串,但是我们并没有传入一个字符串,所以程序就会有问题。一般来说只要字符串中含有%,就算没有段错误,也会出现很奇怪的输出现象。
 
同理,sprintf由于也会调用vfprintf,所以应该同样也会有问题。

linux
相关资讯       C语言段错误 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款