
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
        "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"><script async src="//pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script>
<!-- MyFirstUnitAd -->
<ins class="adsbygoogle"
     style="display:inline-block;width:970px;height:250px"
     data-ad-client="ca-pub-5778386704669218"
     data-ad-slot="1503492166"></ins>
<script>
(adsbygoogle = window.adsbygoogle || []).push({});
</script>

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <link rel="stylesheet" type="text/css" href="../../../style.css" title="style" />
    <link rel="stylesheet" type="text/css" href="../style.css" title="style" />
    <meta http-equiv="content-type" content="text/html;charset=utf-8" />

    <title>getenv.3p - Linux manual page</title>
</head>

<body>

<div class="page-top"><a id="top_of_page"></a></div>
<!--%%%TOP_BAR%%%-->
    <div class="nav-bar">
        <table class="nav-table">
            <tr>
                <td class="nav-cell">
                    <p class="nav-text">
                        <a href="http://man7.org/index.html">man7.org</a> &gt; Linux &gt; <a href="../index.html">man-pages</a>
                    </p>
                </td>
                <td class="training-cell">
                    <p class="training-text"><a class="training-link" href="http://man7.org/training/">Linux/UNIX system programming training</a></p>
                </td>
            </tr>
        </table>
    </div>

<hr class="nav-end" />

<!--%%%PAGE_START%%%-->


<table class="sec-table">
<tr>
    <td>
        <p class="section-dir">
<a href="getenv.3p.html#PROLOG">PROLOG</a> | <a href="getenv.3p.html#NAME">NAME</a> | <a href="getenv.3p.html#SYNOPSIS">SYNOPSIS</a> | <a href="getenv.3p.html#DESCRIPTION">DESCRIPTION</a> | <a href="getenv.3p.html#RETURN_VALUE">RETURN&nbsp;VALUE</a> | <a href="getenv.3p.html#ERRORS">ERRORS</a> | <a href="getenv.3p.html#EXAMPLES">EXAMPLES</a> | <a href="getenv.3p.html#APPLICATION_USAGE">APPLICATION&nbsp;USAGE</a> | <a href="getenv.3p.html#RATIONALE">RATIONALE</a> | <a href="getenv.3p.html#FUTURE_DIRECTIONS">FUTURE&nbsp;DIRECTIONS</a> | <a href="getenv.3p.html#SEE_ALSO">SEE&nbsp;ALSO</a> | <a href="getenv.3p.html#COPYRIGHT">COPYRIGHT</a>
        </p>
    </td>
    <td class="search-box">
        <div class="man-search-box">

            <form method="get" action="http://www.google.com/search">
                <fieldset class="man-search">
                    <input type="text" name="q" size="10" maxlength="255" value="" />
                    <input type="hidden" name="sitesearch" value="man7.org/linux/man-pages" />
                    <input type="submit" name="sa" value="Search online pages" />
                </fieldset>
            </form>

        </div>
    </td>
    <td> </td>
</tr>
</table>

<pre>
<span class="headline">GETENV(3P)                POSIX Programmer's Manual               GETENV(3P)</span>
</pre>
<h2><a id="PROLOG" href="getenv.3p.html#PROLOG"></a>PROLOG  &nbsp; &nbsp; &nbsp; &nbsp; <a href="getenv.3p.html#top_of_page"><span class="top-link">top</span></a></h2><pre>
       This manual page is part of the POSIX Programmer's Manual.  The Linux
       implementation of this interface may differ (consult the
       corresponding Linux manual page for details of Linux behavior), or
       the interface may not be implemented on Linux.
</pre>
<h2><a id="NAME" href="getenv.3p.html#NAME"></a>NAME  &nbsp; &nbsp; &nbsp; &nbsp; <a href="getenv.3p.html#top_of_page"><span class="top-link">top</span></a></h2><pre>
       getenv — get value of an environment variable
</pre>
<h2><a id="SYNOPSIS" href="getenv.3p.html#SYNOPSIS"></a>SYNOPSIS  &nbsp; &nbsp; &nbsp; &nbsp; <a href="getenv.3p.html#top_of_page"><span class="top-link">top</span></a></h2><pre>
       #include &lt;stdlib.h&gt;

       char *getenv(const char *<i>name</i>);
