Code:
/ 4.0 / 4.0 / untmp / 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.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- OrderedDictionary.cs
- ListViewGroup.cs
- DataControlLinkButton.cs
- SiteMapPath.cs
- Visual3D.cs
- AutomationPatternInfo.cs
- StylusButton.cs
- LoginCancelEventArgs.cs
- XmlWrappingReader.cs
- CLRBindingWorker.cs
- XmlSchemaSimpleContent.cs
- QilScopedVisitor.cs
- DependencyObjectProvider.cs
- SqlAliaser.cs
- UnmanagedMemoryStreamWrapper.cs
- BezierSegment.cs
- SmtpNetworkElement.cs
- ObsoleteAttribute.cs
- BaseResourcesBuildProvider.cs
- StorageMappingItemCollection.cs
- EntityDataSourceContainerNameConverter.cs
- StylusPlugin.cs
- ConstraintEnumerator.cs
- WindowPattern.cs
- ControlPropertyNameConverter.cs
- GuidelineSet.cs
- LiteralControl.cs
- sqlinternaltransaction.cs
- ConfigXmlComment.cs
- OleAutBinder.cs
- RpcCryptoRequest.cs
- TabletCollection.cs
- UTF8Encoding.cs
- MatrixTransform3D.cs
- XmlnsDictionary.cs
- SqlCacheDependencyDatabase.cs
- AnnotationResourceChangedEventArgs.cs
- LoadRetryStrategyFactory.cs
- NativeMethods.cs
- WebEventTraceProvider.cs
- URL.cs
- DynamicObjectAccessor.cs
- FeatureManager.cs
- ImportCatalogPart.cs
- LinearGradientBrush.cs
- PartialCachingAttribute.cs
- XamlReader.cs
- DataServiceHost.cs
- ScrollBar.cs
- Calendar.cs
- BridgeDataReader.cs
- StringInfo.cs
- ScrollData.cs
- XmlSerializationWriter.cs
- CodePageUtils.cs
- DataContractSet.cs
- OwnerDrawPropertyBag.cs
- SharedStatics.cs
- StronglyTypedResourceBuilder.cs
- MultiSelector.cs
- ObjectPersistData.cs
- StrongBox.cs
- ConfigurationFileMap.cs
- SecurityTokenValidationException.cs
- PathFigureCollection.cs
- WebBrowsableAttribute.cs
- SerializationException.cs
- precedingquery.cs
- ObjectStateEntryBaseUpdatableDataRecord.cs
- DecimalConverter.cs
- Ray3DHitTestResult.cs
- EndpointIdentityConverter.cs
- ImportStoreException.cs
- embossbitmapeffect.cs
- ContentDefinition.cs
- TreeViewItem.cs
- BooleanFunctions.cs
- SqlFacetAttribute.cs
- ExitEventArgs.cs
- EntityException.cs
- ProviderIncompatibleException.cs
- CompositeDesignerAccessibleObject.cs
- _SSPIWrapper.cs
- EdgeProfileValidation.cs
- ProfileParameter.cs
- BaseComponentEditor.cs
- ElementNotEnabledException.cs
- ToolStripPanelRenderEventArgs.cs
- EntityClassGenerator.cs
- ColumnCollection.cs
- SendOperation.cs
- AccessText.cs
- ResXResourceWriter.cs
- BamlMapTable.cs
- TemplateComponentConnector.cs
- X509CertificateCollection.cs
- ActivityPreviewDesigner.cs
- FormViewPageEventArgs.cs
- Visitor.cs
- MemberMemberBinding.cs