Compartilhar via


INPersonHandle Construtores

Definição

Sobrecargas

INPersonHandle(NSCoder)

Um construtor que inicializa o objeto dos dados armazenados no objeto unarchiver.

INPersonHandle(NSObjectFlag)

Construtor para chamar em classes derivadas para ignorar a inicialização e simplesmente alocar o objeto.

INPersonHandle(IntPtr)

Um construtor usado ao criar representações gerenciadas de objetos não gerenciados; Chamado pelo runtime.

INPersonHandle(String, INPersonHandleType)

Cria um novo identificador de pessoa com os detalhes especificados.

INPersonHandle(String, INPersonHandleType, NSString)

Cria um novo identificador de pessoa com os detalhes especificados.

INPersonHandle(String, INPersonHandleType, INPersonHandleLabel)

Cria um novo identificador de pessoa com os detalhes especificados.

INPersonHandle(NSCoder)

Um construtor que inicializa o objeto dos dados armazenados no objeto unarchiver.

[Foundation.Export("initWithCoder:")]
[ObjCRuntime.DesignatedInitializer]
public INPersonHandle (Foundation.NSCoder coder);
new Intents.INPersonHandle : Foundation.NSCoder -> Intents.INPersonHandle

Parâmetros

coder
NSCoder

O objeto unarchiver.

Atributos

Comentários

Esse construtor é fornecido para permitir que a classe seja inicializada de um unarchiver (por exemplo, durante a desserialização nib). Isso faz parte do NSCoding protocolo.

