ExportProvider.GetExportedValueOrDefault<T> Method

Microsoft Silverlight will reach end of support after October 2021. Learn more.

Gets the exported object with the contract name derived from the specified type parameter or the default value for the specified type, or throws an exception if there is more than one matching exported object.

Namespace:  System.ComponentModel.Composition.Hosting
Assembly:  System.ComponentModel.Composition (in System.ComponentModel.Composition.dll)

Syntax

'Declaration
Public Function GetExportedValueOrDefault(Of T) As T
public T GetExportedValueOrDefault<T>()

Type Parameters

  • T
    The type of the exported object to return. The contract name is also derived from this type parameter.

Return Value

Type: T
The exported object with the contract name derived from T, if found; otherwise, the default value for T.

Exceptions

Exception Condition
ImportCardinalityMismatchException

There is more than one exported object with the contract name derived from T in the CompositionContainer.

ObjectDisposedException

The CompositionContainer object has been disposed of.

CompositionContractMismatchException

The underlying exported object cannot be cast to T.

CompositionException

An error occurred during composition. Errors will contain a collection of errors that occurred.

Remarks

If the exported object is not found, this method returns the appropriate default value for T; for example, zero for integer types, false for Boolean types, and nulla null reference (Nothing in Visual Basic) for reference types.

The contract name is the result of calling the GetContractName method on T.

The contract name is compared by using the Ordinal property to perform a case-sensitive, non-linguistic comparison.

Version Information

Silverlight

Supported in: 5, 4

Platforms

For a list of the operating systems and browsers that are supported by Silverlight, see Supported Operating Systems and Browsers.