DynamicMethod Oluşturucular
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
Dinamik bir yöntem oluşturur.
Aşırı Yüklemeler
DynamicMethod(String, Type, Type[]) |
Anonim olarak barındırılan bir dinamik yöntem başlatır ve yöntem adını, dönüş türünü ve parametre türlerini belirtir. |
DynamicMethod(String, Type, Type[], Boolean) |
Yöntem adını, dönüş türünü, parametre türlerini ve dinamik yöntemin Microsoft ara dili (MSIL) tarafından erişilen türler ve üyeler için tam zamanında (JIT) görünürlük denetimlerinin atlanıp atlanmayacağını belirterek anonim olarak barındırılan bir dinamik yöntemi başlatır. |
DynamicMethod(String, Type, Type[], Module) |
Yöntem adını, dönüş türünü, parametre türlerini ve modülü belirterek bir modül için genel olan dinamik bir yöntem oluşturur. |
DynamicMethod(String, Type, Type[], Type) |
Yöntem adını, dönüş türünü, parametre türlerini ve dinamik yöntemin mantıksal olarak ilişkilendirildiği türü belirterek dinamik bir yöntem oluşturur. |
DynamicMethod(String, Type, Type[], Module, Boolean) |
Yöntem adını, dönüş türünü, parametre türlerini, modülü ve dinamik yöntemin Microsoft ara dili (MSIL) tarafından erişilen türler ve üyeler için tam zamanında (JIT) görünürlük denetimlerinin atlanıp atlanmayacağını belirterek bir modül için genel olan dinamik bir yöntem oluşturur. |
DynamicMethod(String, Type, Type[], Type, Boolean) |
Yöntem adını, dönüş türünü, parametre türlerini, dinamik yöntemin mantıksal olarak ilişkilendirildiği türü ve dinamik yöntemin Microsoft ara dili (MSIL) tarafından erişilen türler ve üyeler için tam zamanında (JIT) görünürlük denetimlerinin atlanıp atlanmayacağını belirten dinamik bir yöntem oluşturur. |
DynamicMethod(String, MethodAttributes, CallingConventions, Type, Type[], Module, Boolean) |
Yöntem adını, özniteliklerini, çağırma kuralını, dönüş türünü, parametre türlerini, modülünü ve dinamik yöntemin Microsoft ara dili (MSIL) tarafından erişilen türler ve üyeler için tam zamanında (JIT) görünürlük denetimlerinin atlanıp atlanmayacağını belirterek bir modül için genel olan dinamik bir yöntem oluşturur. |
DynamicMethod(String, MethodAttributes, CallingConventions, Type, Type[], Type, Boolean) |
Yöntem adını, özniteliklerini, çağırma kuralını, dönüş türünü, parametre türlerini, dinamik yöntemin mantıksal olarak ilişkilendirildiği türü ve dinamik yöntemin Microsoft ara dili (MSIL) tarafından erişilen türler ve üyeler için tam zamanında (JIT) görünürlük denetimlerinin atlanıp atlanmayacağını belirten dinamik bir yöntem oluşturur. |
DynamicMethod(String, Type, Type[])
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
Anonim olarak barındırılan bir dinamik yöntem başlatır ve yöntem adını, dönüş türünü ve parametre türlerini belirtir.
public:
DynamicMethod(System::String ^ name, Type ^ returnType, cli::array <Type ^> ^ parameterTypes);
public DynamicMethod (string name, Type? returnType, Type[]? parameterTypes);
public DynamicMethod (string name, Type returnType, Type[] parameterTypes);
new System.Reflection.Emit.DynamicMethod : string * Type * Type[] -> System.Reflection.Emit.DynamicMethod
Public Sub New (name As String, returnType As Type, parameterTypes As Type())
Parametreler
- name
- String
Dinamik yöntemin adı. Bu sıfır uzunluklu bir dize olabilir, ancak olamaz null
.
- returnType
- Type
Type Dinamik yöntemin dönüş türünü belirten veya null
yöntemin dönüş türü olmayan bir nesne.
- parameterTypes
- Type[]
Dinamik yöntemin Type parametrelerinin türlerini belirten bir nesne dizisi veya null
yöntemin parametresi yoksa.
Özel durumlar
öğesinin parameterTypes
veya öğesidirVoidnull
.
name
, null
değeridir.
.NET Framework ve 2.1'den eski .NET Core sürümleri: returnType
döndüren IsByReftrue
bir türdür.
Açıklamalar
Bu oluşturucu tarafından oluşturulan dinamik yöntem, mevcut bir tür veya modül yerine anonim bir derlemeyle ilişkilendirilir. Anonim derleme yalnızca dinamik yöntemler için bir korumalı alan ortamı sağlamak, yani bunları diğer kodlardan yalıtmak için vardır. Bu ortam, dinamik yöntemin kısmen güvenilen kod tarafından dağıtılıp yürütülmesini güvenli hale getirir.
Bu oluşturucu, dinamik yöntemin Microsoft ara dili (MSIL) için tam zamanında (JIT) görünürlük denetimlerinin zorunlu kılınacağını belirtir. Yani dinamik yöntemdeki kodun ortak sınıf yöntemlerine erişimi vardır. Yöntem , protected
veya internal
(Friend
Visual Basic'te) olan türlere veya üyelere private
erişmeye çalışırsa özel durumlar oluşur. JIT görünürlük denetimlerini atlamayı kısıtlayan bir dinamik yöntem oluşturmak için oluşturucuyu DynamicMethod(String, Type, Type[], Boolean) kullanın.
Anonim olarak barındırılan bir dinamik yöntem oluşturulduğunda, yayma derlemesinin çağrı yığını dahil edilir. yöntemi çağrıldığında, gerçek çağıranın izinleri yerine yayan derlemenin izinleri kullanılır. Bu nedenle, dinamik yöntem, daha yüksek bir güven düzeyine sahip bir derlemeye geçirilse ve yürütülse bile, onu gösteren derlemeden daha yüksek bir ayrıcalık düzeyinde yürütülemez.
Bu oluşturucu yöntem özniteliklerini MethodAttributes.Public ve MethodAttributes.Staticve çağırma kuralını CallingConventions.Standardbelirtir.
Not
Bu oluşturucu .NET Framework 3.5 veya sonraki sürümlerde tanıtıldı.
Ayrıca bkz.
- Nasıl yapılır: Dinamik Yöntemleri Tanımlama ve Yürütme
- Yansıma Yaymadaki Güvenlik Sorunları
- İzlenecek yol: Kısmi Güven Senaryolarında Kod Yayma
Şunlara uygulanır
DynamicMethod(String, Type, Type[], Boolean)
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
Yöntem adını, dönüş türünü, parametre türlerini ve dinamik yöntemin Microsoft ara dili (MSIL) tarafından erişilen türler ve üyeler için tam zamanında (JIT) görünürlük denetimlerinin atlanıp atlanmayacağını belirterek anonim olarak barındırılan bir dinamik yöntemi başlatır.
public:
DynamicMethod(System::String ^ name, Type ^ returnType, cli::array <Type ^> ^ parameterTypes, bool restrictedSkipVisibility);
public DynamicMethod (string name, Type? returnType, Type[]? parameterTypes, bool restrictedSkipVisibility);
public DynamicMethod (string name, Type returnType, Type[] parameterTypes, bool restrictedSkipVisibility);
new System.Reflection.Emit.DynamicMethod : string * Type * Type[] * bool -> System.Reflection.Emit.DynamicMethod
Public Sub New (name As String, returnType As Type, parameterTypes As Type(), restrictedSkipVisibility As Boolean)
Parametreler
- name
- String
Dinamik yöntemin adı. Bu sıfır uzunluklu bir dize olabilir, ancak olamaz null
.
- returnType
- Type
Type Dinamik yöntemin dönüş türünü belirten veya null
yöntemin dönüş türü olmayan bir nesne.
- parameterTypes
- Type[]
Dinamik yöntemin Type parametrelerinin türlerini belirten bir nesne dizisi veya null
yöntemin parametresi yoksa.
- restrictedSkipVisibility
- Boolean
true
dinamik yöntemin MSIL'i tarafından erişilen türler ve üyeler üzerinde JIT görünürlüğü denetimlerini atlamak için, bu kısıtlamayla: bu türleri ve üyeleri içeren derlemelerin güven düzeyi, dinamik yöntemi yayan çağrı yığınının güven düzeyine eşit veya ondan küçük olmalıdır; aksi takdirde , false
.
Özel durumlar
öğesinin parameterTypes
veya öğesidirVoidnull
.
name
, null
değeridir.
.NET Framework ve 2.1'den eski .NET Core sürümleri: returnType
döndüren IsByReftrue
bir türdür.
Açıklamalar
Bu oluşturucu tarafından oluşturulan dinamik yöntem, mevcut bir tür veya modül yerine anonim bir derlemeyle ilişkilendirilir. Anonim derleme yalnızca dinamik yöntemler için bir korumalı alan ortamı sağlamak, yani bunları diğer kodlardan yalıtmak için vardır. Bu ortam, dinamik yöntemin kısmen güvenilen kod tarafından dağıtılıp yürütülmesini güvenli hale getirir.
Anonim olarak barındırılan dinamik yöntemlerin, Visual Basic'te , protected
veya (Friend
olan hiçbir türe veya internal
üyeye private
otomatik erişimi yoktur. Bu, ilişkili kapsamlarındaki gizli üyelere erişimi olan mevcut bir tür veya modülle ilişkili dinamik yöntemlerden farklıdır.
restrictedSkipVisibility
Dinamik yönteminizin , protected
veya internal
olan türlere veya üyelere erişmesi gerekip gerekmediğini private
belirtintrue
. Bu, dinamik yönteme bu üyelere erişimi kısıtlar. Yani, üyelere yalnızca aşağıdaki koşullar karşılandığında erişilebilir:
Hedef üyeler, dinamik yöntemi yayan çağrı yığınına eşit veya daha düşük bir güven düzeyine sahip bir derlemeye aittir.
Dinamik yöntemi yayan çağrı yığını bayrağıyla verilir ReflectionPermissionReflectionPermissionFlag.RestrictedMemberAccess . Kod tam güvenle yürütülürken bu her zaman geçerlidir. Kısmen güvenilen kod için, yalnızca konak açıkça izin verirse doğrudur.
Önemli
İzin verilmediyse, bu oluşturucu çağrıldığında değil, çağrıldığında CreateDelegate veya dinamik yöntem çağrıldığında bir güvenlik özel durumu oluşturulur. Dinamik yöntemi yaymak için özel izin gerekmez.
Örneğin, çağrısı yığınına true
kısıtlı üye erişimi verildiyse, ile oluşturulan restrictedSkipVisibility
dinamik bir yöntem çağrı yığınındaki herhangi bir derlemenin özel üyesine erişebilir. Dinamik yöntem çağrı yığınında kısmen güvenilen kodla oluşturulduysa, .NET Framework derlemedeki bir türün özel üyesine erişemez, çünkü bu tür derlemeler tam olarak güvenilirdir.
ise restrictedSkipVisibility
false
, JIT görünürlük denetimleri zorlanır. Dinamik yöntemdeki kodun ortak sınıf yöntemlerine erişimi vardır ve , protected
veya internal
olan türlere veya üyelere private
erişmeye çalışırsa özel durumlar oluşturulur.
Anonim olarak barındırılan bir dinamik yöntem oluşturulduğunda, yayma derlemesinin çağrı yığını dahil edilir. yöntemi çağrıldığında, gerçek çağıranın izinleri yerine yayan çağrı yığınının izinleri kullanılır. Bu nedenle, dinamik yöntem, daha yüksek bir güven düzeyine sahip bir derlemeye geçirilse ve yürütülse bile, onu gösteren derlemeden daha yüksek bir ayrıcalık düzeyinde yürütülemez.
Bu oluşturucu yöntem özniteliklerini MethodAttributes.Public ve MethodAttributes.Staticve çağırma kuralını CallingConventions.Standardbelirtir.
Not
Bu oluşturucu .NET Framework 3.5 veya sonraki sürümlerde tanıtıldı.
Ayrıca bkz.
- Nasıl yapılır: Dinamik Yöntemleri Tanımlama ve Yürütme
- Yansıma Yaymadaki Güvenlik Sorunları
- İzlenecek yol: Kısmi Güven Senaryolarında Kod Yayma
Şunlara uygulanır
DynamicMethod(String, Type, Type[], Module)
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
Yöntem adını, dönüş türünü, parametre türlerini ve modülü belirterek bir modül için genel olan dinamik bir yöntem oluşturur.
public:
DynamicMethod(System::String ^ name, Type ^ returnType, cli::array <Type ^> ^ parameterTypes, System::Reflection::Module ^ m);
public DynamicMethod (string name, Type? returnType, Type[]? parameterTypes, System.Reflection.Module m);
public DynamicMethod (string name, Type returnType, Type[] parameterTypes, System.Reflection.Module m);
new System.Reflection.Emit.DynamicMethod : string * Type * Type[] * System.Reflection.Module -> System.Reflection.Emit.DynamicMethod
Public Sub New (name As String, returnType As Type, parameterTypes As Type(), m As Module)
Parametreler
- name
- String
Dinamik yöntemin adı. Bu sıfır uzunluklu bir dize olabilir, ancak olamaz null
.
- returnType
- Type
Type Dinamik yöntemin dönüş türünü belirten veya null
yöntemin dönüş türü olmayan bir nesne.
- parameterTypes
- Type[]
Dinamik yöntemin Type parametrelerinin türlerini belirten bir nesne dizisi veya null
yöntemin parametresi yoksa.
Özel durumlar
öğesinin parameterTypes
veya öğesidirVoidnull
.
-veya-
m
, dinamik yöntemler için anonim barındırma sağlayan bir modüldür.
.NET Framework ve 2.1'den eski .NET Core sürümleri: returnType
döndüren IsByReftrue
bir türdür.
Örnekler
Aşağıdaki kod örneği, iki parametre alan dinamik bir yöntem oluşturur. Örnek, ilk parametreyi konsola yazdıran basit bir işlev gövdesi yayar ve örnek, ikinci parametreyi yöntemin dönüş değeri olarak kullanır. Örnek, bir temsilci oluşturarak yöntemini tamamlar, temsilciyi farklı parametrelerle çağırır ve son olarak yöntemini kullanarak Invoke(Object, BindingFlags, Binder, Object[], CultureInfo) dinamik yöntemi çağırır.
using namespace System;
using namespace System::Reflection;
using namespace System::Reflection::Emit;
public ref class Test
{
};
// Declare a delegate that will be used to execute the completed
// dynamic method.
delegate int HelloInvoker(String^ msg, int ret);
int main()
{
// Create an array that specifies the types of the parameters
// of the dynamic method. This method has a string parameter
// and an int parameter.
array<Type^>^ helloArgs = {String::typeid, int::typeid};
// Create a dynamic method with the name "Hello", a return type
// of int, and two parameters whose types are specified by the
// array helloArgs. Create the method in the module that
// defines the Test class.
DynamicMethod^ hello = gcnew DynamicMethod("Hello",
int::typeid,
helloArgs,
Test::typeid->Module);
// Create an array that specifies the parameter types of the
// overload of Console.WriteLine to be used in Hello.
array<Type^>^ writeStringArgs = {String::typeid};
// Get the overload of Console.WriteLine that has one
// String parameter.
MethodInfo^ writeString =
Console::typeid->GetMethod("WriteLine", writeStringArgs);
// Get an ILGenerator and emit a body for the dynamic method.
ILGenerator^ ilgen = hello->GetILGenerator();
// Load the first argument, which is a string, onto the stack.
ilgen->Emit(OpCodes::Ldarg_0);
// Call the overload of Console.WriteLine that prints a string.
ilgen->EmitCall(OpCodes::Call, writeString, nullptr);
// The Hello method returns the value of the second argument;
// to do this, load the onto the stack and return.
ilgen->Emit(OpCodes::Ldarg_1);
ilgen->Emit(OpCodes::Ret);
// Create a delegate that represents the dynamic method. This
// action completes the method, and any further attempts to
// change the method will cause an exception.
HelloInvoker^ helloDelegate =
(HelloInvoker^) hello->CreateDelegate(HelloInvoker::typeid);
// Use the delegate to execute the dynamic method. Save and
// print the return value.
int returnValue = helloDelegate("\r\nHello, World!", 42);
Console::WriteLine("helloDelegate(\"Hello, World!\", 42) returned {0}",
returnValue);
// Do it again, with different arguments.
returnValue = helloDelegate("\r\nHi, Mom!", 5280);
Console::WriteLine("helloDelegate(\"Hi, Mom!\", 5280) returned {0}",
returnValue);
// Create an array of arguments to use with the Invoke method.
array<Object^>^ delegateArgs = {"\r\nHello, World!", 42};
// Invoke the dynamic method using the arguments. This is much
// slower than using the delegate, because you must create an
// array to contain the arguments, and ValueType arguments
// must be boxed.
Object^ returnValueObject = hello->Invoke(nullptr, delegateArgs);
Console::WriteLine("hello.Invoke returned {0}", returnValueObject);
}
using System;
using System.Reflection;
using System.Reflection.Emit;
using Microsoft.VisualBasic;
public class Test
{
// Declare a delegate that will be used to execute the completed
// dynamic method.
private delegate int HelloInvoker(string msg, int ret);
public static void Main()
{
// Create an array that specifies the types of the parameters
// of the dynamic method. This method has a string parameter
// and an int parameter.
Type[] helloArgs = {typeof(string), typeof(int)};
// Create a dynamic method with the name "Hello", a return type
// of int, and two parameters whose types are specified by the
// array helloArgs. Create the method in the module that
// defines the Test class.
DynamicMethod hello = new DynamicMethod("Hello",
typeof(int),
helloArgs,
typeof(Test).Module);
// Create an array that specifies the parameter types of the
// overload of Console.WriteLine to be used in Hello.
Type[] writeStringArgs = {typeof(string)};
// Get the overload of Console.WriteLine that has one
// String parameter.
MethodInfo writeString =
typeof(Console).GetMethod("WriteLine", writeStringArgs);
// Get an ILGenerator and emit a body for the dynamic method.
ILGenerator il = hello.GetILGenerator();
// Load the first argument, which is a string, onto the stack.
il.Emit(OpCodes.Ldarg_0);
// Call the overload of Console.WriteLine that prints a string.
il.EmitCall(OpCodes.Call, writeString, null);
// The Hello method returns the value of the second argument;
// to do this, load the onto the stack and return.
il.Emit(OpCodes.Ldarg_1);
il.Emit(OpCodes.Ret);
// Create a delegate that represents the dynamic method. This
// action completes the method, and any further attempts to
// change the method will cause an exception.
HelloInvoker hi =
(HelloInvoker) hello.CreateDelegate(typeof(HelloInvoker));
// Use the delegate to execute the dynamic method. Save and
// print the return value.
int retval = hi("\r\nHello, World!", 42);
Console.WriteLine("Executing delegate hi(\"Hello, World!\", 42) returned {0}",
retval);
// Do it again, with different arguments.
retval = hi("\r\nHi, Mom!", 5280);
Console.WriteLine("Executing delegate hi(\"Hi, Mom!\", 5280) returned {0}",
retval);
// Create an array of arguments to use with the Invoke method.
object[] invokeArgs = {"\r\nHello, World!", 42};
// Invoke the dynamic method using the arguments. This is much
// slower than using the delegate, because you must create an
// array to contain the arguments, and ValueType arguments
// must be boxed.
object objRet = hello.Invoke(null, invokeArgs);
Console.WriteLine("hello.Invoke returned {0}", objRet);
}
}
Imports System.Reflection
Imports System.Reflection.Emit
Public Class Test
' Declare a delegate that will be used to execute the completed
' dynamic method.
Private Delegate Function HelloInvoker(ByVal msg As String, _
ByVal ret As Integer) As Integer
Public Shared Sub Main()
' Create an array that specifies the types of the parameters
' of the dynamic method. This method has a String parameter
' and an Integer parameter.
Dim helloArgs() As Type = {GetType(String), GetType(Integer)}
' Create a dynamic method with the name "Hello", a return type
' of Integer, and two parameters whose types are specified by
' the array helloArgs. Create the method in the module that
' defines the Test class.
Dim hello As New DynamicMethod("Hello", _
GetType(Integer), _
helloArgs, _
GetType(Test).Module)
' Create an array that specifies the parameter types of the
' overload of Console.WriteLine to be used in Hello.
Dim writeStringArgs() As Type = {GetType(String)}
' Get the overload of Console.WriteLine that has one
' String parameter.
Dim writeString As MethodInfo = GetType(Console). _
GetMethod("WriteLine", writeStringArgs)
' Get an ILGenerator and emit a body for the dynamic method.
Dim il As ILGenerator = hello.GetILGenerator()
' Load the first argument, which is a string, onto the stack.
il.Emit(OpCodes.Ldarg_0)
' Call the overload of Console.WriteLine that prints a string.
il.EmitCall(OpCodes.Call, writeString, Nothing)
' The Hello method returns the value of the second argument;
' to do this, load the onto the stack and return.
il.Emit(OpCodes.Ldarg_1)
il.Emit(OpCodes.Ret)
' Create a delegate that represents the dynamic method. This
' action completes the method, and any further attempts to
' change the method will cause an exception.
Dim hi As HelloInvoker = _
hello.CreateDelegate(GetType(HelloInvoker))
' Use the delegate to execute the dynamic method. Save and
' print the return value.
Dim retval As Integer = hi(vbCrLf & "Hello, World!", 42)
Console.WriteLine("Executing delegate hi(""Hello, World!"", 42) returned " _
& retval)
' Do it again, with different arguments.
retval = hi(vbCrLf & "Hi, Mom!", 5280)
Console.WriteLine("Executing delegate hi(""Hi, Mom!"", 5280) returned " _
& retval)
' Create an array of arguments to use with the Invoke method.
Dim invokeArgs() As Object = {vbCrLf & "Hello, World!", 42}
' Invoke the dynamic method using the arguments. This is much
' slower than using the delegate, because you must create an
' array to contain the arguments, and ValueType arguments
' must be boxed. Note that this overload of Invoke is
' inherited from MethodBase, and simply calls the more
' complete overload of Invoke.
Dim objRet As Object = hello.Invoke(Nothing, invokeArgs)
Console.WriteLine("hello.Invoke returned " & objRet)
End Sub
End Class
' This code example produces the following output:
'
'Hello, World!
'Executing delegate hi("Hello, World!", 42) returned 42
'
'Hi, Mom!
'Executing delegate hi("Hi, Mom!", 5280) returned 5280
'
'Hello, World!
'hello.Invoke returned 42
'
Açıklamalar
Bu oluşturucu yöntem özniteliklerini MethodAttributes.Public ve MethodAttributes.Static, çağırma kuralını CallingConventions.Standardbelirtir ve tam zamanında (JIT) görünürlük denetimlerini atlamaz.
Bu oluşturucuyla oluşturulan dinamik yöntemin, modülünde m
yer alan tüm türlerin public ve internal
(Friend
Visual Basic'te) üyelerine erişimi vardır.
Not
Geriye dönük uyumluluk için bu oluşturucu, aşağıdaki koşulların SecurityPermissionFlag.ControlEvidence her ikisi de doğruysa bayrağını talep SecurityPermission eder: m
çağıran modül dışında bir modüldür ve ReflectionPermission bayrağıyla talebi ReflectionPermissionFlag.MemberAccess başarısız olmuştur. Talebin SecurityPermission başarılı olması durumunda işleme izin verilir.
Ayrıca bkz.
Şunlara uygulanır
DynamicMethod(String, Type, Type[], Type)
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
Yöntem adını, dönüş türünü, parametre türlerini ve dinamik yöntemin mantıksal olarak ilişkilendirildiği türü belirterek dinamik bir yöntem oluşturur.
public:
DynamicMethod(System::String ^ name, Type ^ returnType, cli::array <Type ^> ^ parameterTypes, Type ^ owner);
public DynamicMethod (string name, Type? returnType, Type[]? parameterTypes, Type owner);
public DynamicMethod (string name, Type returnType, Type[] parameterTypes, Type owner);
new System.Reflection.Emit.DynamicMethod : string * Type * Type[] * Type -> System.Reflection.Emit.DynamicMethod
Public Sub New (name As String, returnType As Type, parameterTypes As Type(), owner As Type)
Parametreler
- name
- String
Dinamik yöntemin adı. Bu sıfır uzunluklu bir dize olabilir, ancak olamaz null
.
- returnType
- Type
Type Dinamik yöntemin dönüş türünü belirten veya null
yöntemin dönüş türü olmayan bir nesne.
- parameterTypes
- Type[]
Dinamik yöntemin Type parametrelerinin türlerini belirten bir nesne dizisi veya null
yöntemin parametresi yoksa.
- owner
- Type
Type Dinamik yöntemin mantıksal olarak ilişkilendirildiği bir. Dinamik yöntemin türün tüm üyelerine erişimi vardır.
Özel durumlar
öğesinin parameterTypes
veya öğesidirVoidnull
.
-veya-
owner
bir arabirim, dizi, açık bir genel tür veya genel tür veya yöntemin tür parametresidir.
.NET Framework ve 2.1'den eski .NET Core sürümleri: returnType
döndüren IsByReftrue
bir türdür.
Örnekler
Aşağıdaki kod örneği, bir DynamicMethod türle mantıksal olarak ilişkili bir oluşturur. Bu ilişkilendirme, söz konusu türün özel üyelerine erişim verir.
Kod örneği, özel alanı olan adlı Example
bir sınıfı, birinci sınıftan türetilen adlı DerivedFromExample
sınıfı, ve türünde Int32Example
parametreleri döndüren Int32 ve içeren adlı UseLikeStatic
bir temsilci türünü ve döndüren Int32 ve türünde bir parametresi olan adlı UseLikeInstance
bir temsilci türünü Int32tanımlar.
Örnek kod daha sonra bir DynamicMethod örneğinin Example
özel alanını değiştiren ve önceki değeri döndüren bir oluşturur.
Not
Genel olarak, sınıfların iç alanlarını değiştirmek nesne odaklı kodlama uygulaması için iyi değildir.
Örnek kod bir örneği Example
oluşturur ve ardından iki temsilci oluşturur. birincisi, dinamik yöntemle aynı parametrelere sahip olan türündedir UseLikeStatic
. İkincisi, ilk parametreyi (türünde UseLikeInstance
) eksik olan türündedir Example
. Bu temsilci yöntem aşırı yüklemesi kullanılarak CreateDelegate(Type, Object) oluşturulur; bu yöntem aşırı yüklemesinin ikinci parametresi, yeni oluşturulan temsilciye bağlı olan yeni oluşturulan örneğin bir örneğidir Example
. Bu temsilci her çağrıldığında, dinamik yöntem bağlı örneği Example
üzerinde hareket eder.
Not
Bu, .NET Framework 2.0'da tanıtılan temsilci bağlaması için gevşek kuralların ve yöntemin Delegate.CreateDelegate yeni aşırı yüklemelerinin bir örneğidir. Daha fazla bilgi için sınıfına Delegate bakın.
Temsilci UseLikeStatic
çağrılır Example
ve örneğinin temsilciye UseLikeInstance
bağlı olduğu geçirilir.
UseLikeInstance
Ardından temsilci çağrılır, böylece her iki temsilci de aynı örneği Example
üzerinde hareket eder. İç alanın değerlerindeki değişiklikler her çağrıdan sonra görüntülenir. Son olarak, bir UseLikeInstance
temsilci bir DerivedFromExample
örneğine bağlıdır ve temsilci çağrıları yinelenir.
using System;
using System.Reflection;
using System.Reflection.Emit;
// These classes are for demonstration purposes.
//
public class Example
{
private int id = 0;
public Example(int id)
{
this.id = id;
}
public int ID { get { return id; }}
}
public class DerivedFromExample : Example
{
public DerivedFromExample(int id) : base(id) {}
}
// Two delegates are declared: UseLikeInstance treats the dynamic
// method as if it were an instance method, and UseLikeStatic
// treats the dynamic method in the ordinary fashion.
//
public delegate int UseLikeInstance(int newID);
public delegate int UseLikeStatic(Example ex, int newID);
public class Demo
{
public static void Main()
{
// This dynamic method changes the private id field. It has
// no name; it returns the old id value (return type int);
// it takes two parameters, an instance of Example and
// an int that is the new value of id; and it is declared
// with Example as the owner type, so it can access all
// members, public and private.
//
DynamicMethod changeID = new DynamicMethod(
"",
typeof(int),
new Type[] { typeof(Example), typeof(int) },
typeof(Example)
);
// Get a FieldInfo for the private field 'id'.
FieldInfo fid = typeof(Example).GetField(
"id",
BindingFlags.NonPublic | BindingFlags.Instance
);
ILGenerator ilg = changeID.GetILGenerator();
// Push the current value of the id field onto the
// evaluation stack. It's an instance field, so load the
// instance of Example before accessing the field.
ilg.Emit(OpCodes.Ldarg_0);
ilg.Emit(OpCodes.Ldfld, fid);
// Load the instance of Example again, load the new value
// of id, and store the new field value.
ilg.Emit(OpCodes.Ldarg_0);
ilg.Emit(OpCodes.Ldarg_1);
ilg.Emit(OpCodes.Stfld, fid);
// The original value of the id field is now the only
// thing on the stack, so return from the call.
ilg.Emit(OpCodes.Ret);
// Create a delegate that uses changeID in the ordinary
// way, as a static method that takes an instance of
// Example and an int.
//
UseLikeStatic uls =
(UseLikeStatic) changeID.CreateDelegate(
typeof(UseLikeStatic)
);
// Create an instance of Example with an id of 42.
//
Example ex = new Example(42);
// Create a delegate that is bound to the instance of
// of Example. This is possible because the first
// parameter of changeID is of type Example. The
// delegate has all the parameters of changeID except
// the first.
UseLikeInstance uli =
(UseLikeInstance) changeID.CreateDelegate(
typeof(UseLikeInstance),
ex
);
// First, change the value of id by calling changeID as
// a static method, passing in the instance of Example.
//
Console.WriteLine(
"Change the value of id; previous value: {0}",
uls(ex, 1492)
);
// Change the value of id again using the delegate bound
// to the instance of Example.
//
Console.WriteLine(
"Change the value of id; previous value: {0}",
uli(2700)
);
Console.WriteLine("Final value of id: {0}", ex.ID);
// Now repeat the process with a class that derives
// from Example.
//
DerivedFromExample dfex = new DerivedFromExample(71);
uli = (UseLikeInstance) changeID.CreateDelegate(
typeof(UseLikeInstance),
dfex
);
Console.WriteLine(
"Change the value of id; previous value: {0}",
uls(dfex, 73)
);
Console.WriteLine(
"Change the value of id; previous value: {0}",
uli(79)
);
Console.WriteLine("Final value of id: {0}", dfex.ID);
}
}
/* This code example produces the following output:
Change the value of id; previous value: 42
Change the value of id; previous value: 1492
Final value of id: 2700
Change the value of id; previous value: 71
Change the value of id; previous value: 73
Final value of id: 79
*/
Imports System.Reflection
Imports System.Reflection.Emit
' These classes are for demonstration purposes.
'
Public Class Example
Private _id As Integer = 0
Public Sub New(ByVal newId As Integer)
_id = newId
End Sub
Public ReadOnly Property ID() As Integer
Get
Return _id
End Get
End Property
End Class
Public Class DerivedFromExample
Inherits Example
Public Sub New(ByVal newId As Integer)
MyBase.New(newId)
End Sub
End Class
' Two delegates are declared: UseLikeInstance treats the dynamic
' method as if it were an instance method, and UseLikeStatic
' treats the dynamic method in the ordinary fashion.
'
Public Delegate Function UseLikeInstance(ByVal newID As Integer) _
As Integer
Public Delegate Function UseLikeStatic(ByVal ex As Example, _
ByVal newID As Integer) As Integer
Public Class Demo
Public Shared Sub Main()
' This dynamic method changes the private _id field. It
' has no name; it returns the old _id value (return type
' Integer); it takes two parameters, an instance of Example
' and an Integer that is the new value of _id; and it is
' declared with Example as the owner type, so it can
' access all members, public and private.
'
Dim changeID As New DynamicMethod( _
"", _
GetType(Integer), _
New Type() {GetType(Example), GetType(Integer)}, _
GetType(Example) _
)
' Get a FieldInfo for the private field '_id'.
Dim fid As FieldInfo = GetType(Example).GetField( _
"_id", _
BindingFlags.NonPublic Or BindingFlags.Instance _
)
Dim ilg As ILGenerator = changeID.GetILGenerator()
' Push the current value of the id field onto the
' evaluation stack. It's an instance field, so load the
' instance of Example before accessing the field.
ilg.Emit(OpCodes.Ldarg_0)
ilg.Emit(OpCodes.Ldfld, fid)
' Load the instance of Example again, load the new value
' of id, and store the new field value.
ilg.Emit(OpCodes.Ldarg_0)
ilg.Emit(OpCodes.Ldarg_1)
ilg.Emit(OpCodes.Stfld, fid)
' The original value of the id field is now the only
' thing on the stack, so return from the call.
ilg.Emit(OpCodes.Ret)
' Create a delegate that uses changeID in the ordinary
' way, as a static method that takes an instance of
' Example and an Integer.
'
Dim uls As UseLikeStatic = CType( _
changeID.CreateDelegate(GetType(UseLikeStatic)), _
UseLikeStatic _
)
' Create an instance of Example with an id of 42.
'
Dim ex As New Example(42)
' Create a delegate that is bound to the instance of
' of Example. This is possible because the first
' parameter of changeID is of type Example. The
' delegate has all the parameters of changeID except
' the first.
Dim uli As UseLikeInstance = CType( _
changeID.CreateDelegate( _
GetType(UseLikeInstance), _
ex), _
UseLikeInstance _
)
' First, change the value of _id by calling changeID as
' a static method, passing in the instance of Example.
'
Console.WriteLine( _
"Change the value of _id; previous value: {0}", _
uls(ex, 1492) _
)
' Change the value of _id again using the delegate
' bound to the instance of Example.
'
Console.WriteLine( _
"Change the value of _id; previous value: {0}", _
uli(2700) _
)
Console.WriteLine("Final value of _id: {0}", ex.ID)
' Now repeat the process with a class that derives
' from Example.
'
Dim dfex As New DerivedFromExample(71)
uli = CType( _
changeID.CreateDelegate( _
GetType(UseLikeInstance), _
dfex), _
UseLikeInstance _
)
Console.WriteLine( _
"Change the value of _id; previous value: {0}", _
uls(dfex, 73) _
)
Console.WriteLine( _
"Change the value of _id; previous value: {0}", _
uli(79) _
)
Console.WriteLine("Final value of _id: {0}", dfex.ID)
End Sub
End Class
' This code example produces the following output:
'
'Change the value of _id; previous value: 42
'Change the value of _id; previous value: 1492
'Final value of _id: 2700
'Change the value of _id; previous value: 71
'Change the value of _id; previous value: 73
'Final value of _id: 79'
Açıklamalar
Bu oluşturucu ile oluşturulan dinamik yöntemin türündeki owner
tüm üyelerine ve içeren owner
modüldeki diğer tüm türlerin public ve internal
(Friend
Visual Basic'te) üyelerine erişimi vardır.
Bu oluşturucu yöntem özniteliklerini MethodAttributes.Public ve MethodAttributes.Static, çağırma kuralını CallingConventions.Standardbelirtir ve tam zamanında (JIT) görünürlük denetimlerini atlamaz.
Not
Geriye dönük uyumluluk için bu oluşturucu, aşağıdaki koşulların SecurityPermissionFlag.ControlEvidence her ikisi de doğruysa bayrağını talep SecurityPermission eder: owner
çağıran modül dışında bir modüldedir ve ReflectionPermission bayrağıyla talebi ReflectionPermissionFlag.MemberAccess başarısız olmuştur. Talebin SecurityPermission başarılı olması durumunda işleme izin verilir.
Ayrıca bkz.
Şunlara uygulanır
DynamicMethod(String, Type, Type[], Module, Boolean)
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
Yöntem adını, dönüş türünü, parametre türlerini, modülü ve dinamik yöntemin Microsoft ara dili (MSIL) tarafından erişilen türler ve üyeler için tam zamanında (JIT) görünürlük denetimlerinin atlanıp atlanmayacağını belirterek bir modül için genel olan dinamik bir yöntem oluşturur.
public:
DynamicMethod(System::String ^ name, Type ^ returnType, cli::array <Type ^> ^ parameterTypes, System::Reflection::Module ^ m, bool skipVisibility);
public DynamicMethod (string name, Type? returnType, Type[]? parameterTypes, System.Reflection.Module m, bool skipVisibility);
public DynamicMethod (string name, Type returnType, Type[] parameterTypes, System.Reflection.Module m, bool skipVisibility);
new System.Reflection.Emit.DynamicMethod : string * Type * Type[] * System.Reflection.Module * bool -> System.Reflection.Emit.DynamicMethod
Public Sub New (name As String, returnType As Type, parameterTypes As Type(), m As Module, skipVisibility As Boolean)
Parametreler
- name
- String
Dinamik yöntemin adı. Bu sıfır uzunluklu bir dize olabilir, ancak olamaz null
.
- returnType
- Type
Type Dinamik yöntemin dönüş türünü belirten veya null
yöntemin dönüş türü olmayan bir nesne.
- parameterTypes
- Type[]
Dinamik yöntemin Type parametrelerinin türlerini belirten bir nesne dizisi veya null
yöntemin parametresi yoksa.
- skipVisibility
- Boolean
true
dinamik yöntemin MSIL tarafından erişilen türler ve üyeler üzerinde JIT görünürlük denetimlerini atlamak için.
Özel durumlar
öğesinin parameterTypes
veya öğesidirVoidnull
.
-veya-
m
, dinamik yöntemler için anonim barındırma sağlayan bir modüldür.
.NET Framework ve 2.1'den eski .NET Core sürümleri: returnType
döndüren IsByReftrue
bir türdür.
Açıklamalar
Bu oluşturucu yöntem özniteliklerini MethodAttributes.Public ve MethodAttributes.Staticve çağırma kuralını CallingConventions.Standardbelirtir.
Bu oluşturucu ile oluşturulan dinamik yöntemin, içindeki modüldeki m
tüm türlerin public ve internal
(Friend
Visual Basic'te) üyelerine erişimi vardır. JIT derleyicisinin görünürlük denetimlerinin atlanması, dinamik yöntemin diğer tüm türlerin özel ve korumalı üyelerine de erişmesini sağlar. Bu, örneğin nesneleri seri hale getirmek için kod yazarken yararlıdır.
Not
Geriye dönük uyumluluk için bu oluşturucu, aşağıdaki koşulların SecurityPermissionFlag.ControlEvidence her ikisi de doğruysa bayrağını talep SecurityPermission eder: m
çağıran modül dışında bir modüldür ve ReflectionPermission bayrağıyla talebi ReflectionPermissionFlag.MemberAccess başarısız olmuştur. Talebin SecurityPermission başarılı olması durumunda işleme izin verilir.
Ayrıca bkz.
Şunlara uygulanır
DynamicMethod(String, Type, Type[], Type, Boolean)
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
Yöntem adını, dönüş türünü, parametre türlerini, dinamik yöntemin mantıksal olarak ilişkilendirildiği türü ve dinamik yöntemin Microsoft ara dili (MSIL) tarafından erişilen türler ve üyeler için tam zamanında (JIT) görünürlük denetimlerinin atlanıp atlanmayacağını belirten dinamik bir yöntem oluşturur.
public:
DynamicMethod(System::String ^ name, Type ^ returnType, cli::array <Type ^> ^ parameterTypes, Type ^ owner, bool skipVisibility);
public DynamicMethod (string name, Type? returnType, Type[]? parameterTypes, Type owner, bool skipVisibility);
public DynamicMethod (string name, Type returnType, Type[] parameterTypes, Type owner, bool skipVisibility);
new System.Reflection.Emit.DynamicMethod : string * Type * Type[] * Type * bool -> System.Reflection.Emit.DynamicMethod
Public Sub New (name As String, returnType As Type, parameterTypes As Type(), owner As Type, skipVisibility As Boolean)
Parametreler
- name
- String
Dinamik yöntemin adı. Bu sıfır uzunluklu bir dize olabilir, ancak olamaz null
.
- returnType
- Type
Type Dinamik yöntemin dönüş türünü belirten veya null
yöntemin dönüş türü olmayan bir nesne.
- parameterTypes
- Type[]
Dinamik yöntemin Type parametrelerinin türlerini belirten bir nesne dizisi veya null
yöntemin parametresi yoksa.
- owner
- Type
Type Dinamik yöntemin mantıksal olarak ilişkilendirildiği bir. Dinamik yöntemin türün tüm üyelerine erişimi vardır.
- skipVisibility
- Boolean
true
dinamik yöntemin MSIL tarafından erişilen türler ve üyeler üzerinde JIT görünürlük denetimlerini atlamak için; aksi takdirde , false
.
Özel durumlar
öğesinin parameterTypes
veya öğesidirVoidnull
.
-veya-
owner
bir arabirim, dizi, açık bir genel tür veya genel tür veya yöntemin tür parametresidir.
.NET Framework ve 2.1'den eski .NET Core sürümleri: returnType
döndüren IsByReftrue
bir türdür.
Açıklamalar
Bu oluşturucu ile oluşturulan dinamik yöntemin türündeki owner
tüm üyelerine ve içeren owner
modüldeki diğer tüm türlerin public ve internal
(Friend
Visual Basic'te) üyelerine erişimi vardır. JIT derleyicisinin görünürlük denetimlerinin atlanması, dinamik yöntemin diğer tüm türlerin özel ve korumalı üyelerine de erişmesini sağlar. Bu, örneğin nesneleri seri hale getirmek için kod yazarken yararlıdır.
Bu oluşturucu yöntem özniteliklerini MethodAttributes.Public ve MethodAttributes.Staticve çağırma kuralını CallingConventions.Standardbelirtir.
Not
Geriye dönük uyumluluk için bu oluşturucu, aşağıdaki koşulların SecurityPermissionFlag.ControlEvidence her ikisi de doğruysa bayrağını talep SecurityPermission eder: owner
çağıran modül dışında bir modüldedir ve ReflectionPermission bayrağıyla talebi ReflectionPermissionFlag.MemberAccess başarısız olmuştur. Talebin SecurityPermission başarılı olması durumunda işleme izin verilir.
Ayrıca bkz.
Şunlara uygulanır
DynamicMethod(String, MethodAttributes, CallingConventions, Type, Type[], Module, Boolean)
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
Yöntem adını, özniteliklerini, çağırma kuralını, dönüş türünü, parametre türlerini, modülünü ve dinamik yöntemin Microsoft ara dili (MSIL) tarafından erişilen türler ve üyeler için tam zamanında (JIT) görünürlük denetimlerinin atlanıp atlanmayacağını belirterek bir modül için genel olan dinamik bir yöntem oluşturur.
public:
DynamicMethod(System::String ^ name, System::Reflection::MethodAttributes attributes, System::Reflection::CallingConventions callingConvention, Type ^ returnType, cli::array <Type ^> ^ parameterTypes, System::Reflection::Module ^ m, bool skipVisibility);
public DynamicMethod (string name, System.Reflection.MethodAttributes attributes, System.Reflection.CallingConventions callingConvention, Type? returnType, Type[]? parameterTypes, System.Reflection.Module m, bool skipVisibility);
public DynamicMethod (string name, System.Reflection.MethodAttributes attributes, System.Reflection.CallingConventions callingConvention, Type returnType, Type[] parameterTypes, System.Reflection.Module m, bool skipVisibility);
new System.Reflection.Emit.DynamicMethod : string * System.Reflection.MethodAttributes * System.Reflection.CallingConventions * Type * Type[] * System.Reflection.Module * bool -> System.Reflection.Emit.DynamicMethod
Public Sub New (name As String, attributes As MethodAttributes, callingConvention As CallingConventions, returnType As Type, parameterTypes As Type(), m As Module, skipVisibility As Boolean)
Parametreler
- name
- String
Dinamik yöntemin adı. Bu sıfır uzunluklu bir dize olabilir, ancak olamaz null
.
- attributes
- MethodAttributes
Dinamik yöntemin MethodAttributes özniteliklerini belirten değerlerin bit düzeyinde birleşimi. İzin verilen tek birleşim ve Static'dirPublic.
- callingConvention
- CallingConventions
Dinamik yöntem için çağırma kuralı. olmalıdır Standard.
- returnType
- Type
Type Dinamik yöntemin dönüş türünü belirten veya null
yöntemin dönüş türü olmayan bir nesne.
- parameterTypes
- Type[]
Dinamik yöntemin Type parametrelerinin türlerini belirten bir nesne dizisi veya null
yöntemin parametresi yoksa.
- skipVisibility
- Boolean
true
dinamik yöntemin MSIL tarafından erişilen türler ve üyeler üzerinde JIT görünürlük denetimlerini atlamak için; aksi takdirde , false
.
Özel durumlar
öğesinin parameterTypes
veya öğesidirVoidnull
.
-veya-
m
, dinamik yöntemler için anonim barındırma sağlayan bir modüldür.
attributes
ve Staticdışındaki Public bayrakların birleşimidir.
-veya-
callingConvention
değil Standard.
-veya-
returnType
, değerini döndüren IsByReftrue
bir türdür.
Açıklamalar
Bu oluşturucuyla oluşturulan dinamik yöntemin, modülünde m
bulunan tüm genel ve internal
iç türlerin public ve (Friend
Visual Basic'te) üyelerine erişimi vardır.
JIT derleyicisinin görünürlük denetimlerinin atlanması, dinamik yöntemin modüldeki ve diğer tüm derlemelerdeki diğer tüm türlerin özel ve korumalı üyelerine erişmesini sağlar. Bu, örneğin nesneleri seri hale getirmek için kod yazarken yararlıdır.
Not
Geriye dönük uyumluluk için bu oluşturucu, aşağıdaki koşulların SecurityPermissionFlag.ControlEvidence her ikisi de doğruysa bayrağını talep SecurityPermission eder: m
çağıran modül dışında bir modüldür ve ReflectionPermission bayrağıyla talebi ReflectionPermissionFlag.MemberAccess başarısız olmuştur. Talebin SecurityPermission başarılı olması durumunda işleme izin verilir.
Ayrıca bkz.
Şunlara uygulanır
DynamicMethod(String, MethodAttributes, CallingConventions, Type, Type[], Type, Boolean)
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
- Kaynak:
- DynamicMethod.cs
Yöntem adını, özniteliklerini, çağırma kuralını, dönüş türünü, parametre türlerini, dinamik yöntemin mantıksal olarak ilişkilendirildiği türü ve dinamik yöntemin Microsoft ara dili (MSIL) tarafından erişilen türler ve üyeler için tam zamanında (JIT) görünürlük denetimlerinin atlanıp atlanmayacağını belirten dinamik bir yöntem oluşturur.
public:
DynamicMethod(System::String ^ name, System::Reflection::MethodAttributes attributes, System::Reflection::CallingConventions callingConvention, Type ^ returnType, cli::array <Type ^> ^ parameterTypes, Type ^ owner, bool skipVisibility);
public DynamicMethod (string name, System.Reflection.MethodAttributes attributes, System.Reflection.CallingConventions callingConvention, Type? returnType, Type[]? parameterTypes, Type owner, bool skipVisibility);
public DynamicMethod (string name, System.Reflection.MethodAttributes attributes, System.Reflection.CallingConventions callingConvention, Type returnType, Type[] parameterTypes, Type owner, bool skipVisibility);
new System.Reflection.Emit.DynamicMethod : string * System.Reflection.MethodAttributes * System.Reflection.CallingConventions * Type * Type[] * Type * bool -> System.Reflection.Emit.DynamicMethod
Public Sub New (name As String, attributes As MethodAttributes, callingConvention As CallingConventions, returnType As Type, parameterTypes As Type(), owner As Type, skipVisibility As Boolean)
Parametreler
- name
- String
Dinamik yöntemin adı. Bu sıfır uzunluklu bir dize olabilir, ancak olamaz null
.
- attributes
- MethodAttributes
Dinamik yöntemin MethodAttributes özniteliklerini belirten değerlerin bit düzeyinde birleşimi. İzin verilen tek birleşim ve Static'dirPublic.
- callingConvention
- CallingConventions
Dinamik yöntem için çağırma kuralı. olmalıdır Standard.
- returnType
- Type
Type Dinamik yöntemin dönüş türünü belirten veya null
yöntemin dönüş türü olmayan bir nesne.
- parameterTypes
- Type[]
Dinamik yöntemin Type parametrelerinin türlerini belirten bir nesne dizisi veya null
yöntemin parametresi yoksa.
- owner
- Type
Type Dinamik yöntemin mantıksal olarak ilişkilendirildiği bir. Dinamik yöntemin türün tüm üyelerine erişimi vardır.
- skipVisibility
- Boolean
true
dinamik yöntemin MSIL tarafından erişilen türler ve üyeler üzerinde JIT görünürlük denetimlerini atlamak için; aksi takdirde , false
.
Özel durumlar
öğesinin parameterTypes
veya öğesidirVoidnull
.
-veya-
owner
bir arabirim, dizi, açık bir genel tür veya genel tür veya yöntemin tür parametresidir.
attributes
ve Staticdışındaki Public bayrakların birleşimidir.
-veya-
callingConvention
değil Standard.
-veya-
returnType
, değerini döndüren IsByReftrue
bir türdür.
Açıklamalar
Dinamik yöntem, türünü owner
içeren modül için geneldir. türünün owner
tüm üyelerine erişimi vardır.
Bu oluşturucuyla oluşturulan dinamik yöntemin , türünün owner
tüm üyelerine ve içeren owner
modülde yer alan tüm türlerin public ve internal
(Friend
Visual Basic'te) üyelerine erişimi vardır. JIT derleyicisinin görünürlük denetimlerinin atlanması, dinamik yöntemin diğer tüm türlerin özel ve korumalı üyelerine de erişmesini sağlar. Bu, örneğin nesneleri seri hale getirmek için kod yazarken yararlıdır.
Not
Geriye dönük uyumluluk için bu oluşturucu, aşağıdaki koşulların SecurityPermissionFlag.ControlEvidence her ikisi de doğruysa bayrağını talep SecurityPermission eder: owner
çağıran modül dışında bir modüldedir ve ReflectionPermission bayrağıyla talebi ReflectionPermissionFlag.MemberAccess başarısız olmuştur. Talebin SecurityPermission başarılı olması durumunda işleme izin verilir.