StructLayoutAttributeとは? わかりやすく解説

StructLayoutAttribute クラス

StructLayoutAttribute クラス使用すると、クラスまたは構造体データ フィールド物理的なレイアウト制御できます

名前空間: System.Runtime.InteropServices
アセンブリ: mscorlib (mscorlib.dll 内)
構文構文

<ComVisibleAttribute(True)> _
<AttributeUsageAttribute(AttributeTargets.Class Or AttributeTargets.Struct,
 Inherited:=False)> _
Public NotInheritable Class
 StructLayoutAttribute
    Inherits Attribute
Dim instance As StructLayoutAttribute
[ComVisibleAttribute(true)] 
[AttributeUsageAttribute(AttributeTargets.Class|AttributeTargets.Struct, Inherited=false)]
 
public sealed class StructLayoutAttribute :
 Attribute
[ComVisibleAttribute(true)] 
[AttributeUsageAttribute(AttributeTargets::Class|AttributeTargets::Struct, Inherited=false)]
 
public ref class StructLayoutAttribute sealed
 : public Attribute
/** @attribute ComVisibleAttribute(true) */ 
/** @attribute AttributeUsageAttribute(AttributeTargets.Class|AttributeTargets.Struct,
 Inherited=false) */ 
public final class StructLayoutAttribute extends
 Attribute
ComVisibleAttribute(true) 
AttributeUsageAttribute(AttributeTargets.Class|AttributeTargets.Struct, Inherited=false)
 
public final class StructLayoutAttribute extends
 Attribute
解説解説
使用例使用例

次に示すのは、GetSystemTime 関数マネージ宣言の例です。このコードは、MySystemTime クラスを LayoutKind.Explicit レイアウト定義しますまた、GetSystemTime は、システム タイム取得してコンソール出力します

   <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 'MySystemTime

   
   Class LibWrapper
      
      <DllImport("kernel32.dll")>  _
      Public Shared Sub
 GetSystemTime(<MarshalAs(UnmanagedType.LPStruct)> st As
 MySystemTime)
      End SUb    
   End Class 'LibWrapper

   Class TestApplication
      
      Public Shared Sub
 Main()
         Try
            Dim sysTime As New
 MySystemTime()
            LibWrapper.GetSystemTime(sysTime)
            Console.WriteLine("The System time is {0}/{1}/{2}
 {3}:{4}:{5}", sysTime.wDay, sysTime.wMonth, sysTime.wYear, sysTime.wHour,
 sysTime.wMinute, sysTime.wSecond)
         Catch e As TypeLoadException
            Console.WriteLine(("TypeLoadException : "
 + e.Message.ToString()))
         Catch e As Exception
            Console.WriteLine(("Exception : " + e.Message.ToString()))
         End Try
      End Sub 'Main
   End Class 'TestApplication
End Namespace 'InteropSample 
[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; 
}

class LibWrapper
{
   [DllImport("kernel32.dll")]
   public static extern void
 GetSystemTime([MarshalAs(UnmanagedType.LPStruct)]MySystemTime st);
};

class TestApplication
{      
   public static void Main()
   {
      try
      {
         MySystemTime sysTime = new MySystemTime();
         LibWrapper.GetSystemTime(sysTime);
         Console.WriteLine("The System time is {0}/{1}/{2} {3}:{4}:{5}",
 sysTime.wDay,
            sysTime.wMonth, sysTime.wYear, sysTime.wHour, sysTime.wMinute, sysTime.wSecond);
            
      }         
      catch(TypeLoadException e)
      {
         Console.WriteLine("TypeLoadException : " + e.Message);
      }
      catch(Exception e)
      {
         Console.WriteLine("Exception : " + e.Message);
      }
   }
}
[StructLayout(LayoutKind::Explicit,Size=16,CharSet=CharSet::Ansi)]
value class MySystemTime
{
public:

   [FieldOffset(0)]
   short wYear;

   [FieldOffset(2)]
   short wMonth;

   [FieldOffset(4)]
   short wDayOfWeek;

   [FieldOffset(6)]
   short wDay;

   [FieldOffset(8)]
   short wHour;

   [FieldOffset(10)]
   short wMinute;

   [FieldOffset(12)]
   short wSecond;

   [FieldOffset(14)]
   short wMilliseconds;
};

