Initial commit of OpenSPARC T2 architecture model.
[OpenSPARC-T2-SAM] / sam-t2 / devtools / v8plus / html / python / ext / nullPointers.html
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
<link rel="STYLESHEET" href="ext.css" type='text/css' />
<link rel="SHORTCUT ICON" href="../icons/pyfav.png" type="image/png" />
<link rel='start' href='../index.html' title='Python Documentation Index' />
<link rel="first" href="ext.html" title='Extending and Embedding the Python Interpreter' />
<link rel='contents' href='contents.html' title="Contents" />
<link rel='last' href='about.html' title='About this document...' />
<link rel='help' href='about.html' title='About this document...' />
<link rel="prev" href="thinIce.html" />
<link rel="parent" href="refcounts.html" />
<link rel="next" href="cplusplus.html" />
<meta name='aesop' content='information' />
<title>1.10.4 NULL Pointers
</title>
</head>
<body>
<DIV CLASS="navigation">
<div id='top-navigation-panel' xml:id='top-navigation-panel'>
<table align="center" width="100%" cellpadding="0" cellspacing="2">
<tr>
<td class='online-navigation'><a rel="prev" title="1.10.3 Thin Ice"
href="thinIce.html"><img src='../icons/previous.png'
border='0' height='32' alt='Previous Page' width='32' /></A></td>
<td class='online-navigation'><a rel="parent" title="1.10 Reference Counts"
href="refcounts.html"><img src='../icons/up.png'
border='0' height='32' alt='Up One Level' width='32' /></A></td>
<td class='online-navigation'><a rel="next" title="1.11 Writing Extensions in"
href="cplusplus.html"><img src='../icons/next.png'
border='0' height='32' alt='Next Page' width='32' /></A></td>
<td align="center" width="100%">Extending and Embedding the Python Interpreter</td>
<td class='online-navigation'><a rel="contents" title="Table of Contents"
href="contents.html"><img src='../icons/contents.png'
border='0' height='32' alt='Contents' width='32' /></A></td>
<td class='online-navigation'><img src='../icons/blank.png'
border='0' height='32' alt='' width='32' /></td>
<td class='online-navigation'><img src='../icons/blank.png'
border='0' height='32' alt='' width='32' /></td>
</tr></table>
<div class='online-navigation'>
<b class="navlabel">Previous:</b>
<a class="sectref" rel="prev" href="thinIce.html">1.10.3 Thin Ice</A>
<b class="navlabel">Up:</b>
<a class="sectref" rel="parent" href="refcounts.html">1.10 Reference Counts</A>
<b class="navlabel">Next:</b>
<a class="sectref" rel="next" href="cplusplus.html">1.11 Writing Extensions in</A>
</div>
<hr /></div>
</DIV>
<!--End of Navigation Panel-->
<H2><A NAME="SECTION0031040000000000000000"></A><A NAME="nullPointers"></A>
<BR>
1.10.4 NULL Pointers
</H2>
<P>
In general, functions that take object references as arguments do not
expect you to pass them <tt class="constant">NULL</tt> pointers, and will dump core (or
cause later core dumps) if you do so. Functions that return object
references generally return <tt class="constant">NULL</tt> only to indicate that an
exception occurred. The reason for not testing for <tt class="constant">NULL</tt>
arguments is that functions often pass the objects they receive on to
other function -- if each function were to test for <tt class="constant">NULL</tt>,
there would be a lot of redundant tests and the code would run more
slowly.
<P>
It is better to test for <tt class="constant">NULL</tt> only at the ``source:'' when a
pointer that may be <tt class="constant">NULL</tt> is received, for example, from
<tt class="cfunction">malloc()</tt> or from a function that may raise an exception.
<P>
The macros <tt class="cfunction">Py_INCREF()</tt> and <tt class="cfunction">Py_DECREF()</tt>
do not check for <tt class="constant">NULL</tt> pointers -- however, their variants
<tt class="cfunction">Py_XINCREF()</tt> and <tt class="cfunction">Py_XDECREF()</tt> do.
<P>
The macros for checking for a particular object type
(<code>Py<var>type</var>_Check()</code>) don't check for <tt class="constant">NULL</tt> pointers --
again, there is much code that calls several of these in a row to test
an object against various different expected types, and this would
generate redundant tests. There are no variants with <tt class="constant">NULL</tt>
checking.
<P>
The C function calling mechanism guarantees that the argument list
passed to C functions (<code>args</code> in the examples) is never
<tt class="constant">NULL</tt> -- in fact it guarantees that it is always a tuple.<A NAME="tex2html4"
HREF="#foot464"><SUP>1.4</SUP></A>
<P>
It is a severe error to ever let a <tt class="constant">NULL</tt> pointer ``escape'' to
the Python user.
<P>
<BR><HR><H4>Footnotes</H4>
<DL>
<DT><A NAME="foot464">... tuple.</A><A
href="nullPointers.html#tex2html4"><SUP>1.4</SUP></A></DT>
<DD>
These guarantees don't hold when you use the ``old'' style
calling convention -- this is still found in much existing code.
</DD>
</DL>
<DIV CLASS="navigation">
<div class='online-navigation'>
<p></p><hr />
<table align="center" width="100%" cellpadding="0" cellspacing="2">
<tr>
<td class='online-navigation'><a rel="prev" title="1.10.3 Thin Ice"
href="thinIce.html"><img src='../icons/previous.png'
border='0' height='32' alt='Previous Page' width='32' /></A></td>
<td class='online-navigation'><a rel="parent" title="1.10 Reference Counts"
href="refcounts.html"><img src='../icons/up.png'
border='0' height='32' alt='Up One Level' width='32' /></A></td>
<td class='online-navigation'><a rel="next" title="1.11 Writing Extensions in"
href="cplusplus.html"><img src='../icons/next.png'
border='0' height='32' alt='Next Page' width='32' /></A></td>
<td align="center" width="100%">Extending and Embedding the Python Interpreter</td>
<td class='online-navigation'><a rel="contents" title="Table of Contents"
href="contents.html"><img src='../icons/contents.png'
border='0' height='32' alt='Contents' width='32' /></A></td>
<td class='online-navigation'><img src='../icons/blank.png'
border='0' height='32' alt='' width='32' /></td>
<td class='online-navigation'><img src='../icons/blank.png'
border='0' height='32' alt='' width='32' /></td>
</tr></table>
<div class='online-navigation'>
<b class="navlabel">Previous:</b>
<a class="sectref" rel="prev" href="thinIce.html">1.10.3 Thin Ice</A>
<b class="navlabel">Up:</b>
<a class="sectref" rel="parent" href="refcounts.html">1.10 Reference Counts</A>
<b class="navlabel">Next:</b>
<a class="sectref" rel="next" href="cplusplus.html">1.11 Writing Extensions in</A>
</div>
</div>
<hr />
<span class="release-info">Release 2.4.2, documentation updated on 28 September 2005.</span>
</DIV>
<!--End of Navigation Panel-->
<ADDRESS>
See <i><a href="about.html">About this document...</a></i> for information on suggesting changes.
</ADDRESS>
</BODY>
</HTML>