In this section:
Overview
This error is generated if the null pointer is passed to a routine that de-allocates memory.
Excerpt |
---|
Scroll Table Layout |
---|
sortDirection | ASC |
---|
repeatTableHeaders | default |
---|
widths | 10%,60%,10%,10%,10% |
---|
sortByColumn | 1 |
---|
sortEnabled | false |
---|
cellHighlighting | true |
---|
|
Code | Description | Enabled | Reported | Platform |
---|
FREE_LOCAL | Freeing null pointer | | Runtime | Windows/Unix |
|
Problem
The following code attempts to free a null pointer:
Code Block |
---|
language | cpp |
---|
theme | Eclipse |
---|
linenumbers | true |
---|
|
/*
*File: freenull.c
*/
char*a;
main()
{
free(a);
return 0;
} |
Diagnosis at Runtime
Code Block |
---|
language | text |
---|
linenumbers | true |
---|
|
[freelocl.c:8] **FREE_LOCAL**
>> free(a);
Freeing null pointer: a
Stack trace where the error occurred
main() freenull.c8
**Memory corrupted. Program may crash!!** |
- Line 2: Source file and line at which the problem was detected.
- Line 3: Description of the problem and the expression that is in error.
- Line 5: Stack trace showing the function call sequence leading to the error.
- Line 6: Informational message indicating that a serious error has occurred which may cause the program to crash.
Repair
The quick, simple solution is to add code to check whether the pointer is null before calling free(). Alternatively, check the stack trace. Doing so can lead to clues as to how the pointer was set to null in the first place, so that the error can be prevented from the root.