博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
一个不当使用fclose引发的异常
阅读量:4557 次
发布时间:2019-06-08

本文共 729 字,大约阅读时间需要 2 分钟。

最近服务器上一个后台传输文件的服务,经常会报出异常来,只能强行终止并重启。

昨天刚好有空,现场抓了一下dump,再把程序扔到IDA里看了一下,很快就找出原因了,原来是调用fclose时出错的。

使用C的Runtime函数进行文件操作,也就是fopen,fread,ftell,fclose这些,本身这并没有什么问题

但是出现异常的位置往上一点,程序写了日志,主要内容是“打开文件失败,错误原因:xxxxxx”

也就是说,在使用fopen打开文件失败了之后,程序仍然使用了fclose来关闭这个无效的FILE指针,导致了异常的发生。

可以简单用下面的代码测试一下:

void TestFun(){    FILE *fp;    fp = fopen("C:\\nosuchfile.sys","r");//打开一个不存在的文件    printf("fp = 0x%X\n",fp);    if (fp == NULL)    {        printf("Open file failed.\n");    }    else    {        printf("Open file succeed.\n");    }    fclose(fp);//这里将引发异常}

 

事实上,我所知道的,用CloseHandle关闭一个无效的句柄同样是会引发异常的。

本来打开操作就是失败的,FILE指针也无效,再关它有什么意义呢?

解决办法:直接把程序中这个调用打了个补丁,用nop指令填充了一下,就正常了。如下图所示,将有颜色的三条指令用nop填充:

 

转载于:https://www.cnblogs.com/achillis/p/5188912.html

你可能感兴趣的文章
4嵌入式作业io
查看>>
IntelliJ Idea编译报错:javacTask: 源发行版 1.7 需要目标发行版 1.7
查看>>
Cognos中新建SQLserver数据源的步骤
查看>>
HttpClient连接超时及读取超时
查看>>
SQL优化方法
查看>>
SEO必须掌握的高级搜索指令
查看>>
生产者消费者模型
查看>>
ORACLE 字符串超长问题解决方案
查看>>
线程 题待做
查看>>
PL/SQL可以连oracle,但是jdbc连不上 【转】
查看>>
使用 highlight.js 在网页中高亮显示java 代码 【原】
查看>>
[转]高颜值、好用、易扩展的微信小程序 UI 库,Powered by 有赞
查看>>
[转]SQL Server如何启用xp_cmdshell组件
查看>>
[转]微擎应用笔记3--manifest.xml文件使用说明
查看>>
Codeforces 1000C Covered Points Count 【前缀和优化】
查看>>
python高效读取文件、文件改写
查看>>
gulp
查看>>
pgsql查询优化之模糊查询
查看>>
不变模式
查看>>
matlab去云雾
查看>>