</pre>
<h2><a id="DESCRIPTION" href="getenv.3p.html#DESCRIPTION"></a>DESCRIPTION  &nbsp; &nbsp; &nbsp; &nbsp; <a href="getenv.3p.html#top_of_page"><span class="top-link">top</span></a></h2><pre>
       The functionality described on this reference page is aligned with
       the ISO C standard. Any conflict between the requirements described
       here and the ISO C standard is unintentional. This volume of
       POSIX.1‐2008 defers to the ISO C standard.

       The <i>getenv</i>() function shall search the environment of the calling
       process (see the Base Definitions volume of POSIX.1‐2008, <i>Chapter 8</i>,
       <i>Environment Variables</i>) for the environment variable <i>name</i> if it exists
       and return a pointer to the value of the environment variable. If the
       specified environment variable cannot be found, a null pointer shall
       be returned. The application shall ensure that it does not modify the
       string pointed to by the <i>getenv</i>() function.

       The returned string pointer might be invalidated or the string
       content might be overwritten by a subsequent call to <i>getenv</i>(),
       <i>setenv</i>(), <i>unsetenv</i>(), or (if supported) <i>putenv</i>() but they shall not
       be affected by a call to any other function in this volume of
       POSIX.1‐2008.

       The <i>getenv</i>() function need not be thread-safe.
</pre>
<h2><a id="RETURN_VALUE" href="getenv.3p.html#RETURN_VALUE"></a>RETURN VALUE  &nbsp; &nbsp; &nbsp; &nbsp; <a href="getenv.3p.html#top_of_page"><span class="top-link">top</span></a></h2><pre>
       Upon successful completion, <i>getenv</i>() shall return a pointer to a
       string containing the <i>value</i> for the specified <i>name</i>.  If the specified
       <i>name</i> cannot be found in the environment of the calling process, a
       null pointer shall be returned.
</pre>
<h2><a id="ERRORS" href="getenv.3p.html#ERRORS"></a>ERRORS  &nbsp; &nbsp; &nbsp; &nbsp; <a href="getenv.3p.html#top_of_page"><span class="top-link">top</span></a></h2><pre>
       No errors are defined.

       <i>The following sections are informative.</i>
</pre>
<h2><a id="EXAMPLES" href="getenv.3p.html#EXAMPLES"></a>EXAMPLES  &nbsp; &nbsp; &nbsp; &nbsp; <a href="getenv.3p.html#top_of_page"><span class="top-link">top</span></a></h2><pre>
   <b>Getting the Value of an Environment Variable</b>
       The following example gets the value of the <i>HOME</i> environment
       variable.

           <b>#include &lt;stdlib.h&gt;</b>
           <b>...</b>
           <b>const char *name = "HOME";</b>
           <b>char *value;</b>

           value = getenv(name);
</pre>
<h2><a id="APPLICATION_USAGE" href="getenv.3p.html#APPLICATION_USAGE"></a>APPLICATION USAGE  &nbsp; &nbsp; &nbsp; &nbsp; <a href="getenv.3p.html#top_of_page"><span class="top-link">top</span></a></h2><pre>
       None.
