Estoy aprendiendo sobre el código administrado y no administrado en CLR. Así que escribió este ejemplo con los punteros de tipo C en C#:¿Qué es inseguro en este código?
unsafe static void Main(string[] args)
{
int x;
int* y;
y = &x;
*y = 50;
Console.WriteLine(*y);
Console.WriteLine(((int)y).ToString());
}
Así que me pregunto lo que realmente no es seguro en el código IL que me dieron en el código anterior?
.assembly extern mscorlib
{}
.assembly UnsafePointers
{}
.module UnsafePointers.exe
.class private auto ansi beforefieldinit UnsafePointers.Program
extends [mscorlib]System.Object
{
.method private hidebysig static void Main(string[] args) cil managed
{
.entrypoint
// Code size 34 (0x22)
.locals init (int32 x,
int32* y)
IL_0001: ldloca x
IL_0003: conv.u
IL_0004: stloc y
IL_0005: ldloc y
IL_0006: ldc.i4 50
IL_0008: stind.i4
IL_0009: ldloc y
IL_000a: ldind.i4
IL_000b: call void [mscorlib]System.Console::WriteLine(int32)
IL_0010: nop
IL_0011: ldloca y
IL_0012: conv.i4
IL_0016: call instance string [mscorlib]System.Int32::ToString()
IL_001b: call void [mscorlib]System.Console::WriteLine(string)
IL_0021: ret
}
}
¿CLR gestiona este código? ¿Y qué puede salir mal con un código de arriba?
Además de lo que otros dijeron, este código sigue siendo 100% administrado. Es solo que no es verificable que tenga memoria correcta, como la herramienta peverify puede decirte. – John