Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Core / System / Linq / Parallel / Channels / SynchronousChannel.cs / 1305376 / SynchronousChannel.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== // =+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ // // SynchronousChannel.cs // //[....] // // =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=- using System.Collections.Generic; using System.Diagnostics.Contracts; namespace System.Linq.Parallel { ////// The simplest channel is one that has no synchronization. This is used for stop- /// and-go productions where we are guaranteed the consumer is not running /// concurrently. It just wraps a FIFO queue internally. /// /// Assumptions: /// Producers and consumers never try to enqueue/dequeue concurrently. /// ///internal sealed class SynchronousChannel { // We currently use the BCL FIFO queue internally, although any would do. private Queue m_queue; #if DEBUG // In debug builds, we keep track of when the producer is done (for asserts). private bool m_done; #endif //------------------------------------------------------------------------------------ // Instantiates a new queue. // internal SynchronousChannel() { } //----------------------------------------------------------------------------------- // Initializes the queue for this channel. // internal void Init() { m_queue = new Queue (); } //----------------------------------------------------------------------------------- // Enqueue a new item. // // Arguments: // item - the item to place into the queue // timeoutMilliseconds - synchronous channels never wait, so this is unused // // Assumptions: // The producer has not signaled that it's done yet. // // Return Value: // Synchronous channels always return true for this function. It can't timeout. // internal void Enqueue(T item) { Contract.Assert(m_queue != null); #if DEBUG Contract.Assert(!m_done, "trying to enqueue into the queue after production is done"); #endif m_queue.Enqueue(item); } //----------------------------------------------------------------------------------- // Dequeue the next item in the queue. // // Return Value: // The item removed from the queue. // // Assumptions: // The producer must be done producing. This queue is meant for synchronous // production/consumption, therefore it's unsafe for the consumer to try and // dequeue an item while a producer might be enqueueing one. // internal T Dequeue() { Contract.Assert(m_queue != null); #if DEBUG Contract.Assert(m_done, "trying to dequeue before production is done -- this is not safe"); #endif return m_queue.Dequeue(); } //------------------------------------------------------------------------------------ // Signals that a producer will no longer be enqueueing items. // internal void SetDone() { #if DEBUG // We only track this in DEBUG builds to aid in debugging. This ensures we // can assert dequeue-before-done and enqueue-after-done invariants above. m_done = true; #endif } //----------------------------------------------------------------------------------- // Copies the internal contents of this channel to an array. // internal void CopyTo(T[] array, int arrayIndex) { Contract.Assert(array != null); #if DEBUG Contract.Assert(m_done, "Can only copy from the channel after it's done being added to"); #endif m_queue.CopyTo(array, arrayIndex); } //------------------------------------------------------------------------------------ // Retrieves the current count of items in the queue. // internal int Count { get { Contract.Assert(m_queue != null); return m_queue.Count; } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== // =+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ // // SynchronousChannel.cs // // [....] // // =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=- using System.Collections.Generic; using System.Diagnostics.Contracts; namespace System.Linq.Parallel { ////// The simplest channel is one that has no synchronization. This is used for stop- /// and-go productions where we are guaranteed the consumer is not running /// concurrently. It just wraps a FIFO queue internally. /// /// Assumptions: /// Producers and consumers never try to enqueue/dequeue concurrently. /// ///internal sealed class SynchronousChannel { // We currently use the BCL FIFO queue internally, although any would do. private Queue m_queue; #if DEBUG // In debug builds, we keep track of when the producer is done (for asserts). private bool m_done; #endif //------------------------------------------------------------------------------------ // Instantiates a new queue. // internal SynchronousChannel() { } //----------------------------------------------------------------------------------- // Initializes the queue for this channel. // internal void Init() { m_queue = new Queue (); } //----------------------------------------------------------------------------------- // Enqueue a new item. // // Arguments: // item - the item to place into the queue // timeoutMilliseconds - synchronous channels never wait, so this is unused // // Assumptions: // The producer has not signaled that it's done yet. // // Return Value: // Synchronous channels always return true for this function. It can't timeout. // internal void Enqueue(T item) { Contract.Assert(m_queue != null); #if DEBUG Contract.Assert(!m_done, "trying to enqueue into the queue after production is done"); #endif m_queue.Enqueue(item); } //----------------------------------------------------------------------------------- // Dequeue the next item in the queue. // // Return Value: // The item removed from the queue. // // Assumptions: // The producer must be done producing. This queue is meant for synchronous // production/consumption, therefore it's unsafe for the consumer to try and // dequeue an item while a producer might be enqueueing one. // internal T Dequeue() { Contract.Assert(m_queue != null); #if DEBUG Contract.Assert(m_done, "trying to dequeue before production is done -- this is not safe"); #endif return m_queue.Dequeue(); } //------------------------------------------------------------------------------------ // Signals that a producer will no longer be enqueueing items. // internal void SetDone() { #if DEBUG // We only track this in DEBUG builds to aid in debugging. This ensures we // can assert dequeue-before-done and enqueue-after-done invariants above. m_done = true; #endif } //----------------------------------------------------------------------------------- // Copies the internal contents of this channel to an array. // internal void CopyTo(T[] array, int arrayIndex) { Contract.Assert(array != null); #if DEBUG Contract.Assert(m_done, "Can only copy from the channel after it's done being added to"); #endif m_queue.CopyTo(array, arrayIndex); } //------------------------------------------------------------------------------------ // Retrieves the current count of items in the queue. // internal int Count { get { Contract.Assert(m_queue != null); return m_queue.Count; } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- StrokeCollection.cs
- Wizard.cs
- XmlLinkedNode.cs
- TrackingMemoryStreamFactory.cs
- columnmapfactory.cs
- ValidationHelpers.cs
- FormClosedEvent.cs
- CancellationTokenRegistration.cs
- CorrelationHandle.cs
- AssemblyHash.cs
- NetworkAddressChange.cs
- SoapServerMessage.cs
- CachedFontFace.cs
- DiscardableAttribute.cs
- ActiveXSite.cs
- PropertyDescriptor.cs
- StrongTypingException.cs
- StringWriter.cs
- RoleBoolean.cs
- ValueChangedEventManager.cs
- BrowserCapabilitiesFactory.cs
- nulltextcontainer.cs
- HuffModule.cs
- ActivityXRefConverter.cs
- BrushMappingModeValidation.cs
- HtmlHead.cs
- WorkflowWebHostingModule.cs
- CodeTypeMember.cs
- _UriSyntax.cs
- AssemblyUtil.cs
- TextWriter.cs
- InputLanguage.cs
- PipelineModuleStepContainer.cs
- WorkflowMessageEventHandler.cs
- WindowsUpDown.cs
- MoveSizeWinEventHandler.cs
- ChtmlPageAdapter.cs
- SmiRecordBuffer.cs
- AssemblyHash.cs
- ListViewCancelEventArgs.cs
- WebUtil.cs
- SqlDeflator.cs
- Single.cs
- SendMailErrorEventArgs.cs
- Trace.cs
- SystemColors.cs
- StateDesigner.Layouts.cs
- FontStyle.cs
- QilStrConcat.cs
- RotateTransform3D.cs
- UrlAuthFailedErrorFormatter.cs
- ScrollEvent.cs
- ExtendedPropertyDescriptor.cs
- RSAOAEPKeyExchangeDeformatter.cs
- WmlTextViewAdapter.cs
- FileSystemWatcher.cs
- PictureBox.cs
- EmptyReadOnlyDictionaryInternal.cs
- BuildProvider.cs
- DropDownButton.cs
- HttpCapabilitiesBase.cs
- WebServiceData.cs
- CommandBindingCollection.cs
- WebPartConnectionsCloseVerb.cs
- PtsCache.cs
- Unit.cs
- TreeViewImageIndexConverter.cs
- X509Chain.cs
- OpacityConverter.cs
- StyleReferenceConverter.cs
- TimersDescriptionAttribute.cs
- TreeViewCancelEvent.cs
- CodeSubDirectory.cs
- RolePrincipal.cs
- PasswordDeriveBytes.cs
- SHA1.cs
- ProviderConnectionPoint.cs
- MouseWheelEventArgs.cs
- MasterPageBuildProvider.cs
- DataGridViewColumnHeaderCell.cs
- Types.cs
- LOSFormatter.cs
- DataColumnMapping.cs
- PathSegment.cs
- XmlDigitalSignatureProcessor.cs
- DeviceContext.cs
- XmlNodeComparer.cs
- Tool.cs
- RSAPKCS1KeyExchangeDeformatter.cs
- InternalMappingException.cs
- MarkupExtensionReturnTypeAttribute.cs
- InternalBufferOverflowException.cs
- Operand.cs
- DeviceSpecific.cs
- StaticSiteMapProvider.cs
- documentsequencetextcontainer.cs
- TextParagraphCache.cs
- DSASignatureFormatter.cs
- Pair.cs
- ExclusiveTcpListener.cs