</pre>
<h2><a id="RATIONALE" href="getenv.3p.html#RATIONALE"></a>RATIONALE  &nbsp; &nbsp; &nbsp; &nbsp; <a href="getenv.3p.html#top_of_page"><span class="top-link">top</span></a></h2><pre>
       The <i>clearenv</i>() function was considered but rejected. The <i>putenv</i>()
       function has now been included for alignment with the Single UNIX
       Specification.

       The <i>getenv</i>() function is inherently not thread-safe because it
       returns a value pointing to static data.

       Conforming applications are required not to directly modify the
       pointers to which <i>environ</i> points, but to use only the <i>setenv</i>(),
       <i>unsetenv</i>(), and <i>putenv</i>() functions, or assignment to <i>environ</i> itself,
       to manipulate the process environment. This constraint allows the
       implementation to properly manage the memory it allocates. This
       enables the implementation to free any space it has allocated to
       strings (and perhaps the pointers to them) stored in <i>environ</i> when
       <i>unsetenv</i>() is called. A C runtime start-up procedure (that which
       invokes <i>main</i>() and perhaps initializes <i>environ</i>) can also initialize a
       flag indicating that none of the environment has yet been copied to
       allocated storage, or that the separate table has not yet been
       initialized. If the application switches to a complete new
       environment by assigning a new value to <i>environ</i>, this can be detected
       by <i>getenv</i>(), <i>setenv</i>(), <i>unsetenv</i>(), or <i>putenv</i>() and the implementation
       can at that point reinitialize based on the new environment. (This
       may include copying the environment strings into a new array and
       assigning <i>environ</i> to point to it.)

       In fact, for higher performance of <i>getenv</i>(), implementations that do
       not provide <i>putenv</i>() could also maintain a separate copy of the
       environment in a data structure that could be searched much more
       quickly (such as an indexed hash table, or a binary tree), and update
       both it and the linear list at <i>environ</i> when <i>setenv</i>() or <i>unsetenv</i>() is
       invoked. On implementations that do provide <i>putenv</i>(), such a copy
       might still be worthwhile but would need to allow for the fact that
       applications can directly modify the content of environment strings
       added with <i>putenv</i>().  For example, if an environment string found by
       searching the copy is one that was added using <i>putenv</i>(), the
       implementation would need to check that the string in <i>environ</i> still
       has the same name (and value, if the copy includes values), and
       whenever searching the copy produces no match the implementation
       would then need to search each environment string in <i>environ</i> that was
       added using <i>putenv</i>() in case any of them have changed their names and
       now match. Thus, each use of <i>putenv</i>() to add to the environment would
       reduce the speed advantage of having the copy.

       Performance of <i>getenv</i>() can be important for applications which have
       large numbers of environment variables. Typically, applications like
       this use the environment as a resource database of user-configurable
       parameters.  The fact that these variables are in the user's shell
       environment usually means that any other program that uses
       environment variables (such as <i>ls</i>, which attempts to use <i>COLUMNS</i>), or
       really almost any utility (<i>LANG</i>, <i>LC_ALL</i>, and so on) is similarly
       slowed down by the linear search through the variables.

       An implementation that maintains separate data structures, or even
       one that manages the memory it consumes, is not currently required as
       it was thought it would reduce consensus among implementors who do
       not want to change their historical implementations.
</pre>
<h2><a id="FUTURE_DIRECTIONS" href="getenv.3p.html#FUTURE_DIRECTIONS"></a>FUTURE DIRECTIONS  &nbsp; &nbsp; &nbsp; &nbsp; <a href="getenv.3p.html#top_of_page"><span class="top-link">top</span></a></h2><pre>
       A future version may add one or more functions to access and modify
       the environment in a thread-safe manner.
</pre>
<h2><a id="SEE_ALSO" href="getenv.3p.html#SEE_ALSO"></a>SEE ALSO  &nbsp; &nbsp; &nbsp; &nbsp; <a href="getenv.3p.html#top_of_page"><span class="top-link">top</span></a></h2><pre>
       <a href="../man1/exec.1p.html">exec(1p)</a>, <a href="putenv.3p.html">putenv(3p)</a>, <a href="setenv.3p.html">setenv(3p)</a>, <a href="unsetenv.3p.html">unsetenv(3p)</a>

       The Base Definitions volume of POSIX.1‐2008, <i>Chapter 8</i>, <i>Environment</i>
       <i>Variables</i>, <a href="../man0/stdlib.h.0p.html">stdlib.h(0p)</a>