ref class LibWrapper
{
public:

   [DllImport("kernel32.dll")]
   static void GetSystemTime( MySystemTime
 * st );
};

int main()
{
   try
   {
      MySystemTime sysTime;
      LibWrapper::GetSystemTime(  &sysTime );
      Console::WriteLine( "The System time is {0}/{1}/{2} {3}:{4}:{5}",
 sysTime.wDay, sysTime.wMonth, sysTime.wYear, sysTime.wHour, sysTime.wMinute, sysTime.wSecond
 );
   }
   catch ( TypeLoadException^ e ) 
   {
      Console::WriteLine( "TypeLoadException : {0}", e->Message );
   }
   catch ( Exception^ e ) 
   {
      Console::WriteLine( "Exception : {0}", e->Message );
   }

}

/** @attribute StructLayout(LayoutKind.Explicit, Size = 16, 
    CharSet = CharSet.Ansi)
 */
public class MySystemTime
{
    /** @attribute FieldOffset(0)
     */
    public short wYear;
    
    /** @attribute FieldOffset(2)
     */
    public short wMonth;
    
    /** @attribute FieldOffset(4)
     */
    public short wDayOfWeek;

    /** @attribute FieldOffset(6)
     */
    public short wDay;

    /** @attribute FieldOffset(8)
     */
    public short wHour;

    /** @attribute FieldOffset(10)
     */
    public short wMinute;

    /** @attribute FieldOffset(12)
     */
    public short wSecond;

    /** @attribute FieldOffset(14)
     */
    public short wMilliseconds;

} //MySystemTime

class LibWrapper
{
    /** @attribute DllImport("kernel32.dll")
     */
    public static native void
 GetSystemTime(
        /** @attribute MarshalAs(UnmanagedType.LPStruct)
         */
        MySystemTime st);
} //LibWrapper

class TestApplication
{
    public static void main(String[]
 args)
    {
        try {
            MySystemTime sysTime = new MySystemTime();
            LibWrapper.GetSystemTime(sysTime);
            Console.WriteLine("The System time is {0}/{1}/{2} {3}:{4}:{5}"
,
                new Object[] { (Int32)sysTime.wDay, (Int32)sysTime.wMonth
,
                (Int32)sysTime.wYear, (Int32)sysTime.wHour, (Int32)sysTime.
                wMinute, (Int32)sysTime.wSecond });
        }
        catch (TypeLoadException e) {
            Console.WriteLine("TypeLoadException : " + e.get_Message());
        }
        catch (System.Exception e) {
            Console.WriteLine("Exception : " + e.get_Message());
        }
    } //main
} //TestApplication
継承階層継承階層
System.Object
   System.Attribute
    System.Runtime.InteropServices.StructLayoutAttribute
スレッド セーフスレッド セーフ
この型の public static (Visual Basic では Shared) メンバはすべて、スレッド セーフです。インスタンス メンバ場合は、スレッド セーフであるとは限りません。
プラットフォームプラットフォーム
バージョン情報バージョン情報
参照参照
関連項目
StructLayoutAttribute メンバ
System.Runtime.InteropServices 名前空間
その他の技術情報
タイプ ライブラリ インポータ (Tlbimp.exe)

StructLayoutAttribute コンストラクタ (LayoutKind)

指定した System.Runtime.InteropServices.LayoutKind 列挙メンバ使用して、StructLayoutAttribute クラス新しインスタンス初期化します。

名前空間: System.Runtime.InteropServices
アセンブリ: mscorlib (mscorlib.dll 内)
構文構文

Public Sub New ( _
    layoutKind As LayoutKind _
)
Dim layoutKind As LayoutKind

Dim instance As New StructLayoutAttribute(layoutKind)
public StructLayoutAttribute (
    LayoutKind layoutKind
)
public:
StructLayoutAttribute (
    LayoutKind layoutKind
)
public StructLayoutAttribute (
    LayoutKind layoutKind
)
public function StructLayoutAttribute (
    layoutKind : LayoutKind
)

パラメータ

layoutKind

クラスまたは構造体整列する方法指定する LayoutKind 値の 1 つ

解説解説

