2007-11-06 12:13:52 +00:00
< html >
< head >
< meta http-equiv = "Content-Type" content = "text/html; charset=ISO-8859-1" >
< title > set< / title >
< link rel = "stylesheet" href = "../../boostbook.css" type = "text/css" >
< meta name = "generator" content = "DocBook XSL Stylesheets V1.66.1" >
< link rel = "start" href = "../../index.html" title = "Chapter<65> 1.<2E> Fusion 2.0" >
< link rel = "up" href = "../container.html" title = "Container" >
< link rel = "prev" href = "list.html" title = "list" >
< link rel = "next" href = "map.html" title = "map" >
< / head >
< body bgcolor = "white" text = "black" link = "#0000FF" vlink = "#840084" alink = "#0000FF" >
< table cellpadding = "2" width = "100%" > < tr >
< td valign = "top" > < img alt = "Boost C++ Libraries" width = "277" height = "86" src = "../../../../../../boost.png" > < / td >
< td align = "center" > < a href = "../../../../../../index.htm" > Home< / a > < / td >
< td align = "center" > < a href = "../../../../../libraries.htm" > Libraries< / a > < / td >
< td align = "center" > < a href = "../../../../../../people/people.htm" > People< / a > < / td >
< td align = "center" > < a href = "../../../../../../more/faq.htm" > FAQ< / a > < / td >
< td align = "center" > < a href = "../../../../../../more/index.htm" > More< / a > < / td >
< / tr > < / table >
< hr >
< div class = "spirit-nav" >
< a accesskey = "p" href = "list.html" > < img src = "../../../../../../doc/html/images/prev.png" alt = "Prev" > < / a > < a accesskey = "u" href = "../container.html" > < img src = "../../../../../../doc/html/images/up.png" alt = "Up" > < / a > < a accesskey = "h" href = "../../index.html" > < img src = "../../../../../../doc/html/images/home.png" alt = "Home" > < / a > < a accesskey = "n" href = "map.html" > < img src = "../../../../../../doc/html/images/next.png" alt = "Next" > < / a >
< / div >
< div class = "section" lang = "en" >
< div class = "titlepage" > < div > < div > < h3 class = "title" >
< a name = "fusion.container.set" > < / a > < a href = "set.html" title = "set" > set< / a > < / h3 > < / div > < / div > < / div >
< a name = "fusion.container.set.description" > < / a > < h4 >
2007-11-07 02:12:28 +00:00
< a name = "id531285" > < / a >
2007-11-06 12:13:52 +00:00
< a href = "set.html#fusion.container.set.description" > Description< / a >
< / h4 >
< p >
set is an < a href = "../sequence/concepts/associative_sequence.html" title = "Associative
Sequence">Associative
Sequence< / a > of heteregenous typed data elements. Type identity is used
to impose an equivalence relation on keys. The element's type is its key.
A set may contain at most one element for each key. Membership testing and
element key lookup has constant runtime complexity (see < a href = "../notes.html#fusion.notes.overloaded_functions" > Overloaded
Functions< / a > ).
< / p >
< a name = "fusion.container.set.header" > < / a > < h4 >
2007-11-07 02:12:28 +00:00
< a name = "id531340" > < / a >
2007-11-06 12:13:52 +00:00
< a href = "set.html#fusion.container.set.header" > Header< / a >
< / h4 >
< pre class = "programlisting" >
< span class = "preprocessor" > #include< / span > < span class = "special" > < < / span > < span class = "identifier" > boost< / span > < span class = "special" > /< / span > < span class = "identifier" > fusion< / span > < span class = "special" > /< / span > < span class = "identifier" > container< / span > < span class = "special" > /< / span > < span class = "identifier" > set< / span > < span class = "special" > .< / span > < span class = "identifier" > hpp< / span > < span class = "special" > > < / span >
< span class = "preprocessor" > #include< / span > < span class = "special" > < < / span > < span class = "identifier" > boost< / span > < span class = "special" > /< / span > < span class = "identifier" > fusion< / span > < span class = "special" > /< / span > < span class = "identifier" > include< / span > < span class = "special" > /< / span > < span class = "identifier" > set< / span > < span class = "special" > .< / span > < span class = "identifier" > hpp< / span > < span class = "special" > > < / span >
< span class = "preprocessor" > #include< / span > < span class = "special" > < < / span > < span class = "identifier" > boost< / span > < span class = "special" > /< / span > < span class = "identifier" > fusion< / span > < span class = "special" > /< / span > < span class = "identifier" > container< / span > < span class = "special" > /< / span > < span class = "identifier" > set_fwd< / span > < span class = "special" > .< / span > < span class = "identifier" > hpp< / span > < span class = "special" > > < / span >
< span class = "preprocessor" > #include< / span > < span class = "special" > < < / span > < span class = "identifier" > boost< / span > < span class = "special" > /< / span > < span class = "identifier" > fusion< / span > < span class = "special" > /< / span > < span class = "identifier" > include< / span > < span class = "special" > /< / span > < span class = "identifier" > set_fwd< / span > < span class = "special" > .< / span > < span class = "identifier" > hpp< / span > < span class = "special" > > < / span >
< / pre >
< a name = "fusion.container.set.synopsis" > < / a > < h4 >
2007-11-07 02:12:28 +00:00
< a name = "id531623" > < / a >
2007-11-06 12:13:52 +00:00
< a href = "set.html#fusion.container.set.synopsis" > Synopsis< / a >
< / h4 >
< pre class = "programlisting" >
< span class = "keyword" > template< / span > < span class = "special" > < < / span >
< span class = "keyword" > typename< / span > < span class = "identifier" > T0< / span > < span class = "special" > =< / span > < span class = "emphasis" > < em > unspecified< / em > < / span >
< span class = "special" > ,< / span > < span class = "keyword" > typename< / span > < span class = "identifier" > T1< / span > < span class = "special" > =< / span > < span class = "emphasis" > < em > unspecified< / em > < / span >
< span class = "special" > ,< / span > < span class = "keyword" > typename< / span > < span class = "identifier" > T2< / span > < span class = "special" > =< / span > < span class = "emphasis" > < em > unspecified< / em > < / span >
< span class = "special" > ...< / span >
< span class = "special" > ,< / span > < span class = "keyword" > typename< / span > < span class = "identifier" > TN< / span > < span class = "special" > =< / span > < span class = "emphasis" > < em > unspecified< / em > < / span >
< span class = "special" > > < / span >
< span class = "keyword" > struct< / span > < span class = "identifier" > set< / span > < span class = "special" > ;< / span >
< / pre >
< p >
The variadic class interface accepts < tt class = "computeroutput" > < span class = "number" > 0< / span > < / tt >
to < tt class = "computeroutput" > < span class = "identifier" > FUSION_MAX_SET_SIZE< / span > < / tt > elements,
where < tt class = "computeroutput" > < span class = "identifier" > FUSION_MAX_SET_SIZE< / span > < / tt >
is a user definable predefined maximum that defaults to < tt class = "computeroutput" > < span class = "number" > 10< / span > < / tt > .
Example:
< / p >
< pre class = "programlisting" >
< span class = "identifier" > set< / span > < span class = "special" > < < / span > < span class = "keyword" > int< / span > < span class = "special" > ,< / span > < span class = "keyword" > char< / span > < span class = "special" > ,< / span > < span class = "keyword" > double< / span > < span class = "special" > > < / span >
< / pre >
< p >
You may define the preprocessor constant < tt class = "computeroutput" > < span class = "identifier" > FUSION_MAX_SET_SIZE< / span > < / tt >
before including any Fusion header to change the default. Example:
< / p >
< pre class = "programlisting" >
< span class = "preprocessor" > #define< / span > < span class = "identifier" > FUSION_MAX_SET_SIZE< / span > < span class = "number" > 20< / span >
< / pre >
< a name = "fusion.container.set.template_parameters" > < / a > < h4 >
2007-11-07 02:12:28 +00:00
< a name = "id531954" > < / a >
2007-11-06 12:13:52 +00:00
< a href = "set.html#fusion.container.set.template_parameters" > Template parameters< / a >
< / h4 >
< div class = "informaltable" > < table class = "table" >
< colgroup >
< col >
< col >
< col >
< / colgroup >
< thead > < tr >
< th >
< p >
Parameter
< / p >
< / th >
< th >
< p >
Description
< / p >
< / th >
< th >
< p >
Default
< / p >
< / th >
< / tr > < / thead >
< tbody > < tr >
< td >
< p >
< tt class = "computeroutput" > < span class = "identifier" > T0< / span > < / tt > ...< tt class = "computeroutput" > < span class = "identifier" > TN< / span > < / tt >
< / p >
< / td >
< td >
< p >
Element types
< / p >
< / td >
< td >
< p >
< span class = "emphasis" > < em > unspecified-type< / em > < / span >
< / p >
< / td >
< / tr > < / tbody >
< / table > < / div >
< a name = "fusion.container.set.model_of" > < / a > < h4 >
2007-11-07 02:12:28 +00:00
< a name = "id532074" > < / a >
2007-11-06 12:13:52 +00:00
< a href = "set.html#fusion.container.set.model_of" > Model of< / a >
< / h4 >
< div class = "itemizedlist" > < ul type = "disc" >
< li > < a href = "../sequence/concepts/associative_sequence.html" title = "Associative
Sequence">Associative
Sequence< / a > < / li >
< li > < a href = "../sequence/concepts/forward_sequence.html" title = "Forward
Sequence">Forward Sequence< / a > < / li >
< / ul > < / div >
< div class = "variablelist" >
< p class = "title" > < b > Notation< / b > < / p >
< dl >
< dt > < span class = "term" > < tt class = "computeroutput" > < span class = "identifier" > S< / span > < / tt > < / span > < / dt >
< dd > < p >
A < tt class = "computeroutput" > < span class = "identifier" > set< / span > < / tt > type
< / p > < / dd >
< dt > < span class = "term" > < tt class = "computeroutput" > < span class = "identifier" > s< / span > < / tt > < / span > < / dt >
< dd > < p >
An instance of < tt class = "computeroutput" > < span class = "identifier" > set< / span > < / tt >
< / p > < / dd >
< dt > < span class = "term" > < tt class = "computeroutput" > < span class = "identifier" > e0< / span > < / tt > ...< tt class = "computeroutput" > < span class = "identifier" > en< / span > < / tt > < / span > < / dt >
< dd > < p >
Heterogeneous values
< / p > < / dd >
< dt > < span class = "term" > < tt class = "computeroutput" > < span class = "identifier" > fs< / span > < / tt > < / span > < / dt >
< dd > < p >
A < a href = "../sequence/concepts/forward_sequence.html" title = "Forward
Sequence">Forward Sequence< / a >
< / p > < / dd >
< / dl >
< / div >
< a name = "fusion.container.set.expression_semantics" > < / a > < h4 >
2007-11-07 02:12:28 +00:00
< a name = "id532269" > < / a >
2007-11-06 12:13:52 +00:00
< a href = "set.html#fusion.container.set.expression_semantics" > Expression Semantics< / a >
< / h4 >
< p >
Semantics of an expression is defined only where it differs from, or is not
defined in < a href = "../sequence/concepts/random_access_sequence.html" title = "Random
Access Sequence">Random
Access Sequence< / a > and < a href = "../sequence/concepts/associative_sequence.html" title = "Associative
Sequence">Associative
Sequence< / a > .
< / p >
< div class = "informaltable" > < table class = "table" >
< colgroup >
< col >
< col >
< / colgroup >
< thead > < tr >
< th >
< p >
Expression
< / p >
< / th >
< th >
< p >
Semantics
< / p >
< / th >
< / tr > < / thead >
< tbody >
< tr >
< td >
< p >
< tt class = "computeroutput" > < span class = "identifier" > S< / span > < span class = "special" > ()< / span > < / tt >
< / p >
< / td >
< td >
< p >
Creates a set with default constructed elements.
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < span class = "identifier" > S< / span > < span class = "special" > (< / span > < span class = "identifier" > e0< / span > < span class = "special" > ,< / span > < span class = "identifier" > e1< / span > < span class = "special" > ,...< / span >
< span class = "identifier" > en< / span > < span class = "special" > )< / span > < / tt >
< / p >
< / td >
< td >
< p >
Creates a set with elements < tt class = "computeroutput" > < span class = "identifier" > e0< / span > < / tt > ...< tt class = "computeroutput" > < span class = "identifier" > en< / span > < / tt > .
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < span class = "identifier" > S< / span > < span class = "special" > (< / span > < span class = "identifier" > fs< / span > < span class = "special" > )< / span > < / tt >
< / p >
< / td >
< td >
< p >
Copy constructs a set from a < a href = "../sequence/concepts/forward_sequence.html" title = "Forward
Sequence">Forward
Sequence< / a > < tt class = "computeroutput" > < span class = "identifier" > fs< / span > < / tt > .
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < span class = "identifier" > s< / span > < span class = "special" > =< / span >
< span class = "identifier" > fs< / span > < / tt >
< / p >
< / td >
< td >
< p >
Assigns to a set, < tt class = "computeroutput" > < span class = "identifier" > s< / span > < / tt > ,
from a < a href = "../sequence/concepts/forward_sequence.html" title = "Forward
Sequence">Forward
Sequence< / a > < tt class = "computeroutput" > < span class = "identifier" > fs< / span > < / tt > .
< / p >
< / td >
< / tr >
< / tbody >
< / table > < / div >
< a name = "fusion.container.set.example" > < / a > < h4 >
2007-11-07 02:12:28 +00:00
< a name = "id532617" > < / a >
2007-11-06 12:13:52 +00:00
< a href = "set.html#fusion.container.set.example" > Example< / a >
< / h4 >
< pre class = "programlisting" >
< span class = "keyword" > typedef< / span > < span class = "identifier" > set< / span > < span class = "special" > < < / span > < span class = "keyword" > int< / span > < span class = "special" > ,< / span > < span class = "keyword" > float< / span > < span class = "special" > > < / span > < span class = "identifier" > S< / span > < span class = "special" > ;< / span >
< span class = "identifier" > S< / span > < span class = "identifier" > s< / span > < span class = "special" > (< / span > < span class = "number" > 12< / span > < span class = "special" > ,< / span > < span class = "number" > 5.5f< / span > < span class = "special" > );< / span >
< span class = "identifier" > std< / span > < span class = "special" > ::< / span > < span class = "identifier" > cout< / span > < span class = "special" > < < < / span > < a href = "../sequence/intrinsic/functions/at_key.html" title = "at_key" > < tt class = "computeroutput" > < span class = "identifier" > at_key< / span > < / tt > < / a > < span class = "special" > < < / span > < span class = "keyword" > int< / span > < span class = "special" > > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span > < span class = "special" > < < < / span > < span class = "identifier" > std< / span > < span class = "special" > ::< / span > < span class = "identifier" > endl< / span > < span class = "special" > ;< / span >
< span class = "identifier" > std< / span > < span class = "special" > ::< / span > < span class = "identifier" > cout< / span > < span class = "special" > < < < / span > < a href = "../sequence/intrinsic/functions/at_key.html" title = "at_key" > < tt class = "computeroutput" > < span class = "identifier" > at_key< / span > < / tt > < / a > < span class = "special" > < < / span > < span class = "keyword" > float< / span > < span class = "special" > > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span > < span class = "special" > < < < / span > < span class = "identifier" > std< / span > < span class = "special" > ::< / span > < span class = "identifier" > endl< / span > < span class = "special" > ;< / span >
< span class = "identifier" > std< / span > < span class = "special" > ::< / span > < span class = "identifier" > cout< / span > < span class = "special" > < < < / span > < a href = "../sequence/intrinsic/metafunctions/has_key.html" title = "has_key" > < tt class = "computeroutput" > < span class = "identifier" > result_of< / span > < span class = "special" > ::< / span > < span class = "identifier" > has_key< / span > < / tt > < / a > < span class = "special" > < < / span > < span class = "identifier" > S< / span > < span class = "special" > ,< / span > < span class = "keyword" > double< / span > < span class = "special" > > ::< / span > < span class = "identifier" > value< / span > < span class = "special" > < < < / span > < span class = "identifier" > std< / span > < span class = "special" > ::< / span > < span class = "identifier" > endl< / span > < span class = "special" > ;< / span >
< / pre >
< / div >
< table xmlns:rev = "http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width = "100%" > < tr >
< td align = "left" > < / td >
2007-11-07 02:12:28 +00:00
< td align = "right" > < div class = "copyright-footer" > < small > Copyright <20> 2001-2007 Joel de Guzman, Dan Marsden, Tobias
Schwinger< p >
Distributed under the Boost Software License, Version 1.0. (See accompanying
file LICENSE_1_0.txt or copy at < a href = "http://www.boost.org/LICENSE_1_0.txt" target = "_top" > http://www.boost.org/LICENSE_1_0.txt< / a > )
< / p > < / small > < / div > < / td >
2007-11-06 12:13:52 +00:00
< / tr > < / table >
< hr >
< div class = "spirit-nav" >
< a accesskey = "p" href = "list.html" > < img src = "../../../../../../doc/html/images/prev.png" alt = "Prev" > < / a > < a accesskey = "u" href = "../container.html" > < img src = "../../../../../../doc/html/images/up.png" alt = "Up" > < / a > < a accesskey = "h" href = "../../index.html" > < img src = "../../../../../../doc/html/images/home.png" alt = "Home" > < / a > < a accesskey = "n" href = "map.html" > < img src = "../../../../../../doc/html/images/next.png" alt = "Next" > < / a >
< / div >
< / body >
< / html >