</pre>
<h2><a id="COPYRIGHT" href="getenv.3p.html#COPYRIGHT"></a>COPYRIGHT  &nbsp; &nbsp; &nbsp; &nbsp; <a href="getenv.3p.html#top_of_page"><span class="top-link">top</span></a></h2><pre>
       Portions of this text are reprinted and reproduced in electronic form
       from IEEE Std 1003.1, 2013 Edition, Standard for Information
       Technology -- Portable Operating System Interface (POSIX), The Open
       Group Base Specifications Issue 7, Copyright (C) 2013 by the
       Institute of Electrical and Electronics Engineers, Inc and The Open
       Group.  (This is POSIX.1-2008 with the 2013 Technical Corrigendum 1
       applied.) In the event of any discrepancy between this version and
       the original IEEE and The Open Group Standard, the original IEEE and
       The Open Group Standard is the referee document. The original
       Standard can be obtained online at <a href="http://www.unix.org/online.html">http://www.unix.org/online.html</a> .

       Any typographical or formatting errors that appear in this page are
       most likely to have been introduced during the conversion of the
       source files to man page format. To report such errors, see
       <a href="https://www.kernel.org/doc/man-pages/reporting_bugs.html">https://www.kernel.org/doc/man-pages/reporting_bugs.html</a> .

<span class="footline">IEEE/The Open Group                 2013                          GETENV(3P)</span>
</pre>

<hr class="end-man-text" />
<p>Pages that refer to this page: 
    <a href="../man0/stdlib.h.0p.html">stdlib.h(0p)</a>,&nbsp; 
    <a href="exec.3p.html">exec(3p)</a>,&nbsp; 
    <a href="putenv.3p.html">putenv(3p)</a>,&nbsp; 
    <a href="setenv.3p.html">setenv(3p)</a>,&nbsp; 
    <a href="unsetenv.3p.html">unsetenv(3p)</a>
</p>
<hr/>

 
<hr class="start-footer" />

<div class="footer"> 

<table class="colophon-table">
    <tr>
    <td class="pub-info">
        <p>
            HTML rendering created 2018-02-02
            by <a href="http://man7.org/mtk/index.html">Michael Kerrisk</a>, 
            author of 
            <a href="http://man7.org/tlpi/"><em>The Linux Programming Interface</em></a>, 
            maintainer of the 
            <a href="https://www.kernel.org/doc/man-pages/">Linux <em>man-pages</em> project</a>.
        </p>
        <p>
            For details of in-depth
            <strong>Linux/UNIX system programming training courses</strong>
            that I teach, look <a href="http://man7.org/training/">here</a>.
        </p>
        <p>
            Hosting by <a href="http://www.jambit.com/index_en.html">jambit GmbH</a>.
        </p>
        <p>
            <a href="http://validator.w3.org/check?uri=referer">
            <img src="http://www.w3.org/Icons/valid-xhtml11"
                alt="Valid XHTML 1.1" height="31" width="88" />
            </a>
        </p>
    </td>
    <td class="colophon-divider">
    </td>
    <td class="tlpi-cover">
        <a href="http://man7.org/tlpi/"><img src="../../../tlpi/cover/TLPI-front-cover-vsmall.png" alt="Cover of TLPI" /></a>
    </td>
    </tr>
</table>

</div>

<hr class="end-footer" />



<!--BEGIN-SITETRACKING-->
<!-- SITETRACKING.man7.org_linux_man-pages -->

<!-- Start of StatCounter Code (xhtml) -->

<script type="text/javascript">
//<![CDATA[
var sc_project=7422636; 
var sc_invisible=1; 
var sc_security="9b6714ff"; 
//]]>
</script>
<script type="text/javascript"
src="http://www.statcounter.com/counter/counter_xhtml.js"></script>
<noscript><div class="statcounter"><a title="website
statistics" href="http://statcounter.com/"
class="statcounter"><img class="statcounter"
src="http://c.statcounter.com/7422636/0/9b6714ff/1/"
alt="website statistics" /></a></div></noscript>

<!-- End of StatCounter Code -->


<!-- Start of Google Analytics Code -->

<script type="text/javascript">

  var _gaq = _gaq || [];
  _gaq.push(['_setAccount', 'UA-9830363-8']);
  _gaq.push(['_trackPageview']);

  (function() {
    var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
    ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
    var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
  })();

</script>

<!-- End of Google Analytics Code -->

<!--END-SITETRACKING-->

</body>
</html>
