View source code
							
							
						
								Display the source code in core/sync/barrier.d from which this
								page was generated on github.
							
						
							Report a bug
							
						
								If you spot a problem with this page, click here to create a
								Bugzilla issue.
							
						
							
								Improve this page
							
							
					
								Quickly fork, edit online, and submit a pull request for this page.
								Requires a signed-in GitHub account. This works well for small changes.
								If you'd like to make larger changes you may want to consider using
								local clone.
							
						Class core.sync.barrier.Barrier
This class represents a barrier across which threads may only travel in groups of a specific size.
						
				class Barrier
				;
						
					
				Constructors
| Name | Description | 
|---|---|
| this | Initializes a barrier object which releases threads in groups of limit in size. | 
Methods
| Name | Description | 
|---|---|
| wait | Wait for the pre-determined number of threads and then proceed. | 
| factory | Create instance of class specified by the fully qualified name classname. The class must either have no constructors or have a default constructor. | 
| opCmp | Compare with another Object obj. | 
| opEquals | Test whether thisis equal too.
 The default implementation only compares by identity (using theisoperator).
 Generally, overrides foropEqualsshould attempt to compare objects by their contents. | 
| toHash | Compute hash function for Object. | 
| toString | Convert Object to a human readable string. | 
Example
int  numThreads = 10;
auto barrier    = new Barrier( numThreads );
auto synInfo    = new Object;
int  numReady   = 0;
int  numPassed  = 0;
void threadFn()
{
    synchronized( synInfo )
    {
        ++numReady;
    }
    barrierAuthors
Sean Kelly
License
					Copyright © 1999-2022 by the D Language Foundation | Page generated by ddox.