 
                            ...
The
getenvfunction returns a pointer to a string associated with the matched list member. The string pointed to shall not be modified by the program but may be overwritten by a subsequent call to thegetenvfunction. If the specifiednamecannot be found, a null pointer is returned.
...
Storing the pointer to the string returned by getenv(), localeconv(), setlocale(), or strerror() can result in overwritten data.
| Rule | Severity | Likelihood | Detectable | RepairableRemediation Cost | Priority | Level | 
|---|---|---|---|---|---|---|
| ENV34-C | Low | Probable | Yes | NoMedium | P4 | L3 | 
Related Vulnerabilities
Search for vulnerabilities resulting from the violation of this rule on the CERT website.
...
| Tool | Version | Checker | Description | ||||||
|---|---|---|---|---|---|---|---|---|---|
| Compass/ROSE | |||||||||
| Cppcheck Premium | 24.9.0 | premium-cert-env34-c | |||||||
| Helix QAC | 
 | DF2681, DF2682, DF2683 | |||||||
| Klocwork | 
 | MISRA.STDLIB.ILLEGAL_REUSE.2012_AMD1 | |||||||
| LDRA tool suite | 
 | 133 D | Fully implemented | ||||||
| Parasoft C/C++test | 
 | CERT_C-ENV34-a | Pointers returned by certain Standard Library functions should not be used following a subsequent call to the same or related function | ||||||
| 
 | CERT C: Rule ENV34-C | Checks for misuse of return value from nonreentrant standard function (rule fully covered) | 
Related Guidelines
Key here (explains table format and definitions)
...