Open In App

Error Handling During File Operations in C

Last Updated : 16 Apr, 2025
Comments
Improve
Suggest changes
Like Article
Like
Report

File operations are a common task in C programming, but they can encounter various errors that need to be handled gracefully. Proper error handling ensures that your program can handle unexpected situations, such as missing files or insufficient permissions, without crashing. In this article, we will learn how to handle some common errors during file operations in C.

Here are some common errors that can occur during file operations:

ErrorCause
File Not FoundTrying to open a file that doesn’t exist.
Permission DeniedInsufficient permissions to access the file.
Disk FullNo space left on the disk for writing data.
File Already ExistsAttempting to create a file that already exists in w mode.
Invalid File PointerUsing a null or invalid file pointer for file operations.
End-of-File (EOF)Attempting to read past the end of the file.
File Not OpenAttempting to perform operations on a file that wasn’t opened successfully.

Failure to check for errors then the program may behave abnormally therefore an unchecked error may result in premature termination for the program or incorrect output.

Error Handling Techniques

Below are some standard error handling techniques:

1. File Not Found Error

A file not found error can occur when opening a file in read mode (r) or append mode (a). Use fopen() and check for NULL. If it is, the error message can be printed using perror() function.

C
//Driver Code Starts{
#include <stdio.h>

int main() {
    
//Driver Code Ends }

    // Try to open file in 
    // read mode
    FILE *file = fopen("file.txt", "r");
  
  	// Check if the file 
  	// is opened/found
    if (file == NULL) {
        perror("Error");
        return 1;
    }
    fclose(file);

//Driver Code Starts{
    return 0;
}

//Driver Code Ends }


Output

Error: No such file or directory

In the above program, fopen() returns a NULL pointer because the file is not present in the current directory, then the perror() function prints the error message.

2. Handle Permission Denied Error

If the file exists but the program lacks the required permissions, fopen() will fail and return NULL pointer. We can change the perror() output to “permission denied” as shown in the below snippet.

C
FILE *file = fopen("/restricted/file.txt", "w");
if (file == NULL) {
    perror("Permission denied");
}

3. Handle Disk Full Error

When writing to a file, ensure the disk has enough space. Errors during file operations can be detected using ferror(). In the below program, we assume that there is no space in memory to store any data.

C
//Driver Code Starts{
#include <stdio.h>

int main() {
//Driver Code Ends }

    FILE *fptr = fopen("file.txt", "w");
    if (fptr == NULL) {
        perror("Error opening file");
        return 1;
    }
    
    fprintf(fptr, "Writing to file");
    
    // Check error after performing
    // write operation
    if (ferror(fptr)) {
        perror("Error writing to file");
    }
    fclose(fptr);

//Driver Code Starts{
    return 0;
}

//Driver Code Ends }


Output

Error writing to file: Permission Denied

4. Handle File Already Exists

When creating a new file with fopen() in w mode, the existing file will be overwritten. To avoid this, we open a new file in wx mode because if file is already present then fopen() return NULL and set the EEXIST value to the errno. In the below program, we assume that “test.text” file is already present in current directory.

C
//Driver Code Starts{
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
int main() {
//Driver Code Ends }

    FILE *fptr;

    // Try to open the file in 
    // write mode
    fptr = fopen("test.text", "wx");

    if (fptr == NULL) {
      
        // Check if the error is 
        // due to file already existing
        if (errno == EEXIST)
            printf("File already exist");
    }

//Driver Code Starts{

    // If we reach here, the file 
    // was created successfully
    fprintf(fptr, "This is a new file.");
    fclose(fptr);
    return 0;
}
//Driver Code Ends }


Output

File already exist

5. Handle Invalid File Pointer

Always verify that the file pointer is not NULL before performing operations like reading or writing.

C
FILE *file = NULL;
if (file == NULL) {
    printf("Invalid file pointer. File operations cannot proceed.\n");
}

6. Handle End-of-File (EOF)

When we are reading data from a file and the file pointer reaches the end of the file, we can use the feof() function to handle the end of the file.

C
//Driver Code Starts{
#include <stdio.h>

int main() {
    FILE *file = fopen("test.txt", "r");

//Driver Code Ends }

  	// Check for eof while reading
    char ch;
    while ((ch = fgetc(file)) != EOF)
        putchar(ch);

  	// Use feof() to make sure 
  	// EOF occurred or not
    if (feof(file))
        printf("End of file reached.");
    else if (ferror(file))
        printf("Error reading the file.");

//Driver Code Starts{
    fclose(file);
    return 0;
}
//Driver Code Ends }


Output

End of file reached.

7. Handle File Not Open

Whenever we attempt to open a file and the file cannot be opened due to some error, the fopen() function returns NULL. We can handle this easily using an if-else statement.

C
#include <stdio.h>
int main() {
    FILE *file = fopen("example.txt", "r");
    if (file == NULL) {
        printf("File could not be opened.\n");
    } else {
        printf("File opened successfully.\n");
        fclose(file);
    }
    
    return 0;
}

Output

File could not be opened.

File Closing Error

Sometimes, when we are closing a file using the fclose() function and it fails to close the file due to an error, it returns -1.

C
//Driver Code Starts{
#include <stdio.h>

int main() {
//Driver Code Ends }

    FILE *fptr = fopen("test.txt", "w");
    
    fprintf(fptr, "Writing to file");
    
    // Check file close properly
    if(fclose(fptr) == -1)
        printf("File closing error");
    else
        printf("File closed")

//Driver Code Starts{
    return 0;
}

//Driver Code Ends }

Output

File closing error


Next Article

Similar Reads