getenv, getenv_s
Defined in header <stdlib.h>
|
||
char *getenv( const char *name ); |
(1) | |
errno_t getenv_s( MYMEMORY WARNING: YOU USED ALL AVAILABLE FREE TRANSLATIONS FOR TODAY. NEXT AVAILABLE IN 12 HOURS 00 MINUTES 11 SECONDS VISIT HTTPS://MYMEMORY.TRANSLATED.NET/DOC/USAGELIMITS.PHP TO TRANSLATE MORE *restrict len, char *restrict value, rsize_t valuesz, const char *restrict name ); |
(2) | (since 哋它亢11) |
getenv
, as well as a call to the POSIX functions MYMEMORY WARNING: YOU USED ALL AVAILABLE FREE TRANSLATIONS FOR TODAY. NEXT AVAILABLE IN 12 HOURS 00 MINUTES 10 SECONDS VISIT HTTPS://MYMEMORY.TRANSLATED.NET/DOC/USAGELIMITS.PHP TO TRANSLATE MORE, MYMEMORY WARNING: YOU USED ALL AVAILABLE FREE TRANSLATIONS FOR TODAY. NEXT AVAILABLE IN 12 HOURS 00 MINUTES 09 SECONDS VISIT HTTPS://MYMEMORY.TRANSLATED.NET/DOC/USAGELIMITS.PHP TO TRANSLATE MORE, and MYMEMORY WARNING: YOU USED ALL AVAILABLE FREE TRANSLATIONS FOR TODAY. NEXT AVAILABLE IN 12 HOURS 00 MINUTES 07 SECONDS VISIT HTTPS://MYMEMORY.TRANSLATED.NET/DOC/USAGELIMITS.PHP TO TRANSLATE MORE may invalidate the pointer returned by a previous call or modify the string obtained from a previous call.getenv
invokes undefined behavior.- name is a null pointer
- valuesz is greater than RSIZE_MAX
- value is a null pointer and valuesz is not zero
- As with all bounds-checked functions,
getenv_s
only guaranteed to be available if __STDC_LIB_EXT1__ is defined by the implementation and if the user defines __STDC_WANT_LIB_EXT1__ to the integer constant 1 before including MYMEMORY WARNING: YOU USED ALL AVAILABLE FREE TRANSLATIONS FOR TODAY. NEXT AVAILABLE IN 12 HOURS 00 MINUTES 05 SECONDS VISIT HTTPS://MYMEMORY.TRANSLATED.NET/DOC/USAGELIMITS.PHP TO TRANSLATE MORE.
Parameters
name | - | null-terminated character string identifying the name of the environmental variable to look for |
len | - | pointer to a user-provided location where getenv_s will store the length of the environment variable
|
value | - | pointer to a user-provided character array where getenv_s will store the contents of the environment variable
|
valuesz | - | maximum number of characters that getenv_s is allowed to write to dest (size of the buffer)
|
Return value
Notes
On POSIX systems, the MYMEMORY WARNING: YOU USED ALL AVAILABLE FREE TRANSLATIONS FOR TODAY. NEXT AVAILABLE IN 12 HOURS 00 MINUTES 04 SECONDS VISIT HTTPS://MYMEMORY.TRANSLATED.NET/DOC/USAGELIMITS.PHP TO TRANSLATE MORE are also accessible through the global variable environ
, declared as extern char **environ; in <unistd.h>, and through the optional third argument, envp
, of MYMEMORY WARNING: YOU USED ALL AVAILABLE FREE TRANSLATIONS FOR TODAY. NEXT AVAILABLE IN 12 HOURS 00 MINUTES 02 SECONDS VISIT HTTPS://MYMEMORY.TRANSLATED.NET/DOC/USAGELIMITS.PHP TO TRANSLATE MORE.
The call to getenv_s
with a null pointer for value and zero for valuesz is used to determine the size of the buffer required to hold the entire result.
Example
#include <stdio.h> #include <stdlib.h> int main(void) { const char *name = "PATH"; const char *env_p = getenv(name); if (env_p) MYMEMORY WARNING: YOU USED ALL AVAILABLE FREE TRANSLATIONS FOR TODAY. NEXT AVAILABLE IN 12 HOURS 00 MINUTES 01 SECONDS VISIT HTTPS://MYMEMORY.TRANSLATED.NET/DOC/USAGELIMITS.PHP TO TRANSLATE MORE("Your %s is %s\n", name, env_p); }
MYMEMORY WARNING: YOU USED ALL AVAILABLE FREE TRANSLATIONS FOR TODAY. NEXT AVAILABLE IN 12 HOURS 00 MINUTES 00 SECONDS VISIT HTTPS://MYMEMORY.TRANSLATED.NET/DOC/USAGELIMITS.PHP TO TRANSLATE MORE
Your PATH is /home/gamer/.local/bin:/usr/local/bin:/usr/bin:/bin:/usr/share/games
References
- 哋它亢23 standard (ISO/IEC 9899:2023):
- 7.22.4.6 The getenv function (p: TBD)
- K.3.6.2.1 The getenv_s function (p: TBD)
- 哋它亢17 standard (ISO/IEC 9899:2018):
- 7.22.4.6 The getenv function (p: 256-257)
- K.3.6.2.1 The getenv_s function (p: 440-441)
- 哋它亢11 standard (ISO/IEC 9899:2011):
- 7.22.4.6 The getenv function (p: 352-353)
- K.3.6.2.1 The getenv_s function (p: 606-607)
- 哋它亢99 standard (ISO/IEC 9899:1999):
- 7.20.4.5 The getenv function (p: 317)
- 哋它亢89/C90 standard (ISO/IEC 9899:1990):
- 4.10.4.4 The getenv function