Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Core / System / Linq / Parallel / Merging / ArrayMergeHelper.cs / 1305376 / ArrayMergeHelper.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== // =+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ // // ArrayMergeHelper.cs // //[....] // // // =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=- using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Linq.Parallel; using System.Diagnostics; using System.Threading.Tasks; namespace System.Linq.Parallel { ////// A special merge helper for indexible queries. Given an indexible query, we know how many elements /// we'll have in the result set, so we can allocate the array ahead of time. Then, as each result element /// is produced, we can directly insert it into the appropriate position in the output array, paying /// no extra cost for ordering. /// ///internal class ArrayMergeHelper : IMergeHelper { private QueryResults m_queryResults; // Indexible query results private TInputOutput[] m_outputArray; // The output array. private QuerySettings m_settings; // Settings for the query. /// /// Instantiates the array merge helper. /// /// The query settings /// The query results public ArrayMergeHelper(QuerySettings settings, QueryResultsqueryResults) { m_settings = settings; m_queryResults = queryResults; int count = m_queryResults.Count; m_outputArray = new TInputOutput[count]; } /// /// A method used as a delegate passed into the ForAll operator /// private void ToArrayElement(int index) { m_outputArray[index] = m_queryResults[index]; } ////// Schedules execution of the merge itself. /// public void Execute() { ParallelQueryquery = ParallelEnumerable.Range(0, m_queryResults.Count); query = new QueryExecutionOption (QueryOperator .AsQueryOperator(query), m_settings); query.ForAll(ToArrayElement); } /// /// Gets the enumerator over the results. /// /// We never expect this method to be called. ArrayMergeHelper is intended to be used when we want /// to consume the results using GetResultsAsArray(). /// public IEnumeratorGetEnumerator() { Debug.Assert(false, "ArrayMergeHelper<>.GetEnumerator() is not intended to be used. Call GetResultsAsArray() instead."); return ((IEnumerable )GetResultsAsArray()).GetEnumerator(); } /// /// Returns the merged results as an array. /// ///public TInputOutput[] GetResultsAsArray() { Debug.Assert(m_outputArray != null); return m_outputArray; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== // =+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ // // ArrayMergeHelper.cs // // [....] // // // =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=- using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Linq.Parallel; using System.Diagnostics; using System.Threading.Tasks; namespace System.Linq.Parallel { ////// A special merge helper for indexible queries. Given an indexible query, we know how many elements /// we'll have in the result set, so we can allocate the array ahead of time. Then, as each result element /// is produced, we can directly insert it into the appropriate position in the output array, paying /// no extra cost for ordering. /// ///internal class ArrayMergeHelper : IMergeHelper { private QueryResults m_queryResults; // Indexible query results private TInputOutput[] m_outputArray; // The output array. private QuerySettings m_settings; // Settings for the query. /// /// Instantiates the array merge helper. /// /// The query settings /// The query results public ArrayMergeHelper(QuerySettings settings, QueryResultsqueryResults) { m_settings = settings; m_queryResults = queryResults; int count = m_queryResults.Count; m_outputArray = new TInputOutput[count]; } /// /// A method used as a delegate passed into the ForAll operator /// private void ToArrayElement(int index) { m_outputArray[index] = m_queryResults[index]; } ////// Schedules execution of the merge itself. /// public void Execute() { ParallelQueryquery = ParallelEnumerable.Range(0, m_queryResults.Count); query = new QueryExecutionOption (QueryOperator .AsQueryOperator(query), m_settings); query.ForAll(ToArrayElement); } /// /// Gets the enumerator over the results. /// /// We never expect this method to be called. ArrayMergeHelper is intended to be used when we want /// to consume the results using GetResultsAsArray(). /// public IEnumeratorGetEnumerator() { Debug.Assert(false, "ArrayMergeHelper<>.GetEnumerator() is not intended to be used. Call GetResultsAsArray() instead."); return ((IEnumerable )GetResultsAsArray()).GetEnumerator(); } /// /// Returns the merged results as an array. /// ///public TInputOutput[] GetResultsAsArray() { Debug.Assert(m_outputArray != null); return m_outputArray; } } } // 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
- ScriptResourceHandler.cs
- HtmlTableCell.cs
- FlowDocumentView.cs
- AsymmetricKeyExchangeFormatter.cs
- ScrollChrome.cs
- ReaderWriterLockSlim.cs
- BmpBitmapDecoder.cs
- MSAAEventDispatcher.cs
- webeventbuffer.cs
- ItemsPanelTemplate.cs
- EdmTypeAttribute.cs
- DirectionalAction.cs
- ClassicBorderDecorator.cs
- QueryExpr.cs
- XmlWrappingReader.cs
- lengthconverter.cs
- ApplicationSecurityManager.cs
- _PooledStream.cs
- DialogResultConverter.cs
- MDIClient.cs
- TableSectionStyle.cs
- CodeDirectoryCompiler.cs
- ToolStripRenderer.cs
- ProcessingInstructionAction.cs
- Label.cs
- XmlAttributeAttribute.cs
- SingleStorage.cs
- UnsafeNativeMethods.cs
- RequestCacheEntry.cs
- ManagedIStream.cs
- DataRow.cs
- SqlAggregateChecker.cs
- XmlSchemaIdentityConstraint.cs
- MessageSmuggler.cs
- OleDbConnectionInternal.cs
- LinqDataSourceView.cs
- Visitor.cs
- LicenseManager.cs
- MeasurementDCInfo.cs
- WebBrowsableAttribute.cs
- SmtpLoginAuthenticationModule.cs
- EntityParameter.cs
- LogEntrySerialization.cs
- TemplateControl.cs
- WorkflowNamespace.cs
- ImagingCache.cs
- RoleService.cs
- FacetValueContainer.cs
- Set.cs
- DirtyTextRange.cs
- categoryentry.cs
- Automation.cs
- Profiler.cs
- DataGridPagerStyle.cs
- FacetValues.cs
- ContractUtils.cs
- RawKeyboardInputReport.cs
- DataGridViewCheckBoxColumn.cs
- CacheEntry.cs
- ButtonBaseAutomationPeer.cs
- SelectedGridItemChangedEvent.cs
- FileSystemEventArgs.cs
- Formatter.cs
- DateTimePickerDesigner.cs
- WebExceptionStatus.cs
- XPathNavigatorKeyComparer.cs
- DataServiceRequestOfT.cs
- XpsFixedDocumentReaderWriter.cs
- ItemsPresenter.cs
- ObjectParameter.cs
- RtfFormatStack.cs
- ProcessInfo.cs
- SafeReadContext.cs
- FilterableAttribute.cs
- HierarchicalDataSourceControl.cs
- XmlElementAttributes.cs
- DbConnectionPoolCounters.cs
- TemplateControlCodeDomTreeGenerator.cs
- CryptographicAttribute.cs
- PropertyChangingEventArgs.cs
- BindingNavigator.cs
- ResourcePermissionBase.cs
- ZipIOModeEnforcingStream.cs
- WmlValidationSummaryAdapter.cs
- MetadataPropertyAttribute.cs
- CheckPair.cs
- LayoutEngine.cs
- BufferAllocator.cs
- FrameworkElement.cs
- GeneratedView.cs
- XmlCountingReader.cs
- GZipDecoder.cs
- webclient.cs
- HeaderedContentControl.cs
- StateItem.cs
- SafeNativeMethodsMilCoreApi.cs
- LinearGradientBrush.cs
- Parallel.cs
- ConstraintStruct.cs
- CodeDomDecompiler.cs