Error Handling During File Operations in C
Last Updated :
13 May, 2025
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:
Error | Cause |
---|
File Not Found | Trying to open a file that doesn’t exist. |
---|
Permission Denied | Insufficient permissions to access the file. |
---|
Disk Full | No space left on the disk for writing data. |
---|
File Already Exists | Attempting to create a file that already exists in w mode. |
---|
Invalid File Pointer | Using a null or invalid file pointer for file operations. |
---|
End-of-File (EOF) | Attempting to read past the end of the file. |
---|
File Not Open | Attempting 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
#include <stdio.h>
int main() {
// 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);
return 0;
}
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
#include <stdio.h>
int main() {
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);
return 0;
}
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
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
int main() {
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");
}
// If we reach here, the file
// was created successfully
fprintf(fptr, "This is a new file.");
fclose(fptr);
return 0;
}
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
#include <stdio.h>
int main() {
FILE *file = fopen("test.txt", "r");
// 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.");
fclose(file);
return 0;
}
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
#include <stdio.h>
int main() {
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")
return 0;
}
Output
File closing error
Similar Reads
Error Handling in C In C programming, error handling is typically done using functions that handle runtime errors, returning error codes or messages to notify the programmer about the failure or incorrect operation. Since C does not provide built-in exception handling like other high-level languages (e.g., try-catch in
8 min read
Basics of File Handling in C File handling in C is the process in which we create, open, read, write, and close operations on a file. C language provides different functions such as fopen(), fwrite(), fread(), fseek(), fprintf(), etc. to perform input, output, and many different C file operations in our program.Need of File Han
13 min read
Bank account system in C using File handling This article focuses on how to create a bank account system using C language and File handling in C. Approach:Let's discuss the approach in detail, covering all the functions and their explanation in detail- Create a Menu in the main function and create different functions for the Menu, which will b
12 min read
Output of C programs | Set 40 (File handling) Prerequisite : File handling 1. What is the output of this program by manipulating the text file? C #include <stdio.h> int main() { if (remove("myfile.txt") != 0) perror("Error"); else puts("Success"); return 0; } Options: a) Error b) Success c) Runtime Error d) C
3 min read
C Program to count number of lines in a file C /* C Program to count the Number of Lines in a Text File */ #include <stdio.h> #define MAX_FILE_NAME 100 int main() { FILE *fp; int count = 0; // Line counter (result) char filename[MAX_FILE_NAME]; char c; // To store a character read from file // Get file name from user. The file should be
1 min read