微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在 open_memstream 的 FILE 操作中检查内存不足错误

如何解决在 open_memstream 的 FILE 操作中检查内存不足错误

  1. POSIX 是否保证在 open_memstream 的 FILE 写入操作上设置了 ferror?
  2. 如果 FILE 是使用 open_memstream 创建的,我如何检查 FILE 操作的内存不足情况?

我曾经假设如果内部 realloc 失败并且可以使用 ferror 获得错误条件,则应该在流上设置错误,但是以下 glibc 2.31 测试表明它没有这样做(Linux overcommit_memory 被禁用) :

#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>

static char chunk[1024] = {1};

int main(void) {
    size_t sz = 0;
    char *s = NULL;
    FILE *sf = open_memstream(&s,&sz);
    if (!sf) {
        fprintf(stderr,"%d: ERROR open_memstream Failed: %s",(int)__LINE__,strerror(errno));
        return -1;
    }

    for (;;) {
        size_t new_n = fwrite(chunk,sizeof chunk,1,sf);
        if (ferror(sf))
            fprintf(stderr,"%d: ERROR ferror(sf): %s\n",strerror(errno));
        if (new_n == 0)
            break;
    }

    if (fflush(sf))
        fprintf(stderr,"%d: ERROR fflush(sf)\n",(int)__LINE__);
    if (ferror(sf))
        fprintf(stderr,"%d: ERROR ferror(sf)\n",(int)__LINE__);
        
    fprintf(stderr,"%d: writing done %zu\n",sz);
    fclose(sf);
    free(s);
    return 0;
}

user@ws:~$ ./a.out 
30: writing done 4347395995

问题的 glibc 票证: https://sourceware.org/bugzilla/show_bug.cgi?id=26573

解决方法

POSIX 是否保证在 open_memstream 的 FILE 写操作上设置了 ferror?

令我惊讶的是,不,我在 open_memstreamferror 中都看不到任何东西。

浏览 glibc,在 glibc/memstream.c 中它没有在标志中设置 _IO_ERR_SEEN,所以 ferror 不会输出。

如果 FILE 是使用 open_memstream 创建的,我如何检查 FILE 操作的内存不足情况?

检查 sz 是否增加。检查errno

,

缓冲区仅在 fflush 之后可见,并且

成功完成后,fflush() 应返回 0;否则,它应该为流设置错误指示符,返回EOF,并设置errno以指示错误。

这就要求设置错误指示器。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。