Type.IsExplicitLayout Свойство
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Возвращает значение, указывающее, выкладываются ли поля текущего типа с явно заданными смещениями.
public:
property bool IsExplicitLayout { bool get(); };
public bool IsExplicitLayout { get; }
member this.IsExplicitLayout : bool
Public ReadOnly Property IsExplicitLayout As Boolean
Значение свойства
Значение true
, если свойство Attributes текущего типа включает ExplicitLayout; в противном случае — значение false
.
Реализации
Примеры
В следующем примере создается экземпляр типа и отображается значение его IsExplicitLayout Свойства. В нем используется MySystemTime
класс, который также находится в примере кода для StructLayoutAttribute .
using System;
using System.Reflection;
using System.ComponentModel;
using System.Runtime.InteropServices;
// Class to test for the ExplicitLayout property.
[StructLayout(LayoutKind.Explicit, Size=16, CharSet=CharSet.Ansi)]
public class MySystemTime
{
[FieldOffset(0)]public ushort wYear;
[FieldOffset(2)]public ushort wMonth;
[FieldOffset(4)]public ushort wDayOfWeek;
[FieldOffset(6)]public ushort wDay;
[FieldOffset(8)]public ushort wHour;
[FieldOffset(10)]public ushort wMinute;
[FieldOffset(12)]public ushort wSecond;
[FieldOffset(14)]public ushort wMilliseconds;
}
public class Program
{
public static void Main(string[] args)
{
// Create an instance of the type using the GetType method.
Type t = typeof(MySystemTime);
// Get and display the IsExplicitLayout property.
Console.WriteLine("\nIsExplicitLayout for MySystemTime is {0}.",
t.IsExplicitLayout);
}
}
Imports System.Reflection
Imports System.ComponentModel
Imports System.Runtime.InteropServices
'Class to test for the ExplicitLayout property.
<StructLayout(LayoutKind.Explicit, Size := 16, CharSet := CharSet.Ansi)> _
Public Class MySystemTime
<FieldOffset(0)> Public wYear As Short
<FieldOffset(2)> Public wMonth As Short
<FieldOffset(4)> Public wDayOfWeek As Short
<FieldOffset(6)> Public wDay As Short
<FieldOffset(8)> Public wHour As Short
<FieldOffset(10)> Public wMinute As Short
<FieldOffset(12)> Public wSecond As Short
<FieldOffset(14)> Public wMilliseconds As Short
End Class
Public Class Program
Public Shared Sub Main()
'Create an instance of type using the GetType method.
Dim t As Type = GetType(MySystemTime)
' Get and display the IsExplicitLayout property.
Console.WriteLine(vbCrLf & "IsExplicitLayout for MySystemTime is {0}.", _
t.IsExplicitLayout)
End Sub
End Class
Комментарии
Это свойство предоставляется для удобства. Кроме того, можно использовать TypeAttributes.LayoutMask значение перечисления для выбора атрибутов макета типа, а затем проверить TypeAttributes.ExplicitLayout , задан ли параметр. TypeAttributes.AutoLayout TypeAttributes.ExplicitLayout Значения перечисления, и TypeAttributes.SequentialLayout указывают способ расположения полей типа в памяти.
Для динамических типов можно указать TypeAttributes.ExplicitLayout при создании типа. В коде примените StructLayoutAttribute атрибут со LayoutKind.Explicit значением перечисления к типу, чтобы указать, что смещения, с которых начинаются поля, указаны явно.
Примечание
Нельзя использовать метод, GetCustomAttributes чтобы определить, применен ли к StructLayoutAttribute типу.
Если текущий объект Type представляет сконструированный универсальный тип, это свойство применяется к определению универсального типа, из которого был создан тип. например, если current Type представляет MyGenericType<int>
( MyGenericType(Of Integer)
в Visual Basic), значение этого свойства определяется MyGenericType<T>
.
Если Current Type представляет параметр типа в определении универсального типа или универсального метода, это свойство всегда возвращает значение false
.