2000-04-21 22:33:34 +02:00
|
|
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN">
|
2001-09-18 01:24:40 +02:00
|
|
|
<html>
|
|
|
|
<head>
|
2001-10-09 22:18:14 +02:00
|
|
|
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
|
|
|
|
<meta name="AUTHOR" content="pme@gcc.gnu.org (Phil Edwards)">
|
|
|
|
<meta name="KEYWORDS" content="HOWTO, libstdc++, gcc, g++, libg++, STL">
|
|
|
|
<meta name="DESCRIPTION" content="HOWTO for libstdc++ chapter 17.">
|
|
|
|
<meta name="GENERATOR" content="vi and eight fingers">
|
2001-09-18 01:24:40 +02:00
|
|
|
<title>libstdc++-v3 HOWTO: Chapter 17</title>
|
2001-10-11 20:41:47 +02:00
|
|
|
<link rel="StyleSheet" href="../lib3styles.css">
|
2001-09-18 01:24:40 +02:00
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
|
2001-10-09 22:18:14 +02:00
|
|
|
<h1 class="centered"><a name="top">Chapter 17: Library Introduction</a></h1>
|
2001-09-18 01:24:40 +02:00
|
|
|
|
|
|
|
<p>Chapter 17 is actually a list of definitions and descriptions used
|
2000-04-21 22:33:34 +02:00
|
|
|
in the following chapters of the Standard when describing the actual
|
|
|
|
library. Here, we use "Introduction" as an introduction
|
2001-09-18 01:24:40 +02:00
|
|
|
to the <em>GNU implementation of</em> the ISO Standard C++ Library.
|
|
|
|
</p>
|
2000-04-21 22:33:34 +02:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ####################################################### -->
|
2001-09-18 01:24:40 +02:00
|
|
|
<hr>
|
|
|
|
<h1>Contents</h1>
|
|
|
|
<ul>
|
|
|
|
<li><a href="#2">The Standard C++ header files</a>
|
2001-11-16 21:59:10 +01:00
|
|
|
<li><a href="#3">The Standard C++ library and multithreading</a>
|
2001-09-18 01:24:40 +02:00
|
|
|
<li><a href="#4"><code><foo></code> vs <code><foo.h></code></a>
|
2001-10-09 22:18:14 +02:00
|
|
|
<li><a href="porting-howto.html">Porting HOWTO</a>
|
2002-02-02 01:18:24 +01:00
|
|
|
<li><a href="#5">Behavior specific to libstdc++-v3</a>
|
2001-09-18 01:24:40 +02:00
|
|
|
</ul>
|
2000-04-21 22:33:34 +02:00
|
|
|
|
2001-09-18 01:24:40 +02:00
|
|
|
<hr>
|
2000-04-21 22:33:34 +02:00
|
|
|
|
|
|
|
<!-- ####################################################### -->
|
|
|
|
|
2001-09-18 01:24:40 +02:00
|
|
|
<h2><a name="2">The Standard C++ header files</a></h2>
|
|
|
|
<p>The Standard C++ Library specifies 50 header files that must be
|
2000-04-21 22:33:34 +02:00
|
|
|
available to all hosted implementations. Actually, the word
|
|
|
|
"files" is a misnomer, since the contents of the headers
|
|
|
|
don't necessarily have to be in any kind of external file. The
|
2001-09-18 01:24:40 +02:00
|
|
|
only rule is that when you <code>#include</code> a certain header, the
|
2000-04-21 22:33:34 +02:00
|
|
|
contents of that header, as defined by the Standard, become
|
|
|
|
available to you, no matter how.
|
2001-09-18 01:24:40 +02:00
|
|
|
</p>
|
|
|
|
<p>The names of the headers can be easily seen in
|
|
|
|
<a href="headers_cc.txt"><code>testsuite/17_intro/headers.cc</code></a>,
|
2000-04-21 22:33:34 +02:00
|
|
|
which is a small testbed we use to make certain that the headers
|
|
|
|
all compile and run.
|
2001-09-18 01:24:40 +02:00
|
|
|
</p>
|
2000-04-21 22:33:34 +02:00
|
|
|
|
2001-09-18 01:24:40 +02:00
|
|
|
<hr>
|
2001-11-16 21:59:10 +01:00
|
|
|
<h2><a name="3">The Standard C++ library and multithreading</a></h2>
|
|
|
|
<p>This section discusses issues surrounding the proper compilation
|
|
|
|
of multithreaded applications which use the Standard C++
|
|
|
|
library. This information is gcc-specific since the C++
|
|
|
|
standard does not address matters of multithreaded applications.
|
|
|
|
Unless explicitly prefaced, all information in this section is
|
|
|
|
current as of the gcc 3.0 release and all later point releases.
|
2001-09-18 01:24:40 +02:00
|
|
|
</p>
|
2001-11-16 21:59:10 +01:00
|
|
|
<p>Earlier gcc releases had a somewhat different approach to
|
|
|
|
threading configuration and proper compilation. Before gcc 3.0,
|
|
|
|
configuration of the threading model was dictated by compiler
|
|
|
|
command-line options and macros (both of which were somewhat
|
|
|
|
thread-implementation and port-specific). There were no
|
|
|
|
guarantees related to being able to link code compiled with one
|
|
|
|
set of options and macro setting with another set. For gcc 3.0,
|
|
|
|
configuration of the threading model used with libraries and
|
|
|
|
user-code is performed when gcc is configured and built using
|
|
|
|
the --enable-threads and --disable-threads options. The ABI is
|
|
|
|
stable for symbol name-mangling and limited functional
|
|
|
|
compatibility exists between code compiled under different
|
|
|
|
threading models.
|
2001-09-18 01:24:40 +02:00
|
|
|
</p>
|
2001-11-16 21:59:10 +01:00
|
|
|
<p>All normal disclaimers aside, multithreaded C++ application are
|
|
|
|
only supported when libstdc++ and all user code was built with
|
2001-11-28 01:02:04 +01:00
|
|
|
compilers which report (via <code> gcc/g++ -v </code>) the same thread
|
2001-11-16 21:59:10 +01:00
|
|
|
model and that model is not <em>single</em>. As long as your
|
|
|
|
final application is actually single-threaded, then it should be
|
|
|
|
safe to mix user code built with a thread model of
|
|
|
|
<em>single</em> with a libstdc++ and other C++ libraries built
|
|
|
|
with another thread model useful on the platform. Other mixes
|
|
|
|
may or may not work but are not considered supported. (Thus, if
|
|
|
|
you distribute a shared C++ library in binary form only, it may
|
|
|
|
be best to compile it with a gcc configured with
|
|
|
|
--enable-threads for maximal interchangeability and usefulness
|
|
|
|
with a user population that may have built gcc with either
|
|
|
|
--enable-threads or --disable-threads.)
|
2001-09-18 01:24:40 +02:00
|
|
|
</p>
|
2001-11-16 21:59:10 +01:00
|
|
|
<p>When you link a multithreaded application, you will probably
|
|
|
|
need to add a library or flag to g++. This is a very
|
2001-11-28 01:02:04 +01:00
|
|
|
non-standardized area of GCC across ports. Some ports support a
|
2001-11-16 21:59:10 +01:00
|
|
|
special flag (the spelling isn't even standardized yet) to add
|
|
|
|
all required macros to a compilation (if any such flags are
|
|
|
|
required then you must provide the flag for all compilations not
|
|
|
|
just linking) and link-library additions and/or replacements at
|
|
|
|
link time. The documentation is weak. Here is a quick summary
|
|
|
|
to display how ad hoc this is: On Solaris, both -pthreads and
|
|
|
|
-threads (with subtly different meanings) are honored. On OSF,
|
|
|
|
-pthread and -threads (with subtly different meanings) are
|
|
|
|
honored. On Linux/i386, -pthread is honored. On FreeBSD,
|
|
|
|
-pthread is honored. Some other ports use other switches.
|
|
|
|
AFAIK, none of this is properly documented anywhere other than
|
|
|
|
in ``gcc -dumpspecs'' (look at lib and cpp entries).
|
2001-09-18 01:24:40 +02:00
|
|
|
</p>
|
2001-11-16 21:59:10 +01:00
|
|
|
<p>See <a href="../faq/index.html#3">FAQ</a> (general overview), <a
|
|
|
|
href="../23_containers/howto.html#3">23</a> (containers), and <a
|
|
|
|
href="../27_io/howto.html#9">27</a> (I/O) for more information.
|
|
|
|
</p>
|
|
|
|
<p>The libstdc++-v3 library (unlike libstdc++-v2, all of it, not
|
|
|
|
just the STL) has been designed so that multithreaded
|
|
|
|
applications using it may be written. The first problem is
|
|
|
|
finding a <em>fast</em> method of implementation portable to all
|
|
|
|
platforms. Due to historical reasons, some of the library is
|
|
|
|
written against per-CPU-architecture spinlocks and other parts
|
|
|
|
against the gthr.h abstraction layer which is provided by gcc.
|
|
|
|
A minor problem that pops up every so often is different
|
|
|
|
interpretations of what "thread-safe" means for a
|
|
|
|
library (not a general program). We currently use the <a
|
|
|
|
href="http://www.sgi.com/tech/stl/thread_safety.html">same
|
|
|
|
definition that SGI</a> uses for their STL subset. However, the
|
|
|
|
exception for read-only containers only applies to the STL
|
|
|
|
components.
|
2001-09-18 01:24:40 +02:00
|
|
|
</p>
|
|
|
|
<p>Here is a small link farm to threads (no pun) in the mail archives
|
2000-04-21 22:33:34 +02:00
|
|
|
that discuss the threading problem. Each link is to the first
|
ChangeLog, [...]: Fix spelling errors.
* ChangeLog, docs/doxygen/maint.cfg.in, docs/doxygen/user.cfg.in,
docs/doxygen/doxygroups.cc, docs/doxygen/Intro.3,
docs/html/17_intro/BUGS, docs/html/17_intro/C++STYLE,
docs/html/17_intro/CHECKLIST, docs/html/17_intro/DESIGN,
docs/html/17_intro/howto.html, docs/html/17_intro/porting.html,
docs/html/17_intro/porting.texi, docs/html/18_support/howto.html,
docs/html/19_diagnostics/howto.html, docs/html/20_util/howto.html,
docs/html/21_strings/howto.html,
docs/html/23_containers/howto.html,
docs/html/26_numerics/howto.html, docs/html/27_io/howto.html,
docs/html/27_io/binary_iostreams_kuehl.txt,
docs/html/ext/sgiexts.html, docs/html/faq/index.html,
docs/html/faq/index.txt, testsuite/24_iterators/iterator.cc,
include/bits/basic_file.h, include/bits/locale_facets.h,
include/bits/locale_facets.tcc, include/bits/std_sstream.h,
include/ext/ropeimpl.h, include/ext/stl_rope.h,
libsupc++/tinfo.cc, libsupc++/cxxabi.h, libsupc++/typeinfo,
libsupc++/eh_throw.cc, acinclude.m4, aclocal.m4, configure,
configure.target, ChangeLog-2000: Fix spelling errors.
From-SVN: r47291
2001-11-23 17:29:02 +01:00
|
|
|
relevant message in the thread; from there you can use
|
2000-04-21 22:33:34 +02:00
|
|
|
"Thread Next" to move down the thread. This farm is in
|
|
|
|
latest-to-oldest order.
|
2001-09-18 01:24:40 +02:00
|
|
|
<ul>
|
2001-10-17 20:14:58 +02:00
|
|
|
<li>Our threading expert Loren gives a breakdown of
|
|
|
|
<a href="http://gcc.gnu.org/ml/libstdc++/2001-10/msg00024.html">the
|
|
|
|
six situations involving threads</a> for the 3.0 release series.
|
2001-09-18 01:24:40 +02:00
|
|
|
<li><a href="http://gcc.gnu.org/ml/libstdc++/2001-05/msg00384.html">
|
2001-10-17 20:14:58 +02:00
|
|
|
This message</a> inspired a recent updating of issues with threading
|
2001-09-15 02:41:11 +02:00
|
|
|
and the SGI STL library. It also contains some example
|
2001-10-17 20:14:58 +02:00
|
|
|
POSIX-multithreaded STL code.
|
2001-09-18 01:24:40 +02:00
|
|
|
</ul>
|
2001-10-17 20:14:58 +02:00
|
|
|
(A large selection of links to older messages has been removed; many
|
|
|
|
of the messages from 1999 were lost in a disk crash, and the few
|
|
|
|
people with access to the backup tapes have been too swamped with work
|
ChangeLog, [...]: Fix spelling errors.
* ChangeLog, docs/doxygen/maint.cfg.in, docs/doxygen/user.cfg.in,
docs/doxygen/doxygroups.cc, docs/doxygen/Intro.3,
docs/html/17_intro/BUGS, docs/html/17_intro/C++STYLE,
docs/html/17_intro/CHECKLIST, docs/html/17_intro/DESIGN,
docs/html/17_intro/howto.html, docs/html/17_intro/porting.html,
docs/html/17_intro/porting.texi, docs/html/18_support/howto.html,
docs/html/19_diagnostics/howto.html, docs/html/20_util/howto.html,
docs/html/21_strings/howto.html,
docs/html/23_containers/howto.html,
docs/html/26_numerics/howto.html, docs/html/27_io/howto.html,
docs/html/27_io/binary_iostreams_kuehl.txt,
docs/html/ext/sgiexts.html, docs/html/faq/index.html,
docs/html/faq/index.txt, testsuite/24_iterators/iterator.cc,
include/bits/basic_file.h, include/bits/locale_facets.h,
include/bits/locale_facets.tcc, include/bits/std_sstream.h,
include/ext/ropeimpl.h, include/ext/stl_rope.h,
libsupc++/tinfo.cc, libsupc++/cxxabi.h, libsupc++/typeinfo,
libsupc++/eh_throw.cc, acinclude.m4, aclocal.m4, configure,
configure.target, ChangeLog-2000: Fix spelling errors.
From-SVN: r47291
2001-11-23 17:29:02 +01:00
|
|
|
to restore them. Many of the points have been superseded anyhow.)
|
2001-09-18 01:24:40 +02:00
|
|
|
</p>
|
|
|
|
<p>This section will be updated as new and interesting issues come
|
2000-04-21 22:33:34 +02:00
|
|
|
to light.
|
2001-09-18 01:24:40 +02:00
|
|
|
</p>
|
|
|
|
<p>Return <a href="#top">to top of page</a> or
|
|
|
|
<a href="../faq/index.html">to the FAQ</a>.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<hr>
|
|
|
|
<h2><a name="4"><code><foo></code> vs <code><foo.h></code></a></h2>
|
|
|
|
<p>The new-style headers are fully supported in libstdc++-v3. The compiler
|
|
|
|
itself fully supports namespaces, including <code>std::</code>.
|
|
|
|
</p>
|
|
|
|
<p>For those of you new to ISO C++98, no, that isn't a typo, the headers
|
2000-04-21 22:33:34 +02:00
|
|
|
really have new names. Marshall Cline's C++ FAQ Lite has a good
|
|
|
|
explanation in
|
2001-09-18 01:24:40 +02:00
|
|
|
<a href="http://www.cerfnet.com/~mpcline/On-Line-C++-FAQ/coding-standards.html#[25.4]">item [25.4]</a>.
|
|
|
|
</p>
|
|
|
|
<p>Return <a href="#top">to top of page</a> or
|
|
|
|
<a href="../faq/index.html">to the FAQ</a>.
|
|
|
|
</p>
|
2000-04-21 22:33:34 +02:00
|
|
|
|
2002-02-02 01:18:24 +01:00
|
|
|
<hr>
|
|
|
|
<h2><a name="5">Behavior specific to libstdc++-v3</a></h2>
|
|
|
|
<p>The ISO standard defines the following:
|
|
|
|
<blockquote><dl>
|
|
|
|
<dt><code>[1.3.5] implementation-defined behavior</code>
|
|
|
|
<dd>behavior, for a well-formed program construct and correct data, that
|
|
|
|
depends on the implementation <strong>and that each implementation
|
|
|
|
shall document</strong>.
|
|
|
|
</dl></blockquote>
|
|
|
|
We do so here, for the C++ library only. Behavior of the compiler,
|
|
|
|
linker, runtime loader, and other elements of "the
|
|
|
|
implementation" are documented elsewhere.
|
|
|
|
</p>
|
|
|
|
<p>For each entry, we give the section number of the standard, when
|
|
|
|
applicable. This list is known to be incomplet and inkorrekt.
|
|
|
|
</p>
|
|
|
|
<p><strong>[17.4.4.5]</strong> Non-reentrant functions are probably best
|
|
|
|
discussed in the various sections on multithreading (see above).
|
|
|
|
</p>
|
|
|
|
<!-- [17.4.4.8]/3 says any function that doesn't have an exception-spec
|
|
|
|
can throw whatever we want; see also its footnote. Let's list those
|
|
|
|
in the sections where the function itself occurs.
|
|
|
|
-->
|
|
|
|
<p><strong>[18.1]/4</strong> The type of <code>NULL</code> is described
|
|
|
|
<a href="../18_support/howto.html#1">here</a>.
|
|
|
|
</p>
|
|
|
|
<p><strong>[18.3]/8</strong> Even though it's listed in the library
|
|
|
|
sections, libstdc++-v3 has zero control over what the cleanup code hands
|
|
|
|
back to the runtime loader. Talk to the compiler people. :-)
|
|
|
|
</p>
|
|
|
|
<p><strong>[18.4.2.1]/5</strong> (bad_alloc),<br>
|
|
|
|
<strong>[18.5.2]/5</strong> (bad_cast),<br>
|
|
|
|
<strong>[18.5.3]/5</strong> (bad_typeid),<br>
|
|
|
|
<strong>[18.6.1]/8</strong> (exception),<br>
|
|
|
|
<strong>[18.6.2.1]/5</strong> (bad_exception): The <code>what()</code>
|
|
|
|
member function of class <code>std::exception</code>, and these other
|
|
|
|
classes publicly derived from it, simply returns the name of the
|
|
|
|
class. But they are the <em>mangled</em> names.
|
|
|
|
<!-- demangler bug fixed yet? -->
|
|
|
|
(The classes in <code><stdexcept></code> have constructors which
|
|
|
|
require a string argument to use in <code>what()</code> calls, so the
|
|
|
|
question does not arise in most user-defined exceptions.)
|
|
|
|
</p>
|
|
|
|
<p><strong></strong>
|
|
|
|
</p>
|
|
|
|
<p><strong></strong>
|
|
|
|
</p>
|
|
|
|
<p><strong></strong>
|
|
|
|
</p>
|
|
|
|
<p><strong></strong>
|
|
|
|
</p>
|
|
|
|
<p><strong></strong>
|
|
|
|
</p>
|
|
|
|
<p><strong></strong>
|
|
|
|
</p>
|
|
|
|
<p><strong></strong>
|
|
|
|
</p>
|
|
|
|
<p><strong></strong>
|
|
|
|
</p>
|
|
|
|
<p>Return <a href="#top">to top of page</a> or
|
|
|
|
<a href="../faq/index.html">to the FAQ</a>.
|
|
|
|
</p>
|
|
|
|
|
2000-04-21 22:33:34 +02:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ####################################################### -->
|
|
|
|
|
2001-09-18 01:24:40 +02:00
|
|
|
<hr>
|
2001-10-09 22:18:14 +02:00
|
|
|
<p class="fineprint"><em>
|
2001-10-04 22:03:22 +02:00
|
|
|
See <a href="license.html">license.html</a> for copying conditions.
|
2000-04-21 22:33:34 +02:00
|
|
|
Comments and suggestions are welcome, and may be sent to
|
2001-10-09 22:18:14 +02:00
|
|
|
<a href="mailto:libstdc++@gcc.gnu.org">the libstdc++ mailing list</a>.
|
2001-09-18 01:24:40 +02:00
|
|
|
</em></p>
|
2000-04-21 22:33:34 +02:00
|
|
|
|
|
|
|
|
2001-09-18 01:24:40 +02:00
|
|
|
</body>
|
|
|
|
</html>
|
2000-04-21 22:33:34 +02:00
|
|
|
|
|
|
|
|