DynamicObject.TryInvokeMember(InvokeMemberBinder, Object[], Object) Metode
Definisi
Penting
Beberapa informasi terkait produk prarilis yang dapat diubah secara signifikan sebelum dirilis. Microsoft tidak memberikan jaminan, tersirat maupun tersurat, sehubungan dengan informasi yang diberikan di sini.
Menyediakan implementasi untuk operasi yang memanggil anggota. Kelas yang berasal dari DynamicObject kelas dapat mengambil alih metode ini untuk menentukan perilaku dinamis untuk operasi seperti memanggil metode.
public:
virtual bool TryInvokeMember(System::Dynamic::InvokeMemberBinder ^ binder, cli::array <System::Object ^> ^ args, [Runtime::InteropServices::Out] System::Object ^ % result);
public virtual bool TryInvokeMember (System.Dynamic.InvokeMemberBinder binder, object[] args, out object result);
public virtual bool TryInvokeMember (System.Dynamic.InvokeMemberBinder binder, object?[]? args, out object? result);
abstract member TryInvokeMember : System.Dynamic.InvokeMemberBinder * obj[] * obj -> bool
override this.TryInvokeMember : System.Dynamic.InvokeMemberBinder * obj[] * obj -> bool
Public Overridable Function TryInvokeMember (binder As InvokeMemberBinder, args As Object(), ByRef result As Object) As Boolean
Parameter
- binder
- InvokeMemberBinder
Menyediakan informasi tentang operasi dinamis. Properti binder.Name
memberikan nama anggota tempat operasi dinamis dilakukan. Misalnya, untuk pernyataan sampleObject.SampleMethod(100)
, di mana sampleObject
adalah instans kelas yang berasal dari DynamicObject kelas , binder.Name
mengembalikan "SampleMethod". Properti binder.IgnoreCase
menentukan apakah nama anggota peka huruf besar/kecil.
- args
- Object[]
Argumen yang diteruskan ke anggota objek selama operasi pemanggilan. Misalnya, untuk pernyataan sampleObject.SampleMethod(100)
, di mana sampleObject
berasal dari DynamicObject kelas , args[0]
sama dengan 100.
- result
- Object
Hasil pemanggilan anggota.
Mengembalikan
true
jika operasi berhasil; jika tidak, false
. Jika metode ini mengembalikan false
, pengikat run-time bahasa menentukan perilaku. (Dalam kebanyakan kasus, pengecualian run-time khusus bahasa dilemparkan.)
Contoh
Asumsikan bahwa Anda ingin memberikan sintaks alternatif untuk mengakses nilai dalam kamus, sehingga alih-alih menulis sampleDictionary["Text"] = "Sample text"
(sampleDictionary("Text") = "Sample text"
di Visual Basic), Anda dapat menulis sampleDictionary.Text = "Sample text"
. Selain itu, Anda ingin dapat memanggil semua metode kamus standar pada kamus ini.
Contoh kode berikut menunjukkan DynamicDictionary
kelas , yang berasal dari DynamicObject kelas . Kelas DynamicDictionary
berisi objek jenis Dictionary<string, object>
(Dictionary(Of String, Object)
di Visual Basic) untuk menyimpan pasangan kunci-nilai. Ini mengambil alih TryInvokeMember metode untuk mendukung metode Dictionary<TKey,TValue> kelas dan mengambil TrySetMember alih metode dan TryGetMember untuk mendukung sintaks baru. Ini juga menyediakan Print
metode, yang mencetak semua kunci dan nilai kamus.
// Add using System.Reflection;
// to the beginning of the file.
// The class derived from DynamicObject.
public class DynamicDictionary : DynamicObject
{
// The inner dictionary.
Dictionary<string, object> dictionary
= new Dictionary<string, object>();
// Getting a property.
public override bool TryGetMember(
GetMemberBinder binder, out object result)
{
return dictionary.TryGetValue(binder.Name, out result);
}
// Setting a property.
public override bool TrySetMember(
SetMemberBinder binder, object value)
{
dictionary[binder.Name] = value;
return true;
}
// Calling a method.
public override bool TryInvokeMember(
InvokeMemberBinder binder, object[] args, out object result)
{
Type dictType = typeof(Dictionary<string, object>);
try
{
result = dictType.InvokeMember(
binder.Name,
BindingFlags.InvokeMethod,
null, dictionary, args);
return true;
}
catch
{
result = null;
return false;
}
}
// This methods prints out dictionary elements.
public void Print()
{
foreach (var pair in dictionary)
Console.WriteLine(pair.Key + " " + pair.Value);
if (dictionary.Count == 0)
Console.WriteLine("No elements in the dictionary.");
}
}
class Program
{
static void Main(string[] args)
{
// Creating a dynamic dictionary.
dynamic person = new DynamicDictionary();
// Adding new dynamic properties.
// The TrySetMember method is called.
person.FirstName = "Ellen";
person.LastName = "Adams";
// Calling a method defined in the DynmaicDictionary class.
// The Print method is called.
person.Print();
Console.WriteLine(
"Removing all the elements from the dictionary.");
// Calling a method that is not defined in the DynamicDictionary class.
// The TryInvokeMember method is called.
person.Clear();
// Calling the Print method again.
person.Print();
// The following statement throws an exception at run time.
// There is no Sample method
// in the dictionary or in the DynamicDictionary class.
// person.Sample();
}
}
// This example has the following output:
// FirstName Ellen
// LastName Adams
// Removing all the elements from the dictionary.
// No elements in the dictionary.
' Add Imports System.Reflection
' to the beginning of the file.
' The class derived from DynamicObject.
Public Class DynamicDictionary
Inherits DynamicObject
' The inner dictionary.
Dim dictionary As New Dictionary(Of String, Object)
' Getting a property value.
Public Overrides Function TryGetMember(
ByVal binder As System.Dynamic.GetMemberBinder,
ByRef result As Object) As Boolean
Return dictionary.TryGetValue(binder.Name, result)
End Function
' Setting a property value.
Public Overrides Function TrySetMember(
ByVal binder As System.Dynamic.SetMemberBinder,
ByVal value As Object) As Boolean
dictionary(binder.Name) = value
Return True
End Function
' Calling a method.
Public Overrides Function TryInvokeMember(
ByVal binder As System.Dynamic.InvokeMemberBinder,
ByVal args() As Object, ByRef result As Object) As Boolean
Dim dictType As Type = GetType(Dictionary(Of String, Object))
Try
result = dictType.InvokeMember(
binder.Name,
BindingFlags.InvokeMethod,
Nothing, dictionary, args)
Return True
Catch ex As Exception
result = Nothing
Return False
End Try
End Function
' This method prints out dictionary elements.
Public Sub Print()
For Each pair In dictionary
Console.WriteLine(pair.Key & " " & pair.Value)
Next
If (dictionary.Count = 0) Then
Console.WriteLine("No elements in the dictionary.")
End If
End Sub
End Class
Sub Test()
' Creating a dynamic dictionary.
Dim person As Object = New DynamicDictionary()
' Adding new dynamic properties.
' The TrySetMember method is called.
person.FirstName = "Ellen"
person.LastName = "Adams"
' Calling a method defined in the DynmaicDictionary class.
' The Print method is called.
person.Print()
Console.WriteLine(
"Removing all the elements from the dictionary.")
' Calling a method that is not defined in the DynamicDictionary class.
' The TryInvokeMember method is called.
person.Clear()
' Calling the Print method again.
person.Print()
' The following statement throws an exception at run time.
' There is no Sample method
' in the dictionary or in the DynamicDictionary class.
' person.Sample()
End Sub
' This example has the following output:
' FirstName Ellen
' LastName Adams
' Removing all the elements from the dictionary.
' No elements in the dictionary.
Keterangan
Kelas yang berasal dari DynamicObject kelas dapat mengambil alih metode ini untuk menentukan bagaimana operasi yang memanggil anggota objek harus dilakukan untuk objek dinamis. Ketika metode tidak ditimpa, pengikat run-time bahasa menentukan perilaku. (Dalam kebanyakan kasus, pengecualian run-time khusus bahasa dilemparkan.)
Jika metode ini ditimpa, metode ini secara otomatis dipanggil ketika Anda melakukan operasi seperti sampleObject.SampleMethod(100)
, di mana sampleObject
berasal dari DynamicObject
kelas .
Anda juga dapat menambahkan metode Anda sendiri ke kelas yang berasal dari DynamicObject kelas . Misalnya, jika Anda mengambil TryInvokeMember alih metode , sistem pengiriman dinamis terlebih dahulu mencoba menentukan apakah metode yang ditentukan ada di kelas . Jika tidak menemukan metode , metode menggunakan TryInvokeMember implementasi .
Metode ini tidak mendukung ref
parameter dan out
. Semua parameter dalam args
array diteruskan oleh nilai.