• linux下两次fclose运行时出错及解决方法


    今天敲代码不小心两次fclose了同一个文件指针。结果运行时爆了一堆错误

    *** glibc detected *** logconvert: double free or corruption (out): 0x000000001685d750 ***
    ======= Backtrace: =========
    /lib64/libc.so.6[0x30c66722ef]
    /lib64/libc.so.6(cfree+0x4b)[0x30c667273b]
    /lib64/libc.so.6(fclose+0x14b)[0x30c6660d5b]
    logconvert[0x403278]
    /lib64/libc.so.6(__libc_start_main+0xf4)[0x30c661d994]
    logconvert(__gxx_personality_v0+0x121)[0x4026a9]
    ======= Memory map: ========
    00400000-00421000 r-xp 00000000 08:03 425403                           
    00621000-00622000 rw-p 00021000 08:03 425403                            
    00622000-00a2a000 rw-p 00622000 00:00 0
    16830000-16872000 rw-p 16830000 00:00 0                                 
    302cc00000-302cc45000 r-xp 00000000 08:03 457417                        
    302cc45000-302ce44000 ---p 00045000 08:03 457417                        
    302ce44000-302ce4a000 rw-p 00044000 08:03 457417                        
    3033400000-3033409000 r-xp 00000000 08:03 457416                        
    3033409000-3033608000 ---p 00009000 08:03 457416                       
    3033608000-3033609000 r--p 00008000 08:03 457416                        
    3033609000-303360a000 rw-p 00009000 08:03 457416 

    这堆错误当然是看不懂了,目录下生成了core.20472这个core文件,可以方便的帮我们找出错误所在行。

    当前目录下执行gdb -c core.20472 logconvert    PS:logconvert是编译生成的可执行程序

    进入gdb后,使用命令bt得到以下结果

    (gdb) bt
    #0  0x00000030c6630265 in raise () from /lib64/libc.so.6
    #1  0x00000030c6631d10 in abort () from /lib64/libc.so.6
    #2  0x00000030c666a84b in __libc_message () from /lib64/libc.so.6
    #3  0x00000030c66722ef in _int_free () from /lib64/libc.so.6
    #4  0x00000030c667273b in free () from /lib64/libc.so.6
    #5  0x00000030c6660d5b in fclose@@GLIBC_2.2.5 () from /lib64/libc.so.6
    #6  0x0000000000403278 in main (argc=, argv=)
        at logconvert.cpp:676

    产生异常的地方位于logconvert.cpp 676行。

    总结:在linux下fclose两次是未定义行为,会运行出错。而在windows+VS2010环境下则不会报错,还没来得及深究。

    良好编程习惯:fclose文件指针后,再将指针置为NULL,以后判断是省的重复close,以免报错。

  • 相关阅读:
    Ajax技术【Ajax技术详解、 Ajax 的使用、Ajax请求、 JSON详解、JACKSON 的使用 】(一)-全面详解(学习总结---从入门到深化)
    基于SSM的旅游信息管理系统设计与实现
    RUST 每日一省:闭包
    2:开发环境搭建-Java Web
    [附源码]SSM计算机毕业设计拾穗在线培训考试系统JAVA
    中国香港学生IB高分是如何做到的?
    老师设计的库CRC计算
    怎样做好一个开源项目
    Catia零件透明度调节
    JAVA学习第2步——项目创建和导包
  • 原文地址:https://blog.csdn.net/liuliuhelingdao/article/details/127334468