• 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,以免报错。

  • 相关阅读:
    client-go实战之九:手写一个kubernetes的controller
    Quartz重启服务会执行但再次执行前Trigger状态为Error的问题。Quartz不同环境的注意事项
    数据库连接池
    跨境物流FBM的主要流程是怎样的?
    python opencv环境配置 保姆级教程
    VS+CUDA环境配置
    数据库的基本操作
    微信小程序(四十五)登入界面-简易版
    1.vue的响应式原理
    如何配置Outlook的SMTP信息?
  • 原文地址:https://blog.csdn.net/liuliuhelingdao/article/details/127334468