MarshalAsAttribute.SizeParamIndex Campo

Definición

Indica el parámetro de base cero que contiene el recuento de elementos de matriz, similar a size_is en COM.

C#
public short SizeParamIndex;

Valor de campo

Ejemplos

C#
using System.Runtime.InteropServices;
using SomeNamespace;

namespace SomeNamespace
{
    // Force the layout of your fields to the C style struct layout.
    // Without this, the .NET Framework will reorder your fields.
    [StructLayout(LayoutKind.Sequential)]
    public struct Vertex
    {
        float	x;
    float	y;
        float	z;
    }

    class SomeClass
    {
        // Add [In] or [In, Out] attributes as approppriate.
        // Marshal as a C style array of Vertex, where the second (SizeParamIndex is zero-based)
        //  parameter (size) contains the count of array elements.
        [DllImport ("SomeDll.dll")]
        public static extern void SomeUnsafeMethod(
                                      [MarshalAs(UnmanagedType.LPArray, SizeParamIndex=1)] Vertex[] data,
                                      long size );

        public void SomeMethod()
        {
            Vertex[] verts = new Vertex[3];
            SomeUnsafeMethod( verts, verts.Length );
        }
    }
}

class Test
{
    public static void Main()
    {
        SomeClass AClass = new SomeClass();

        AClass.SomeMethod();
    }
}

Comentarios

El SizeParamIndex campo admite llamadas administradas a no administradas y no administradas a administradas. No tiene ningún efecto en el código administrado que llama a objetos COM.

Según el tipo administrado y los atributos aplicados, la matriz se puede pasar como una matriz segura o una matriz de estilo C.

Cuando las matrices se pasan como matrices de estilo C, el serializador no puede determinar el tamaño de la matriz. Por lo tanto, para pasar una matriz administrada a una función o método no administrados, debe proporcionar dos argumentos:

  • Matriz, definida por referencia o valor.

  • Tamaño de la matriz, definido por referencia o valor.

El índice de base cero del parámetro de tamaño de matriz se define mediante el SizeParamIndex campo .

Si especifica y SizeParamIndexMarshalAsAttribute.SizeConst con un UnmanagedType.LPArray campo, la suma de los valores de los campos genera un tamaño total.

Para obtener más información, vea Serialización predeterminada para matrices.

Se aplica a

Produto Versións
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Consulte también