function.html 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  2. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml">
  4. <head>
  5. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  6. <title>BOOST_HOF_STATIC_FUNCTION &#8212; Boost.HigherOrderFunctions 0.6 documentation</title>
  7. <link rel="stylesheet" href="../../../_static/boostbook.css" type="text/css" />
  8. <link rel="stylesheet" href="../../../_static/pygments.css" type="text/css" />
  9. <script type="text/javascript">
  10. var DOCUMENTATION_OPTIONS = {
  11. URL_ROOT: '../../../',
  12. VERSION: '0.6',
  13. COLLAPSE_INDEX: false,
  14. FILE_SUFFIX: '.html',
  15. HAS_SOURCE: true,
  16. SOURCELINK_SUFFIX: '.txt'
  17. };
  18. </script>
  19. <script type="text/javascript" src="../../../_static/jquery.js"></script>
  20. <script type="text/javascript" src="../../../_static/underscore.js"></script>
  21. <script type="text/javascript" src="../../../_static/doctools.js"></script>
  22. <link rel="index" title="Index" href="../../../genindex.html" />
  23. <link rel="search" title="Search" href="../../../search.html" />
  24. <link rel="next" title="BOOST_HOF_STATIC_LAMBDA" href="lambda.html" />
  25. <link rel="prev" title="eval" href="eval.html" />
  26. </head>
  27. <body role="document">
  28. <table cellpadding="2" width="100%"><tr>
  29. <td valign="top"><img alt="Boost C++ Libraries" width="277" height="86"src="../../../_static/boost.png"></td>
  30. </tr></table>
  31. <div class="spirit-nav">
  32. <a accesskey="p" href="eval.html"><img src="../../../_static/prev.png" alt="Prev"></a>
  33. <a accesskey="u" href="../../../doc/src/reference.html"><img src="../../../_static/up.png" alt="Up"></a>
  34. <a accesskey="h" href="../../../doc/index.html"><img src="../../../_static/home.png" alt="Home"></a>
  35. <a accesskey="n" href="lambda.html"><img src="../../../_static/next.png" alt="Next"></a>
  36. </div>
  37. <div class="document">
  38. <div class="chapter">
  39. <div class="body" role="main">
  40. <div class="section" id="boost-hof-static-function">
  41. <h1>BOOST_HOF_STATIC_FUNCTION<a class="headerlink" href="#boost-hof-static-function" title="Permalink to this headline">¶</a></h1>
  42. <div class="section" id="header">
  43. <h2>Header<a class="headerlink" href="#header" title="Permalink to this headline">¶</a></h2>
  44. <div class="highlight-cpp"><div class="highlight"><pre><span class="cp">#include</span> <span class="cpf">&lt;boost/hof/function.hpp&gt;</span><span class="cp"></span>
  45. </pre></div>
  46. </div>
  47. </div>
  48. <div class="section" id="description">
  49. <h2>Description<a class="headerlink" href="#description" title="Permalink to this headline">¶</a></h2>
  50. <p>The <code class="docutils literal"><span class="pre">BOOST_HOF_STATIC_FUNCTION</span></code> macro allows initializing a function object from a
  51. <code class="docutils literal"><span class="pre">constexpr</span></code> expression. It uses the best practices as outlined in
  52. <a class="reference external" href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2015/n4381.html">N4381</a>.
  53. This includes using <code class="docutils literal"><span class="pre">const</span></code> to avoid global state, compile-time
  54. initialization of the function object to avoid the <a class="reference external" href="https://isocpp.org/wiki/faq/ctors#static-init-order">static initialization
  55. order fiasco</a>, and an
  56. external address of the function object that is the same across translation
  57. units to avoid possible One-Definition-Rule(ODR) violations.</p>
  58. <p>In C++17, this achieved using the <code class="docutils literal"><span class="pre">inline</span></code> keyword. However, on older
  59. compilers it is initialized using a reference to a static member variable.
  60. The static member variable is default constructed, as such the user variable
  61. is always default constructed regardless of the expression.</p>
  62. <p>By default, all functions defined with <code class="docutils literal"><span class="pre">BOOST_HOF_STATIC_FUNCTION</span></code> use the
  63. <a class="reference internal" href="reveal.html"><span class="doc">reveal</span></a> adaptor to improve error messages.</p>
  64. </div>
  65. <div class="section" id="example">
  66. <h2>Example<a class="headerlink" href="#example" title="Permalink to this headline">¶</a></h2>
  67. <div class="highlight-cpp"><div class="highlight"><pre><span class="cp">#include</span> <span class="cpf">&lt;boost/hof.hpp&gt;</span><span class="cp"></span>
  68. <span class="cp">#include</span> <span class="cpf">&lt;cassert&gt;</span><span class="cp"></span>
  69. <span class="k">struct</span> <span class="n">sum_f</span>
  70. <span class="p">{</span>
  71. <span class="k">template</span><span class="o">&lt;</span><span class="k">class</span> <span class="nc">T</span><span class="p">,</span> <span class="k">class</span> <span class="nc">U</span><span class="o">&gt;</span>
  72. <span class="n">T</span> <span class="k">operator</span><span class="p">()(</span><span class="n">T</span> <span class="n">x</span><span class="p">,</span> <span class="n">U</span> <span class="n">y</span><span class="p">)</span> <span class="k">const</span>
  73. <span class="p">{</span>
  74. <span class="k">return</span> <span class="n">x</span><span class="o">+</span><span class="n">y</span><span class="p">;</span>
  75. <span class="p">}</span>
  76. <span class="p">};</span>
  77. <span class="n">BOOST_HOF_STATIC_FUNCTION</span><span class="p">(</span><span class="n">sum</span><span class="p">)</span> <span class="o">=</span> <span class="n">sum_f</span><span class="p">();</span>
  78. <span class="n">BOOST_HOF_STATIC_FUNCTION</span><span class="p">(</span><span class="n">partial_sum</span><span class="p">)</span> <span class="o">=</span> <span class="n">boost</span><span class="o">::</span><span class="n">hof</span><span class="o">::</span><span class="n">partial</span><span class="p">(</span><span class="n">sum_f</span><span class="p">());</span>
  79. <span class="kt">int</span> <span class="nf">main</span><span class="p">()</span> <span class="p">{</span>
  80. <span class="n">assert</span><span class="p">(</span><span class="n">sum</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="mi">2</span><span class="p">)</span> <span class="o">==</span> <span class="n">partial_sum</span><span class="p">(</span><span class="mi">1</span><span class="p">)(</span><span class="mi">2</span><span class="p">));</span>
  81. <span class="p">}</span>
  82. </pre></div>
  83. </div>
  84. </div>
  85. </div>
  86. </div>
  87. </div>
  88. <div class="clearer"></div>
  89. </div>
  90. <div class="footer" role="contentinfo">
  91. <table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
  92. <td align="left"></td>
  93. <td align="right"><div class="copyright-footer">
  94. &#169; Copyright 2016, Paul Fultz II.
  95. Created using <a href="http://sphinx-doc.org/">Sphinx</a> 1.5.6.
  96. <p>Distributed under the Boost Software License, Version 1.0.
  97. (See accompanying file <code class="filename">LICENSE_1_0.txt</code> or copy at
  98. <a href="http://www.boost.org/LICENSE_1_0.txt" target="_top">http://www.boost.org/LICENSE_1_0.txt</a>)
  99. </p>
  100. </div></td>
  101. </tr></table>
  102. </div>
  103. </body>
  104. </html>