Bagikan melalui


ExpressionServices.ConvertReference<TResult> Metode

Definisi

Mengonversi referensi ke ekspresi sadar lingkungan alur kerja menjadi pohon aktivitas.

public:
generic <typename TResult>
 static System::Activities::Activity<System::Activities::Location<TResult> ^> ^ ConvertReference(System::Linq::Expressions::Expression<Func<System::Activities::ActivityContext ^, TResult> ^> ^ expression);
public static System.Activities.Activity<System.Activities.Location<TResult>> ConvertReference<TResult> (System.Linq.Expressions.Expression<Func<System.Activities.ActivityContext,TResult>> expression);
static member ConvertReference : System.Linq.Expressions.Expression<Func<System.Activities.ActivityContext, 'Result>> -> System.Activities.Activity<System.Activities.Location<'Result>>
Public Shared Function ConvertReference(Of TResult) (expression As Expression(Of Func(Of ActivityContext, TResult))) As Activity(Of Location(Of TResult))

Jenis parameter

TResult

Jenis ekspresi yang sedang dikonversi.

Parameter

expression
Expression<Func<ActivityContext,TResult>>

Ekspresi sedang dikonversi.

Mengembalikan

Activity<Location<TResult>>

Ekspresi yang dikonversi.

Contoh

Dua contoh kode berikut mengilustrasikan penggunaan ConvertReference dan Convert. Contoh kode pertama menggunakan ConvertReference dalam Assign aktivitas untuk mengonversi ekspresi lambda menjadi properti string yang diberi nilai. Selanjutnya, Convert dipanggil untuk mengonversi ekspresi lambda menjadi nilai properti string yang dicetak ke konsol dalam WriteLine aktivitas.

// Define a struct with a property named AProperty.  
struct StructWithProperty  
{  
    public string AProperty { get; set; }  
}  

public static void ConvertReferenceForValueTypePropertyReferenceSample()  
{              
    // Create a variable of type StructWithProperty to store the property.  
    var swpvar = new Variable<StructWithProperty>("swpvar", new StructWithProperty());  

    Activity myActivity = new Sequence  
    {  
        Variables = { swpvar },  
        Activities =   
        {                      
            // Create an Assign activity to assign a value to the AProperty property.  
            new Assign<string>  
            {  
                To = ExpressionServices.ConvertReference<string>(ctx => swpvar.Get(ctx).AProperty),  
                // Assign a string literal to AProperty.  
                Value = "Hello",  
            },  
            // Print the new property value to the console.  
            new WriteLine()  
            {  
                Text = ExpressionServices.Convert<string>(ctx => swpvar.Get(ctx).AProperty),  
            }  
        }  
    };  

    // Invoke the Sequence activity.  
    WorkflowInvoker.Invoke(myActivity);  
}  

Contoh kode berikut seperti yang sebelumnya kecuali bahwa ekspresi yang akan dikonversi adalah referensi ke item dalam array multidimensi.

public static void ConvertReferenceForMultidimensionalArrayItemReferenceSample()  
{  
    // Create a variable to store a multidimensional array.  
    var arrayvar = new Variable<int[,]>("arrayvar", new int[4, 5]);  

    Activity myActivity = new Sequence  
    {  
        Variables = { arrayvar },  
        Activities =   
        {                      
            // Create an Assign activity to assign a value to the array item at index [1,2].  
            new Assign<int>  
            {  
                To = ExpressionServices.ConvertReference<int>(ctx => arrayvar.Get(ctx)[1, 2]),  
                // Assign an integer value to the array item at row 1 column 2.  
                Value = 1,  
            },  
            // Print the array item value to the console.  
            new WriteLine()  
            {  
                Text = ExpressionServices.Convert<string>(ctx => arrayvar.Get(ctx)[1, 2].ToString()),  
            }  
        }  
    };  

    // Invoke the Sequence activity.  
    WorkflowInvoker.Invoke(myActivity);  
}  

Keterangan

Metode konversi di ExpressionServices dirancang untuk bekerja dengan variabel dan konstanta yang ditentukan di dalam alur kerja, atau diteruskan ke alur kerja melalui argumen.

Berlaku untuk