2007-05-29 06:40:25 +00:00
< html >
< head >
2011-04-06 20:54:18 +00:00
< meta http-equiv = "Content-Type" content = "text/html; charset=US-ASCII" >
2009-02-12 14:01:48 +00:00
< title > Exception Safety Guarantees< / title >
2014-04-12 20:54:37 +02:00
< link rel = "stylesheet" href = "../../../../../doc/src/boostbook.css" type = "text/css" >
< meta name = "generator" content = "DocBook XSL Stylesheets V1.78.1" >
2011-04-06 20:54:18 +00:00
< link rel = "home" href = "../index.html" title = "Chapter 1. Boost.Optional" >
< link rel = "up" href = "../index.html" title = "Chapter 1. Boost.Optional" >
2009-02-12 14:01:48 +00:00
< link rel = "prev" href = "a_note_about_optional_bool_.html" title = "A note about optional<bool>" >
2007-05-29 06:40:25 +00:00
< link rel = "next" href = "type_requirements.html" title = "Type requirements" >
< / head >
< body bgcolor = "white" text = "black" link = "#0000FF" vlink = "#840084" alink = "#0000FF" >
2008-02-14 17:43:52 +00:00
< table cellpadding = "2" width = "100%" > < tr >
< td valign = "top" > < img alt = "Boost C++ Libraries" width = "277" height = "86" src = "../../../../../boost.png" > < / td >
2009-02-12 14:01:48 +00:00
< td align = "center" > < a href = "../../../../../index.html" > Home< / a > < / td >
2011-04-06 20:54:18 +00:00
< td align = "center" > < a href = "../../../../../libs/libraries.htm" > Libraries< / a > < / td >
2009-02-12 14:01:48 +00:00
< td align = "center" > < a href = "http://www.boost.org/users/people.html" > People< / a > < / td >
< td align = "center" > < a href = "http://www.boost.org/users/faq.html" > FAQ< / a > < / td >
2008-02-14 17:43:52 +00:00
< td align = "center" > < a href = "../../../../../more/index.htm" > More< / a > < / td >
< / tr > < / table >
2007-05-29 06:40:25 +00:00
< hr >
< div class = "spirit-nav" >
2011-04-06 20:54:18 +00:00
< a accesskey = "p" href = "a_note_about_optional_bool_.html" > < img src = "../../../../../doc/src/images/prev.png" alt = "Prev" > < / a > < a accesskey = "u" href = "../index.html" > < img src = "../../../../../doc/src/images/up.png" alt = "Up" > < / a > < a accesskey = "h" href = "../index.html" > < img src = "../../../../../doc/src/images/home.png" alt = "Home" > < / a > < a accesskey = "n" href = "type_requirements.html" > < img src = "../../../../../doc/src/images/next.png" alt = "Next" > < / a >
2007-05-29 06:40:25 +00:00
< / div >
2014-04-11 23:36:24 +02:00
< div class = "section" >
2007-05-29 06:40:25 +00:00
< div class = "titlepage" > < div > < div > < h2 class = "title" style = "clear: both" >
2009-02-12 14:01:48 +00:00
< a name = "boost_optional.exception_safety_guarantees" > < / a > < a class = "link" href = "exception_safety_guarantees.html" title = "Exception Safety Guarantees" > Exception Safety
2007-05-29 06:40:25 +00:00
Guarantees< / a >
< / h2 > < / div > < / div > < / div >
< p >
2009-02-12 14:01:48 +00:00
Because of the current implementation (see < a class = "link" href = "implementation_notes.html" title = "Implementation Notes" > Implementation
2007-05-29 06:40:25 +00:00
Notes< / a > ), all of the assignment methods:
< / p >
2013-02-16 19:42:42 +00:00
< div class = "itemizedlist" > < ul class = "itemizedlist" style = "list-style-type: disc; " >
2011-04-06 20:54:18 +00:00
< li class = "listitem" >
< code class = "computeroutput" > < span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > ::< / span > < span class = "keyword" > operator< / span > < span class = "special" > =< / span > < span class = "special" > (< / span > < span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > < / span > < span class = "keyword" > const< / span > < span class = "special" > & < / span > < span class = "special" > )< / span > < / code >
< / li >
< li class = "listitem" >
< code class = "computeroutput" > < span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > ::< / span > < span class = "keyword" > operator< / span > < span class = "special" > =< / span > < span class = "special" > (< / span > < span class = "identifier" > T< / span > < span class = "keyword" > const< / span > < span class = "special" > & < / span > < span class = "special" > )< / span > < / code >
< / li >
< li class = "listitem" >
< code class = "computeroutput" > < span class = "keyword" > template< / span > < span class = "special" > < < / span > < span class = "keyword" > class< / span > < span class = "identifier" > U< / span > < span class = "special" > > < / span > < span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > ::< / span > < span class = "keyword" > operator< / span > < span class = "special" > =< / span > < span class = "special" > (< / span > < span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > U< / span > < span class = "special" > > < / span > < span class = "keyword" > const< / span > < span class = "special" > & < / span > < span class = "special" > )< / span > < / code >
< / li >
< li class = "listitem" >
< code class = "computeroutput" > < span class = "keyword" > template< / span > < span class = "special" > < < / span > < span class = "keyword" > class< / span > < span class = "identifier" > InPlaceFactory< / span > < span class = "special" > > < / span > < span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > ::< / span > < span class = "keyword" > operator< / span > < span class = "special" > =< / span > < span class = "special" > (< / span > < span class = "identifier" > InPlaceFactory< / span >
< span class = "keyword" > const< / span > < span class = "special" > & < / span >
< span class = "special" > )< / span > < / code >
< / li >
< li class = "listitem" >
< code class = "computeroutput" > < span class = "keyword" > template< / span > < span class = "special" > < < / span > < span class = "keyword" > class< / span > < span class = "identifier" > TypedInPlaceFactory< / span > < span class = "special" > > < / span > < span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > ::< / span > < span class = "keyword" > operator< / span > < span class = "special" > =< / span > < span class = "special" > (< / span > < span class = "identifier" > TypedInPlaceFactory< / span >
< span class = "keyword" > const< / span > < span class = "special" > & < / span >
< span class = "special" > )< / span > < / code >
< / li >
< li class = "listitem" >
2013-02-16 19:42:42 +00:00
< code class = "computeroutput" > < span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > ::< / span > < span class = "identifier" > reset< / span > < span class = "special" > (< / span > < span class = "identifier" > T< / span > < span class = "keyword" > const< / span > < span class = "special" > & )< / span > < / code >
2011-04-06 20:54:18 +00:00
< / li >
2007-05-29 06:40:25 +00:00
< / ul > < / div >
< p >
Can only < span class = "emphasis" > < em > guarantee< / em > < / span > the < span class = "underline" > basic
exception safety< / span > : The lvalue optional is left < span class = "underline" > uninitialized< / span >
if an exception is thrown (any previous value is < span class = "emphasis" > < em > first< / em > < / span >
destroyed using < code class = "computeroutput" > < span class = "identifier" > T< / span > < span class = "special" > ::~< / span > < span class = "identifier" > T< / span > < span class = "special" > ()< / span > < / code > )
< / p >
< p >
On the other hand, the < span class = "emphasis" > < em > uninitializing< / em > < / span > methods:
< / p >
2013-02-16 19:42:42 +00:00
< div class = "itemizedlist" > < ul class = "itemizedlist" style = "list-style-type: disc; " >
2011-04-06 20:54:18 +00:00
< li class = "listitem" >
< code class = "computeroutput" > < span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > ::< / span > < span class = "keyword" > operator< / span > < span class = "special" > =< / span > < span class = "special" > (< / span > < span class = "identifier" > detail< / span > < span class = "special" > ::< / span > < span class = "identifier" > none_t< / span > < span class = "special" > )< / span > < / code >
< / li >
< li class = "listitem" >
< code class = "computeroutput" > < span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > ::< / span > < span class = "identifier" > reset< / span > < span class = "special" > ()< / span > < / code >
< / li >
2007-05-29 06:40:25 +00:00
< / ul > < / div >
< p >
Provide the no-throw guarantee (assuming a no-throw < code class = "computeroutput" > < span class = "identifier" > T< / span > < span class = "special" > ::~< / span > < span class = "identifier" > T< / span > < span class = "special" > ()< / span > < / code > )
< / p >
< p >
However, since < code class = "computeroutput" > < span class = "identifier" > optional< / span > < span class = "special" > < > < / span > < / code >
itself doesn't throw any exceptions, the only source for exceptions here are
< code class = "computeroutput" > < span class = "identifier" > T< / span > < / code > 's constructor, so if you
know the exception guarantees for < code class = "computeroutput" > < span class = "identifier" > T< / span > < span class = "special" > ::< / span > < span class = "identifier" > T< / span > < span class = "special" > (< / span >
< span class = "identifier" > T< / span > < span class = "keyword" > const< / span > < span class = "special" > & < / span > < span class = "special" > )< / span > < / code > , you
know that < code class = "computeroutput" > < span class = "identifier" > optional< / span > < / code > 's assignment
and reset has the same guarantees.
< / p >
2013-02-16 19:42:42 +00:00
< pre class = "programlisting" > < span class = "comment" > //< / span >
< span class = "comment" > // Case 1: Exception thrown during assignment.< / span >
< span class = "comment" > //< / span >
< span class = "identifier" > T< / span > < span class = "identifier" > v0< / span > < span class = "special" > (< / span > < span class = "number" > 123< / span > < span class = "special" > );< / span >
2007-05-29 06:40:25 +00:00
< span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > < / span > < span class = "identifier" > opt0< / span > < span class = "special" > (< / span > < span class = "identifier" > v0< / span > < span class = "special" > );< / span >
< span class = "keyword" > try< / span >
< span class = "special" > {< / span >
< span class = "identifier" > T< / span > < span class = "identifier" > v1< / span > < span class = "special" > (< / span > < span class = "number" > 456< / span > < span class = "special" > );< / span >
< span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > < / span > < span class = "identifier" > opt1< / span > < span class = "special" > (< / span > < span class = "identifier" > v1< / span > < span class = "special" > );< / span >
< span class = "identifier" > opt0< / span > < span class = "special" > =< / span > < span class = "identifier" > opt1< / span > < span class = "special" > ;< / span >
2013-02-16 19:42:42 +00:00
< span class = "comment" > // If no exception was thrown, assignment succeeded.< / span >
< span class = "identifier" > assert< / span > < span class = "special" > (< / span > < span class = "special" > *< / span > < span class = "identifier" > opt0< / span > < span class = "special" > ==< / span > < span class = "identifier" > v1< / span > < span class = "special" > )< / span > < span class = "special" > ;< / span >
2007-05-29 06:40:25 +00:00
< span class = "special" > }< / span >
< span class = "keyword" > catch< / span > < span class = "special" > (...)< / span >
< span class = "special" > {< / span >
2013-02-16 19:42:42 +00:00
< span class = "comment" > // If any exception was thrown, 'opt0' is reset to uninitialized.< / span >
< span class = "identifier" > assert< / span > < span class = "special" > (< / span > < span class = "special" > !< / span > < span class = "identifier" > opt0< / span > < span class = "special" > )< / span > < span class = "special" > ;< / span >
2007-05-29 06:40:25 +00:00
< span class = "special" > }< / span >
2013-02-16 19:42:42 +00:00
< span class = "comment" > //< / span >
< span class = "comment" > // Case 2: Exception thrown during reset(v)< / span >
< span class = "comment" > //< / span >
< span class = "identifier" > T< / span > < span class = "identifier" > v0< / span > < span class = "special" > (< / span > < span class = "number" > 123< / span > < span class = "special" > );< / span >
2007-05-29 06:40:25 +00:00
< span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > < / span > < span class = "identifier" > opt< / span > < span class = "special" > (< / span > < span class = "identifier" > v0< / span > < span class = "special" > );< / span >
< span class = "keyword" > try< / span >
< span class = "special" > {< / span >
< span class = "identifier" > T< / span > < span class = "identifier" > v1< / span > < span class = "special" > (< / span > < span class = "number" > 456< / span > < span class = "special" > );< / span >
< span class = "identifier" > opt< / span > < span class = "special" > .< / span > < span class = "identifier" > reset< / span > < span class = "special" > (< / span > < span class = "identifier" > v1< / span > < span class = "special" > )< / span > < span class = "special" > ;< / span >
2013-02-16 19:42:42 +00:00
< span class = "comment" > // If no exception was thrown, reset succeeded.< / span >
< span class = "identifier" > assert< / span > < span class = "special" > (< / span > < span class = "special" > *< / span > < span class = "identifier" > opt< / span > < span class = "special" > ==< / span > < span class = "identifier" > v1< / span > < span class = "special" > )< / span > < span class = "special" > ;< / span >
2007-05-29 06:40:25 +00:00
< span class = "special" > }< / span >
< span class = "keyword" > catch< / span > < span class = "special" > (...)< / span >
< span class = "special" > {< / span >
2013-02-16 19:42:42 +00:00
< span class = "comment" > // If any exception was thrown, 'opt' is reset to uninitialized.< / span >
< span class = "identifier" > assert< / span > < span class = "special" > (< / span > < span class = "special" > !< / span > < span class = "identifier" > opt< / span > < span class = "special" > )< / span > < span class = "special" > ;< / span >
2007-05-29 06:40:25 +00:00
< span class = "special" > }< / span >
< / pre >
2013-02-16 19:42:42 +00:00
< h4 >
< a name = "boost_optional.exception_safety_guarantees.h0" > < / a >
< span class = "phrase" > < a name = "boost_optional.exception_safety_guarantees.swap" > < / a > < / span > < a class = "link" href = "exception_safety_guarantees.html#boost_optional.exception_safety_guarantees.swap" > Swap< / a >
2007-05-29 06:40:25 +00:00
< / h4 >
< p >
< code class = "computeroutput" > < span class = "keyword" > void< / span > < span class = "identifier" > swap< / span > < span class = "special" > (< / span > < span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > & ,< / span >
< span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > & < / span > < span class = "special" > )< / span > < / code > has the same exception guarantee as < code class = "computeroutput" > < span class = "identifier" > swap< / span > < span class = "special" > (< / span > < span class = "identifier" > T< / span > < span class = "special" > & ,< / span > < span class = "identifier" > T< / span > < span class = "special" > & )< / span > < / code >
when both optionals are initialized. If only one of the optionals is initialized,
it gives the same < span class = "emphasis" > < em > basic< / em > < / span > exception guarantee as < code class = "computeroutput" > < span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > ::< / span > < span class = "identifier" > reset< / span > < span class = "special" > (< / span > < span class = "identifier" > T< / span > < span class = "keyword" > const< / span > < span class = "special" > & < / span > < span class = "special" > )< / span > < / code > (since
< code class = "computeroutput" > < span class = "identifier" > optional< / span > < span class = "special" > < < / span > < span class = "identifier" > T< / span > < span class = "special" > > ::< / span > < span class = "identifier" > reset< / span > < span class = "special" > ()< / span > < / code > doesn't throw). If none of the optionals
is initialized, it has no-throw guarantee since it is a no-op.
< / p >
< / div >
< table xmlns:rev = "http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width = "100%" > < tr >
< td align = "left" > < / td >
2011-04-06 20:54:18 +00:00
< td align = "right" > < div class = "copyright-footer" > Copyright © 2003-2007 Fernando Luis Cacciola Carballal< p >
2008-02-14 17:43:52 +00:00
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 >
< / div > < / td >
2007-05-29 06:40:25 +00:00
< / tr > < / table >
< hr >
< div class = "spirit-nav" >
2011-04-06 20:54:18 +00:00
< a accesskey = "p" href = "a_note_about_optional_bool_.html" > < img src = "../../../../../doc/src/images/prev.png" alt = "Prev" > < / a > < a accesskey = "u" href = "../index.html" > < img src = "../../../../../doc/src/images/up.png" alt = "Up" > < / a > < a accesskey = "h" href = "../index.html" > < img src = "../../../../../doc/src/images/home.png" alt = "Home" > < / a > < a accesskey = "n" href = "type_requirements.html" > < img src = "../../../../../doc/src/images/next.png" alt = "Next" > < / a >
2007-05-29 06:40:25 +00:00
< / div >
< / body >
< / html >