Assembly.GetCallingAssembly Methode
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
Gibt die Assembly der Methode zurück, die die derzeit ausgeführte Methode aufgerufen hat.
public:
static System::Reflection::Assembly ^ GetCallingAssembly();
public static System.Reflection.Assembly GetCallingAssembly ();
static member GetCallingAssembly : unit -> System.Reflection.Assembly
Public Shared Function GetCallingAssembly () As Assembly
Gibt zurück
Das Assembly
-Objekt der Methode, die die derzeit ausgeführte Methode aufgerufen hat.
Beispiele
Im folgenden Beispiel wird die aufrufende Assembly der aktuellen Methode abgerufen.
using namespace System;
using namespace System::Reflection;
void main()
{
// Instantiate a target object.
Int32 integer1 = 0;
// Set the Type instance to the target class type.
Type^ type1 = integer1.GetType();
// Instantiate an Assembly class to the assembly housing the Integer type.
Assembly^ sampleAssembly = Assembly::GetAssembly(integer1.GetType());
// Display the name of the assembly that is calling the method.
Console::WriteLine("GetCallingAssembly = {0}", Assembly::GetCallingAssembly()->FullName);
}
// The example displays output like the following:
// GetCallingAssembly = Example, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null
// Assembly FirstAssembly
using System;
using System.Reflection;
using System.Runtime.CompilerServices;
namespace FirstAssembly
{
public class InFirstAssembly
{
public static void Main()
{
FirstMethod();
SecondAssembly.InSecondAssembly.OtherMethod();
}
[MethodImpl(MethodImplOptions.NoInlining)]
public static void FirstMethod()
{
Console.WriteLine("FirstMethod called from: " + Assembly.GetCallingAssembly().FullName);
}
}
}
// Assembly SecondAssembly
namespace SecondAssembly
{
class InSecondAssembly
{
[MethodImpl(MethodImplOptions.NoInlining)]
public static void OtherMethod()
{
Console.WriteLine("OtherMethod executing assembly: " + Assembly.GetExecutingAssembly().FullName);
Console.WriteLine("OtherMethod called from: " + Assembly.GetCallingAssembly().FullName);
}
}
}
// The example produces output like the following:
// "FirstMethod called from: FirstAssembly, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null"
// "OtherMethod executing assembly: SecondAssembly, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null"
// "OtherMethod called from: FirstAssembly, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null"
Imports System.Reflection
Module Example
Public Sub Main()
' Instantiate a target object.
Dim int1 As Integer
' Set the Type instance to the target class type.
Dim type1 As Type =int1.GetType()
' Instantiate an Assembly class to the assembly housing the Integer type.
Dim sampleAssembly = Assembly.GetAssembly(int1.GetType())
' Display the name of the assembly that is calling the method.
Console.WriteLine(("GetCallingAssembly = " + Assembly.GetCallingAssembly().FullName))
End Sub
End Module
' The example displays output like the following:
' GetCallingAssembly = Example, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null
Hinweise
Wenn die Methode, die die GetCallingAssembly Methode aufruft, vom JIT-Compiler (Just-In-Time) inline erweitert wird oder der Aufrufer inline erweitert wird, kann die von GetCallingAssembly zurückgegebene Assembly unerwartet abweichen. Betrachten Sie beispielsweise die folgenden Methoden und Assemblys:
Die Methode
M1
in der AssemblyA1
ruft auf GetCallingAssembly.Die Methode
M2
in der AssemblyA2
ruft aufM1
.Die Methode
M3
in der AssemblyA3
ruft aufM2
.
Wenn M1
nicht inlined ist, GetCallingAssembly wird zurückgegeben A2
. Wenn M1
inline ist, GetCallingAssembly gibt zurück A3
. Auf ähnliche Weise wird zurückgegebenA2
, wenn M2
nicht inlined GetCallingAssembly ist. Wenn M2
inline ist, GetCallingAssembly gibt zurück A3
.
Dieser Effekt tritt auch auf, wenn M1
als Tail-Aufruf von M2
oder als M2
Tail-Aufruf von M3
ausgeführt wird. Sie können verhindern, dass der JIT-Compiler die Methode aufgibt, die aufruft GetCallingAssembly, indem Sie das MethodImplAttribute -Attribut mit dem MethodImplOptions.NoInlining -Flag anwenden. Es gibt jedoch keinen ähnlichen Mechanismus zum Verhindern von Tail-Aufrufen.