DynamicObject.TryInvokeMember(InvokeMemberBinder, Object[], Object) Metodo
Definizione
Importante
Alcune informazioni sono relative alla release non definitiva del prodotto, che potrebbe subire modifiche significative prima della release definitiva. Microsoft non riconosce alcuna garanzia, espressa o implicita, in merito alle informazioni qui fornite.
Fornisce l'implementazione per operazioni che richiamano un membro. Le classi derivate dalla classe DynamicObject possono eseguire l'override di questo metodo per specificare il comportamento dinamico per operazioni quale la chiamata a un metodo.
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
Parametri
- binder
- InvokeMemberBinder
Fornisce informazioni sull'operazione dinamica. La binder.Name
proprietà fornisce il nome del membro in cui viene eseguita l'operazione dinamica. Ad esempio, per l'istruzione sampleObject.SampleMethod(100)
, dove sampleObject
è un'istanza della classe derivata dalla DynamicObject classe , binder.Name
restituisce "SampleMethod". La binder.IgnoreCase
proprietà specifica se il nome del membro fa distinzione tra maiuscole e minuscole.
- args
- Object[]
Argomenti passati al membro dell'oggetto durante l'operazione invoke. Ad esempio, per l'istruzione sampleObject.SampleMethod(100)
, dove sampleObject
è derivato dalla DynamicObject classe , args[0]
è uguale a 100.
- result
- Object
Risultato della chiamata al membro.
Restituisce
true
se l'operazione riesce; in caso contrario, false
. Se questo metodo restituisce false
, il comportamento viene determinato dal gestore di associazione di runtime del linguaggio. Nella maggior parte dei casi viene generata un'eccezione di runtime specifica del linguaggio.
Esempio
Si supponga di voler fornire una sintassi alternativa per l'accesso ai valori in un dizionario, in modo che invece di scrivere sampleDictionary["Text"] = "Sample text"
(sampleDictionary("Text") = "Sample text"
in Visual Basic), è possibile scrivere sampleDictionary.Text = "Sample text"
. Inoltre, si vuole essere in grado di chiamare tutti i metodi di dizionario standard in questo dizionario.
Nell'esempio di codice seguente viene illustrata la DynamicDictionary
classe derivata dalla DynamicObject classe . La DynamicDictionary
classe contiene un oggetto del Dictionary<string, object>
tipo (Dictionary(Of String, Object)
in Visual Basic) per archiviare le coppie chiave-valore. Esegue l'override del TryInvokeMember metodo per supportare i metodi della Dictionary<TKey,TValue> classe ed esegue l'override dei TrySetMember metodi e TryGetMember per supportare la nuova sintassi. Fornisce anche un Print
metodo che stampa tutte le chiavi e i valori del dizionario.
// 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.
Commenti
Le classi derivate dalla classe possono eseguire l'override DynamicObject di questo metodo per specificare la modalità di esecuzione delle operazioni che richiamano un membro dell'oggetto per un oggetto dinamico. Quando il metodo non viene sottoposto a override, il binder di runtime del linguaggio determina il comportamento. Nella maggior parte dei casi viene generata un'eccezione di runtime specifica del linguaggio.
Se questo metodo viene sottoposto a override, viene richiamato automaticamente quando si esegue un'operazione come sampleObject.SampleMethod(100)
, dove sampleObject
deriva dalla DynamicObject
classe .
È anche possibile aggiungere metodi personalizzati alle classi derivate dalla DynamicObject classe . Ad esempio, se si esegue l'override del TryInvokeMember metodo , il sistema di invio dinamico tenta innanzitutto di determinare se il metodo specificato esiste nella classe . Se il metodo non viene trovato, viene utilizzata l'implementazione TryInvokeMember .
Questo metodo non supporta ref
i parametri e out
. Tutti i parametri nella args
matrice vengono passati per valore.