エラー招きにくく、読みやすいコードにするためには、常にこのコンストラクタ使用してください

プラットフォームプラットフォーム
バージョン情報バージョン情報
参照参照
関連項目
StructLayoutAttribute クラス
StructLayoutAttribute メンバ
System.Runtime.InteropServices 名前空間
LayoutKind 列挙

StructLayoutAttribute コンストラクタ

StructLayoutAttribute クラス新しインスタンス初期化します。
オーバーロードの一覧オーバーロードの一覧

名前 説明
StructLayoutAttribute (Int16) 指定した System.Runtime.InteropServices.LayoutKind 列挙メンバ使用してStructLayoutAttribute クラス新しインスタンス初期化します。
StructLayoutAttribute (LayoutKind) 指定した System.Runtime.InteropServices.LayoutKind 列挙メンバ使用してStructLayoutAttribute クラス新しインスタンス初期化します。

.NET Compact Framework によってサポートされています。

参照参照

関連項目

StructLayoutAttribute クラス
StructLayoutAttribute メンバ
System.Runtime.InteropServices 名前空間
LayoutKind 列挙

その他の技術情報

タイプ ライブラリ インポータ (Tlbimp.exe)

StructLayoutAttribute コンストラクタ (Int16)

指定した System.Runtime.InteropServices.LayoutKind 列挙メンバ使用して、StructLayoutAttribute クラス新しインスタンス初期化します。

名前空間: System.Runtime.InteropServices
アセンブリ: mscorlib (mscorlib.dll 内)
構文構文

Public Sub New ( _
    layoutKind As Short _
)
Dim layoutKind As Short

Dim instance As New StructLayoutAttribute(layoutKind)
public StructLayoutAttribute (
    short layoutKind
)
public:
StructLayoutAttribute (
    short layoutKind
)
public StructLayoutAttribute (
    short layoutKind
)
public function StructLayoutAttribute (
    layoutKind : short
)

パラメータ

layoutKind

クラスまたは構造体整列する方法指定する LayoutKind 値の 1 つ

解説解説

このコンストラクタは、LayoutKind 列挙体の各メンバを表す、基になる 16 ビット整数値を受け取りますタイプ ライブラリ インポータ (Tlbimp.exe) は、このコンストラクタ使用します

プラットフォームプラットフォーム
バージョン情報バージョン情報
参照参照
関連項目
StructLayoutAttribute クラス
StructLayoutAttribute メンバ
System.Runtime.InteropServices 名前空間
LayoutKind 列挙
その他の技術情報
タイプ ライブラリ インポータ (Tlbimp.exe)

StructLayoutAttribute フィールド


パブリック フィールドパブリック フィールド

参照参照

関連項目

StructLayoutAttribute クラス
System.Runtime.InteropServices 名前空間

その他の技術情報

タイプ ライブラリ インポータ (Tlbimp.exe)

StructLayoutAttribute プロパティ


パブリック プロパティパブリック プロパティ

  名前 説明
パブリック プロパティ TypeId  派生クラス実装されている場合は、この Attribute一意識別子取得します。 ( Attribute から継承されます。)
パブリック プロパティ Value クラスまたは構造体整列する方法指定する LayoutKind 値を取得します
参照参照

関連項目

StructLayoutAttribute クラス
System.Runtime.InteropServices 名前空間

その他の技術情報

タイプ ライブラリ インポータ (Tlbimp.exe)

StructLayoutAttribute メソッド


パブリック メソッドパブリック メソッド

  名前 説明
