为什么 fopen 在不保存返回指针的情况下工作?

Why does fopen works without saving the returned pointer?

我写了一个小程序来解密一个 OTP 加密的文件。这很好用。

但是我意识到我在"Solution.jpg"上调用fopen时忘记保存返回的文件指针。如您所见,我正在写入文件指针 f。我想知道为什么这段代码有效。

#include <stdio.h>

#define FILE_SIZE 4202

int main () {
    unsigned char key[FILE_SIZE], otpCipher[FILE_SIZE];

    FILE *f = fopen("otpkey.bin", "r");
    fread(key, sizeof(char), FILE_SIZE, f);
    fclose(f);

    f = fopen("otpcipher.bin", "r");
    fread(otpCipher, sizeof(char), FILE_SIZE, f);
    fclose(f);

    fopen("Solution.jpg", "w");

    for (int j = 0; j < FILE_SIZE; ++j) {
        otpCipher[j] = otpCipher[j] ^ key[j];
        fputc(otpCipher[j], f);
    }

    fclose(f);

    return 0;
}

我刚刚使用 gdb 找到了答案。

因此,由于我在打开新文件之前使用了 fclose(),所以指向之前使用的文件的指针被释放了。这个指针可以再次使用,每次我 运行 这个程序时 fopen() 返回这个指针。

所以它起作用只是因为在我调用 fopen() 时没有打开其他文件。

这是未定义的行为,可能会导致其他问题。在任何情况下都应该避免(我错误地做到了)。我只是想了解为什么这有效并修复了我的代码。