<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> <title>MPQC: sc::ProcThreadGrp Class Reference</title> <link href="tabs.css" rel="stylesheet" type="text/css"> <link href="doxygen.css" rel="stylesheet" type="text/css"> </head><body> <!-- Generated by Doxygen 1.5.9 --> <div class="navigation" id="top"> <div class="tabs"> <ul> <li><a href="index.html"><span>Main Page</span></a></li> <li><a href="pages.html"><span>Related Pages</span></a></li> <li class="current"><a href="annotated.html"><span>Classes</span></a></li> <li><a href="files.html"><span>Files</span></a></li> </ul> </div> <div class="tabs"> <ul> <li><a href="annotated.html"><span>Class List</span></a></li> <li><a href="hierarchy.html"><span>Class Hierarchy</span></a></li> <li><a href="functions.html"><span>Class Members</span></a></li> </ul> </div> <div class="navpath"><b>sc</b>::<a class="el" href="classsc_1_1ProcThreadGrp.html">ProcThreadGrp</a> </div> </div> <div class="contents"> <h1>sc::ProcThreadGrp Class Reference</h1><!-- doxytag: class="sc::ProcThreadGrp" --><!-- doxytag: inherits="sc::ThreadGrp" -->The <a class="el" href="classsc_1_1ProcThreadGrp.html" title="The ProcThreadGrp class privides a concrete thread group appropriate for an environment...">ProcThreadGrp</a> class privides a concrete thread group appropriate for an environment where there is only one thread. <a href="#_details">More...</a> <p> <code>#include <<a class="el" href="thread_8h_source.html">thread.h</a>></code> <p> <div class="dynheader"> Inheritance diagram for sc::ProcThreadGrp:</div> <div class="dynsection"> <p><center><img src="classsc_1_1ProcThreadGrp.png" usemap="#sc::ProcThreadGrp_map" border="0" alt=""></center> <map name="sc::ProcThreadGrp_map"> <area href="classsc_1_1ThreadGrp.html" alt="sc::ThreadGrp" shape="rect" coords="0,168,120,192"> <area href="classsc_1_1DescribedClass.html" alt="sc::DescribedClass" shape="rect" coords="0,112,120,136"> <area href="classsc_1_1RefCount.html" alt="sc::RefCount" shape="rect" coords="0,56,120,80"> <area href="classsc_1_1Identity.html" alt="sc::Identity" shape="rect" coords="0,0,120,24"> </map> </div> <p> <a href="classsc_1_1ProcThreadGrp-members.html">List of all members.</a><table border="0" cellpadding="0" cellspacing="0"> <tr><td></td></tr> <tr><td colspan="2"><br><h2>Public Member Functions</h2></td></tr> <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="db2442c2dc6dd8d8564bb1dce9f5173c"></a><!-- doxytag: member="sc::ProcThreadGrp::ProcThreadGrp" ref="db2442c2dc6dd8d8564bb1dce9f5173c" args="(const Ref< KeyVal > &)" --> </td><td class="memItemRight" valign="bottom"><b>ProcThreadGrp</b> (const <a class="el" href="classsc_1_1Ref.html">Ref</a>< <a class="el" href="classsc_1_1KeyVal.html">KeyVal</a> > &)</td></tr> <tr><td class="memItemLeft" nowrap align="right" valign="top">int </td><td class="memItemRight" valign="bottom"><a class="el" href="classsc_1_1ProcThreadGrp.html#b824ceab8baf444803a5c9bc98a47bfe">start_threads</a> ()</td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">Starts the threads running. <a href="#b824ceab8baf444803a5c9bc98a47bfe"></a><br></td></tr> <tr><td class="memItemLeft" nowrap align="right" valign="top">int </td><td class="memItemRight" valign="bottom"><a class="el" href="classsc_1_1ProcThreadGrp.html#950e42bc7b760dde27e6681b977db178">wait_threads</a> ()</td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">Wait for all the threads to complete. <a href="#950e42bc7b760dde27e6681b977db178"></a><br></td></tr> <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="cc7cee6b509d839a76a81dcf7c79ca86"></a><!-- doxytag: member="sc::ProcThreadGrp::new_lock" ref="cc7cee6b509d839a76a81dcf7c79ca86" args="()" --> <a class="el" href="classsc_1_1Ref.html">Ref</a>< <a class="el" href="classsc_1_1ThreadLock.html">ThreadLock</a> > </td><td class="memItemRight" valign="bottom"><a class="el" href="classsc_1_1ProcThreadGrp.html#cc7cee6b509d839a76a81dcf7c79ca86">new_lock</a> ()</td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">Return a local object. <br></td></tr> <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="el" href="classsc_1_1ThreadGrp.html">ThreadGrp</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classsc_1_1ProcThreadGrp.html#ab10fdce9b46341d22600984f90e4a8b">clone</a> (int nthread=-1)</td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">Create a <a class="el" href="classsc_1_1ThreadGrp.html" title="The ThreadGrp abstract class provides a means to manage separate threads of control...">ThreadGrp</a> like the current one. <a href="#ab10fdce9b46341d22600984f90e4a8b"></a><br></td></tr> </table> <hr><a name="_details"></a><h2>Detailed Description</h2> The <a class="el" href="classsc_1_1ProcThreadGrp.html" title="The ProcThreadGrp class privides a concrete thread group appropriate for an environment...">ProcThreadGrp</a> class privides a concrete thread group appropriate for an environment where there is only one thread. <hr><h2>Member Function Documentation</h2> <a class="anchor" name="ab10fdce9b46341d22600984f90e4a8b"></a><!-- doxytag: member="sc::ProcThreadGrp::clone" ref="ab10fdce9b46341d22600984f90e4a8b" args="(int nthread=-1)" --> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname"><a class="el" href="classsc_1_1ThreadGrp.html">ThreadGrp</a>* sc::ProcThreadGrp::clone </td> <td>(</td> <td class="paramtype">int </td> <td class="paramname"> <em>nthread</em> = <code>-1</code> </td> <td> ) </td> <td><code> [virtual]</code></td> </tr> </table> </div> <div class="memdoc"> <p> Create a <a class="el" href="classsc_1_1ThreadGrp.html" title="The ThreadGrp abstract class provides a means to manage separate threads of control...">ThreadGrp</a> like the current one. <p> If nthread is given, the new <a class="el" href="classsc_1_1ThreadGrp.html" title="The ThreadGrp abstract class provides a means to manage separate threads of control...">ThreadGrp</a> will attempt to support that number of threads, but the actual number supported may be less. If nthread is -1, the number of threads in the current group will be used. <p>Reimplemented from <a class="el" href="classsc_1_1ThreadGrp.html#84fabb069dca43f5fe86b3595d09aecb">sc::ThreadGrp</a>.</p> </div> </div><p> <a class="anchor" name="b824ceab8baf444803a5c9bc98a47bfe"></a><!-- doxytag: member="sc::ProcThreadGrp::start_threads" ref="b824ceab8baf444803a5c9bc98a47bfe" args="()" --> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname">int sc::ProcThreadGrp::start_threads </td> <td>(</td> <td class="paramname"> </td> <td> ) </td> <td><code> [virtual]</code></td> </tr> </table> </div> <div class="memdoc"> <p> Starts the threads running. <p> <a class="el" href="classsc_1_1Thread.html" title="The Thread abstract class defines an interface which must be implemented by classes...">Thread</a> 0 will be run by the thread that calls start_threads. <p>Implements <a class="el" href="classsc_1_1ThreadGrp.html#ab79c71d061780a0c2d1545a6cc4229c">sc::ThreadGrp</a>.</p> </div> </div><p> <a class="anchor" name="950e42bc7b760dde27e6681b977db178"></a><!-- doxytag: member="sc::ProcThreadGrp::wait_threads" ref="950e42bc7b760dde27e6681b977db178" args="()" --> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname">int sc::ProcThreadGrp::wait_threads </td> <td>(</td> <td class="paramname"> </td> <td> ) </td> <td><code> [virtual]</code></td> </tr> </table> </div> <div class="memdoc"> <p> Wait for all the threads to complete. <p> This must be called before start_threads is called again or the object is destroyed. <p>Implements <a class="el" href="classsc_1_1ThreadGrp.html#c6a273d457278ad45269128c5cedd80c">sc::ThreadGrp</a>.</p> </div> </div><p> <hr>The documentation for this class was generated from the following file:<ul> <li><a class="el" href="thread_8h_source.html">thread.h</a></ul> </div> <hr> <address> <small> Generated at Wed Oct 14 14:12:16 2009 for <a href="http://www.mpqc.org">MPQC</a> 2.3.1 using the documentation package <a href="http://www.doxygen.org">Doxygen</a> 1.5.9. </small> </address> </body> </html>