パブリック メソッド Equals  オーバーロードされます。 ( Attribute から継承されます。)
パブリック メソッド GetCustomAttribute  オーバーロードされますアセンブリモジュール、型のメンバ、またはメソッド パラメータ適用され指定した型のカスタム属性取得します。 ( Attribute から継承されます。)
パブリック メソッド GetCustomAttributes  オーバーロードされますアセンブリモジュール、型のメンバ、またはメソッド パラメータ適用されカスタム属性配列取得します。 ( Attribute から継承されます。)
パブリック メソッド GetHashCode  このインスタンスハッシュ コード返します。 ( Attribute から継承されます。)
パブリック メソッド GetType  現在のインスタンスType取得します。 ( Object から継承されます。)
パブリック メソッド IsDefaultAttribute  派生クラス内でオーバーライドされたときに、このインスタンスの値が派生クラス既定値かどうか示します。 ( Attribute から継承されます。)
パブリック メソッド IsDefined  オーバーロードされます指定した型のカスタム属性が、アセンブリモジュール、型のメンバ、またはメソッド パラメータ適用されているかどうか判断します。 ( Attribute から継承されます。)
パブリック メソッド Match  派生クラス内でオーバーライドされたときに、指定したオブジェクトとこのインスタンス等しかどうかを示す値を返します。 ( Attribute から継承されます。)
パブリック メソッド ReferenceEquals  指定した複数Object インスタンス同一かどうか判断します。 ( Object から継承されます。)
パブリック メソッド ToString  現在の Object を表す String返します。 ( Object から継承されます。)
参照参照

関連項目

StructLayoutAttribute クラス
System.Runtime.InteropServices 名前空間

その他の技術情報

タイプ ライブラリ インポータ (Tlbimp.exe)

StructLayoutAttribute メンバ

StructLayoutAttribute クラス使用すると、クラスまたは構造体データ フィールド物理的なレイアウト制御できます

StructLayoutAttribute データ型公開されるメンバを以下の表に示します


パブリック コンストラクタパブリック コンストラクタ
  名前 説明
パブリック メソッド StructLayoutAttribute オーバーロードされます。 StructLayoutAttribute クラス新しインスタンス初期化します。
パブリック フィールドパブリック フィールド
パブリック プロパティパブリック プロパティ
パブリック メソッドパブリック メソッド
  名前 説明
パブリック メソッド Equals  オーバーロードされます。 ( Attribute から継承されます。)
パブリック メソッド GetCustomAttribute  オーバーロードされますアセンブリモジュール、型のメンバ、またはメソッド パラメータ適用され指定した型のカスタム属性取得します。 (Attribute から継承されます。)
パブリック メソッド GetCustomAttributes  オーバーロードされますアセンブリモジュール、型のメンバ、またはメソッド パラメータ適用されカスタム属性配列取得します。 (Attribute から継承されます。)
パブリック メソッド GetHashCode  このインスタンスハッシュ コード返します。 (Attribute から継承されます。)
パブリック メソッド GetType  現在のインスタンスType取得します。 (Object から継承されます。)
パブリック メソッド IsDefaultAttribute  派生クラス内でオーバーライドされたときに、このインスタンスの値が派生クラス既定値かどうか示します。 (Attribute から継承されます。)
パブリック メソッド IsDefined  オーバーロードされます指定した型のカスタム属性が、アセンブリモジュール、型のメンバ、またはメソッド パラメータ適用されているかどうか判断します。 (Attribute から継承されます。)
パブリック メソッド Match  派生クラス内でオーバーライドされたときに、指定したオブジェクトとこのインスタンス等しかどうかを示す値を返します。 (Attribute から継承されます。)
パブリック メソッド ReferenceEquals  指定した複数Object インスタンス同一かどうか判断します。 (Object から継承されます。)
パブリック メソッド ToString  現在の Object を表す String返します。 (Object から継承されます。)
参照参照

関連項目

StructLayoutAttribute クラス
System.Runtime.InteropServices 名前空間

その他の技術情報

タイプ ライブラリ インポータ (Tlbimp.exe)


このページでは「.NET Framework クラス ライブラリ リファレンス」からStructLayoutAttributeを検索した結果を表示しています。
Weblioに収録されているすべての辞書からStructLayoutAttributeを検索する場合は、下記のリンクをクリックしてください。
 全ての辞書からStructLayoutAttribute を検索

英和和英テキスト翻訳>> Weblio翻訳
英語⇒日本語日本語⇒英語
  

辞書ショートカット

すべての辞書の索引

「StructLayoutAttribute」の関連用語

StructLayoutAttributeのお隣キーワード
検索ランキング

   

英語⇒日本語
日本語⇒英語
   



StructLayoutAttributeのページの著作権
Weblio 辞書 情報提供元は 参加元一覧 にて確認できます。

   
日本マイクロソフト株式会社日本マイクロソフト株式会社
© 2025 Microsoft.All rights reserved.

©2025 GRAS Group, Inc.RSS