Aracılığıyla paylaş


InAttribute Sınıf

Tanım

Verilerin çağırandan çağırana sıralanması gerektiğini, ancak arayana geri döndürülmeyeceğini gösterir.

public ref class InAttribute sealed : Attribute
[System.AttributeUsage(System.AttributeTargets.Parameter, Inherited=false)]
public sealed class InAttribute : Attribute
[System.AttributeUsage(System.AttributeTargets.Parameter, Inherited=false)]
[System.Runtime.InteropServices.ComVisible(true)]
public sealed class InAttribute : Attribute
[<System.AttributeUsage(System.AttributeTargets.Parameter, Inherited=false)>]
type InAttribute = class
    inherit Attribute
[<System.AttributeUsage(System.AttributeTargets.Parameter, Inherited=false)>]
[<System.Runtime.InteropServices.ComVisible(true)>]
type InAttribute = class
    inherit Attribute
Public NotInheritable Class InAttribute
Inherits Attribute
Devralma
InAttribute
Öznitelikler

Örnekler

Aşağıdaki örnek, bir diziyi InAttribute parametre olarak geçiren bir platform çağırma prototipine ve'nin OutAttribute nasıl uygulanacağını gösterir. Yönlü özniteliklerin birleşimi, çağıranın çağrıyı yapan tarafından yapılan değişiklikleri görmesine olanak tanır.

using namespace System;
using namespace System::Runtime::InteropServices;

// Declare a class member for each structure element.

[StructLayout(LayoutKind::Sequential, CharSet = CharSet::Unicode)]
public ref class OpenFileName
{
public:
    int structSize;
    String^ filter;
    String^ file;
    // ...
};

private ref class NativeMethods
{
public:

    // Declare a managed prototype for the unmanaged function.

    [DllImport("Comdlg32.dll", CharSet = CharSet::Unicode)]
    static bool GetOpenFileName([In, Out]OpenFileName^ ofn);
};

void main() {}
using System.Runtime.InteropServices;
using System;

// Declare a class member for each structure element.
[StructLayout(LayoutKind.Sequential, CharSet = CharSet.Unicode)]
public class OpenFileName
{
    public int structSize = 0;
    public string filter = null;
    public string file = null;
    // ...
}

internal static class NativeMethods
{
    // Declare a managed prototype for the unmanaged function.
    [DllImport("Comdlg32.dll", CharSet = CharSet.Unicode)]
    internal static extern bool GetOpenFileName([In, Out] OpenFileName ofn);
}

public class MainMethod
{
    static void Main()
    { }
}
Imports System.Runtime.InteropServices

' Declare a class member for each structure element.
<StructLayout(LayoutKind.Sequential, CharSet:=CharSet.Unicode)>
Public Class OpenFileName

    Public structSize As Integer = 0
    Public filter As String = Nothing
    Public file As String = Nothing
    ' ...

End Class

Friend Class NativeMethods
    ' Declare managed prototype for the unmanaged function.
    Friend Declare Unicode Function GetOpenFileName Lib "Comdlg32.dll" (
       <[In](), Out()> ByVal ofn As OpenFileName) As Boolean
End Class

Public Class App
    Public Shared Sub Main()

    End Sub
End Class

Açıklamalar

Bu özniteliği parametrelere uygulayabilirsiniz.

InAttribute isteğe bağlıdır. özniteliği yalnızca COM birlikte çalışma ve platform çağırma için desteklenir. Açık ayarların olmaması halinde birlikte çalışma sıralayıcısı parametre türüne, parametrenin başvuru veya değere göre geçirilip geçirilmediğine ve türün blittable veya blittable olmayan olmasına göre kuralları varsayar. Örneğin, sınıfın StringBuilder her zaman In/Out olduğu varsayılır ve değer tarafından geçirilen dize dizisinin In olduğu varsayılır.

C#styled out anahtar sözcüğüyle değiştirilmiş bir parametreye uygulayamazsınızInAttribute. Visual Basic'te anahtar sözcüğün In , eksi Özniteliği ile InAttributekarıştırılmasını önlemek için, özniteliğin <[In]> etrafındaki köşeli ayraçlar içeren formu kullanın.

dizilere InAttribute ve biçimlendirilmiş, bölünebilir olmayan türlere uygulandığında ve OutAttribute birleştirildiğinde özellikle yararlıdır. Arayanlar, çağıranın bu türlerde yaptığı değişiklikleri yalnızca her iki özniteliği de uyguladığınızda görür. Bu türler hazırlama sırasında kopyalama gerektirdiğinden, gereksiz kopyaları azaltmak için ve OutAttribute kullanabilirsinizInAttribute.

Hazırlama davranışı üzerindeki etkisi InAttribute hakkında daha fazla bilgi için bkz . Yön Öznitelikleri.

Oluşturucular

InAttribute()

InAttribute sınıfının yeni bir örneğini başlatır.

Özellikler

TypeId

Türetilmiş bir sınıfta uygulandığında, bu Attributeiçin benzersiz bir tanımlayıcı alır.

(Devralındığı yer: Attribute)

Yöntemler

Equals(Object)

Bu örneğin belirtilen bir nesneye eşit olup olmadığını gösteren bir değeri döndürür.

(Devralındığı yer: Attribute)
GetHashCode()

Bu örneğe ilişkin karma kodu döndürür.

(Devralındığı yer: Attribute)
GetType()

Type Geçerli örneğini alır.

(Devralındığı yer: Object)
IsDefaultAttribute()

Türetilmiş bir sınıfta geçersiz kılındığında, bu örneğin değerinin türetilmiş sınıf için varsayılan değer olup olmadığını gösterir.

(Devralındığı yer: Attribute)
Match(Object)

Türetilmiş bir sınıfta geçersiz kılındığında, bu örneğin belirtilen bir nesneye eşit olup olmadığını gösteren bir değer döndürür.

(Devralındığı yer: Attribute)
MemberwiseClone()

Geçerli Objectöğesinin sığ bir kopyasını oluşturur.

(Devralındığı yer: Object)
ToString()

Geçerli nesneyi temsil eden dizeyi döndürür.

(Devralındığı yer: Object)

Belirtik Arabirim Kullanımları

_Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr)

Bir ad kümesini karşılık gelen bir dağıtma tanımlayıcısı kümesine eşler.

(Devralındığı yer: Attribute)
_Attribute.GetTypeInfo(UInt32, UInt32, IntPtr)

Bir arabirimin tür bilgilerini almak için kullanılabilecek bir nesnenin tür bilgilerini alır.

(Devralındığı yer: Attribute)
_Attribute.GetTypeInfoCount(UInt32)

Bir nesnenin sağladığı tür bilgisi arabirimlerinin sayısını alır (0 ya da 1).

(Devralındığı yer: Attribute)
_Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

Bir nesne tarafından sunulan özelliklere ve yöntemlere erişim sağlar.

(Devralındığı yer: Attribute)

Şunlara uygulanır

Ayrıca bkz.