Se os desenvolvedores quiserem criar uma subclasse desse objeto e continuar a dar suporte à desserialização de um arquivo morto, eles deverão implementar um construtor com uma assinatura idêntica: pegar um único parâmetro do tipo NSCoder e decorá-lo com a declaração de atributo [Export("initWithCoder:"].

O estado desse objeto também pode ser serializado usando o método complementar EncodeTo.

Aplica-se a

INPersonHandle(NSObjectFlag)

Construtor para chamar em classes derivadas para ignorar a inicialização e simplesmente alocar o objeto.

protected INPersonHandle (Foundation.NSObjectFlag t);
new Intents.INPersonHandle : Foundation.NSObjectFlag -> Intents.INPersonHandle

Parâmetros

t
NSObjectFlag

Valor sentinela não utilizado, passe NSObjectFlag.Empty.

Comentários

Esse construtor deve ser chamado por classes derivadas quando eles constroem completamente o objeto no código gerenciado e apenas querem que o runtime aloque e inicialize o NSObject. Isso é necessário para implementar o processo de inicialização em duas etapas que Objective-C usa, a primeira etapa é executar a alocação de objeto, a segunda etapa é inicializar o objeto. Quando os desenvolvedores invocam o construtor que usa o NSObjectFlag.Empty, eles aproveitam um caminho direto que vai até NSObject para simplesmente alocar a memória do objeto e associar os objetos Objective-C e C#. A inicialização real do objeto cabe ao desenvolvedor.

Esse construtor normalmente é usado pelo gerador de associação para alocar o objeto, mas impede que a inicialização real ocorra. Depois que a alocação tiver ocorrido, o construtor precisará inicializar o objeto . Com construtores gerados pelo gerador de associação, isso significa que ele invoca manualmente um dos métodos "init" para inicializar o objeto.

É responsabilidade do desenvolvedor inicializar completamente o objeto se ele se encadear usando o caminho NSObjectFlag.Empty.

Em geral, se o construtor do desenvolvedor invocar a implementação base NSObjectFlag.Empty, ele deverá chamar um método objective-C init. Se esse não for o caso, os desenvolvedores deverão encadear o construtor adequado em sua classe.

O valor do argumento é ignorado e apenas garante que o único código executado seja a fase de construção é a alocação básica de NSObject e o registro de tipo de runtime. Normalmente, o encadeamento teria esta aparência:

//
// The NSObjectFlag merely allocates the object and registers the
// C# class with the Objective-C runtime if necessary, but no actual
// initXxx method is invoked, that is done later in the constructor
//
// This is taken from Xamarin.iOS's source code:
//
[Export ("initWithFrame:")]
public UIView (System.Drawing.RectangleF frame) : base (NSObjectFlag.Empty)
{
// Invoke the init method now.
	var initWithFrame = new Selector ("initWithFrame:").Handle;
	if (IsDirectBinding)
		Handle = ObjCRuntime.Messaging.IntPtr_objc_msgSend_CGRect (this.Handle, initWithFrame, frame);
	else
		Handle = ObjCRuntime.Messaging.IntPtr_objc_msgSendSuper_CGRect (this.SuperHandle, initWithFrame, frame);
}

Aplica-se a

INPersonHandle(IntPtr)

Um construtor usado ao criar representações gerenciadas de objetos não gerenciados; Chamado pelo runtime.

protected internal INPersonHandle (IntPtr handle);
new Intents.INPersonHandle : nativeint -> Intents.INPersonHandle

Parâmetros

handle
IntPtr

nativeint

Ponteiro (identificador) para o objeto não gerenciado.

Comentários

Esse construtor é invocado pela infraestrutura de runtime (GetNSObject(IntPtr)) para criar uma nova representação gerenciada para um ponteiro para um objeto Objective-C não gerenciado. Os desenvolvedores não devem invocar esse método diretamente, em vez disso, devem chamar o método GetNSObject, pois ele impedirá que duas instâncias de um objeto gerenciado apontem para o mesmo objeto nativo.

Aplica-se a

INPersonHandle(String, INPersonHandleType)

Cria um novo identificador de pessoa com os detalhes especificados.

[Foundation.Export("initWithValue:type:")]
public INPersonHandle (string value, Intents.INPersonHandleType type);
new Intents.INPersonHandle : string * Intents.INPersonHandleType -> Intents.INPersonHandle

Parâmetros

value
String

A ser adicionado.

Esse parâmetro pode ser null.

Atributos

Aplica-se a

INPersonHandle(String, INPersonHandleType, NSString)

Cria um novo identificador de pessoa com os detalhes especificados.

[Foundation.Export("initWithValue:type:label:")]
[ObjCRuntime.DesignatedInitializer]
[ObjCRuntime.Introduced(ObjCRuntime.PlatformName.iOS, 10, 2, ObjCRuntime.PlatformArchitecture.All, null)]
[ObjCRuntime.Introduced(ObjCRuntime.PlatformName.MacOSX, 10, 12, 2, ObjCRuntime.PlatformArchitecture.Arch64, null)]
protected INPersonHandle (string value, Intents.INPersonHandleType type, Foundation.NSString stringLabel);
new Intents.INPersonHandle : string * Intents.INPersonHandleType * Foundation.NSString -> Intents.INPersonHandle

Parâmetros

value
String

A ser adicionado.

Esse parâmetro pode ser null.

stringLabel
NSString

A ser adicionado.

Esse parâmetro pode ser null.

Atributos

Aplica-se a

INPersonHandle(String, INPersonHandleType, INPersonHandleLabel)

Cria um novo identificador de pessoa com os detalhes especificados.

[ObjCRuntime.Introduced(ObjCRuntime.PlatformName.iOS, 10, 2, ObjCRuntime.PlatformArchitecture.All, null)]
[ObjCRuntime.Introduced(ObjCRuntime.PlatformName.MacOSX, 10, 12, 2, ObjCRuntime.PlatformArchitecture.Arch64, null)]
public INPersonHandle (string value, Intents.INPersonHandleType type, Intents.INPersonHandleLabel label);
new Intents.INPersonHandle : string * Intents.INPersonHandleType * Intents.INPersonHandleLabel -> Intents.INPersonHandle

Parâmetros

value
String
Atributos

Aplica-se a