Condividi tramite


NSNumber Costruttori

Definizione

Overload

NSNumber(NSCoder)

Costruttore che inizializza l'oggetto dai dati archiviati nell'oggetto unrchiver.

NSNumber(UInt64)
NSNumber(UInt32)
NSNumber(UInt16)
NSNumber(Single)
NSNumber(SByte)
NSNumber(nuint)
NSNumber(nint)
NSNumber(nfloat)
NSNumber(Int64)
NSNumber(Int32)
NSNumber(Int16)
NSNumber(Double)
NSNumber(Byte)
NSNumber(Boolean)
NSNumber(NSObjectFlag)

Costruttore per chiamare classi derivate per ignorare l'inizializzazione e allocare semplicemente l'oggetto.

NSNumber(IntPtr)

Costruttore usato durante la creazione di rappresentazioni gestite di oggetti non gestiti; Chiamato dal runtime.

NSNumber(NSCoder)

Costruttore che inizializza l'oggetto dai dati archiviati nell'oggetto unrchiver.

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

Parametri

coder
NSCoder

Oggetto unarchiver.

Attributi

Commenti

Questo costruttore viene fornito per consentire l'inizializzazione della classe da un nonrchiver (ad esempio durante la deserializzazione nib). Fa parte del NSCoding protocollo.

Se gli sviluppatori vogliono creare una sottoclasse di questo oggetto e continuare a supportare la deserializzazione da un archivio, devono implementare un costruttore con una firma identica: prendere un singolo parametro di tipo NSCoder e decorarlo con la dichiarazione di attributo [Export("initWithCoder:"].

Lo stato di questo oggetto può essere serializzato anche usando il metodo complementare CodificaTo.

Si applica a

NSNumber(UInt64)

[Foundation.Export("initWithUnsignedLongLong:")]
[ObjCRuntime.DesignatedInitializer]
public NSNumber (ulong value);
new Foundation.NSNumber : uint64 -> Foundation.NSNumber

Parametri

value
UInt64
Attributi

Si applica a

NSNumber(UInt32)

[Foundation.Export("initWithUnsignedInt:")]
[ObjCRuntime.DesignatedInitializer]
public NSNumber (uint value);
new Foundation.NSNumber : uint32 -> Foundation.NSNumber

Parametri

value
UInt32
Attributi

Si applica a

NSNumber(UInt16)

[Foundation.Export("initWithUnsignedShort:")]
[ObjCRuntime.DesignatedInitializer]
public NSNumber (ushort value);
new Foundation.NSNumber : uint16 -> Foundation.NSNumber

Parametri

value
UInt16
Attributi

Si applica a

NSNumber(Single)

[Foundation.Export("initWithFloat:")]
[ObjCRuntime.DesignatedInitializer]
public NSNumber (float value);
new Foundation.NSNumber : single -> Foundation.NSNumber

Parametri

value
Single
Attributi

Si applica a

NSNumber(SByte)

[Foundation.Export("initWithChar:")]
[ObjCRuntime.DesignatedInitializer]
public NSNumber (sbyte value);
new Foundation.NSNumber : sbyte -> Foundation.NSNumber

Parametri

value
SByte
Attributi

Si applica a

NSNumber(nuint)

[Foundation.Export("initWithUnsignedInteger:")]
[ObjCRuntime.DesignatedInitializer]
public NSNumber (nuint value);
new Foundation.NSNumber : nuint -> Foundation.NSNumber

Parametri

value
System.System.UIntPtr System.unativeint
Attributi

Si applica a

NSNumber(nint)

[Foundation.Export("initWithInteger:")]
[ObjCRuntime.DesignatedInitializer]
public NSNumber (nint value);
new Foundation.NSNumber : nint -> Foundation.NSNumber

Parametri

value
System.System.IntPtr System.nativeint
Attributi

Si applica a

NSNumber(nfloat)

public NSNumber (nfloat value);
new Foundation.NSNumber : nfloat -> Foundation.NSNumber

Parametri

value
nfloat

Si applica a

NSNumber(Int64)

[Foundation.Export("initWithLongLong:")]
[ObjCRuntime.DesignatedInitializer]
public NSNumber (long value);
new Foundation.NSNumber : int64 -> Foundation.NSNumber

Parametri

value
Int64
Attributi

Si applica a

NSNumber(Int32)

[Foundation.Export("initWithInt:")]
[ObjCRuntime.DesignatedInitializer]
public NSNumber (int value);
new Foundation.NSNumber : int -> Foundation.NSNumber

Parametri

value
Int32
Attributi

Si applica a

NSNumber(Int16)

[Foundation.Export("initWithShort:")]
[ObjCRuntime.DesignatedInitializer]
public NSNumber (short value);
new Foundation.NSNumber : int16 -> Foundation.NSNumber

Parametri

value
Int16
Attributi

Si applica a

NSNumber(Double)

[Foundation.Export("initWithDouble:")]
[ObjCRuntime.DesignatedInitializer]
public NSNumber (double value);
new Foundation.NSNumber : double -> Foundation.NSNumber

Parametri

value
Double
Attributi

Si applica a

NSNumber(Byte)

[Foundation.Export("initWithUnsignedChar:")]
[ObjCRuntime.DesignatedInitializer]
public NSNumber (byte value);
new Foundation.NSNumber : byte -> Foundation.NSNumber

Parametri

value
Byte
Attributi

Si applica a

NSNumber(Boolean)

[Foundation.Export("initWithBool:")]
[ObjCRuntime.DesignatedInitializer]
public NSNumber (bool value);
new Foundation.NSNumber : bool -> Foundation.NSNumber

Parametri

value
Boolean
Attributi

Si applica a

NSNumber(NSObjectFlag)

Costruttore per chiamare classi derivate per ignorare l'inizializzazione e allocare semplicemente l'oggetto.

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

Parametri

t
NSObjectFlag

Valore sentinel inutilizzato, passare NSObjectFlag.Empty.

Commenti

Questo costruttore deve essere chiamato dalle classi derivate quando costruiscono completamente l'oggetto nel codice gestito e vogliono semplicemente che il runtime alloca e inizializzi NSObject. È necessario implementare il processo di inizializzazione in due passaggi usato da Objective-C, il primo passaggio consiste nell'eseguire l'allocazione dell'oggetto, il secondo passaggio consiste nell'inizializzare l'oggetto. Quando gli sviluppatori richiamano il costruttore che accetta nSObjectFlag.Empty sfruttano un percorso diretto che passa fino a NSObject per allocare semplicemente la memoria dell'oggetto e associare insieme gli oggetti Objective-C e C#. L'inizializzazione effettiva dell'oggetto è fino allo sviluppatore.

Questo costruttore viene in genere usato dal generatore di associazione per allocare l'oggetto, ma impedisce che venga eseguita l'inizializzazione effettiva. Dopo aver eseguito l'allocazione, il costruttore deve inizializzare l'oggetto. Con i costruttori generati dal generatore di binding questo significa che richiama manualmente uno dei metodi "init" per inizializzare l'oggetto.

È responsabilità dello sviluppatore inizializzare completamente l'oggetto se si concatenano usando il percorso NSObjectFlag.Empty.

In generale, se il costruttore dello sviluppatore richiama l'implementazione di base NSObjectFlag.Empty, deve chiamare un metodo Objective-C init. In caso contrario, gli sviluppatori devono invece concatenare il costruttore appropriato nella propria classe.

Il valore dell'argomento viene ignorato e garantisce semplicemente che l'unico codice eseguito sia la fase di costruzione sia l'allocazione NSObject di base e la registrazione del tipo di runtime. In genere il concatenamento sarà simile al seguente:

//
// 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);
}

Si applica a

NSNumber(IntPtr)

Costruttore usato durante la creazione di rappresentazioni gestite di oggetti non gestiti; Chiamato dal runtime.

protected internal NSNumber (IntPtr handle);
new Foundation.NSNumber : nativeint -> Foundation.NSNumber

Parametri

handle
IntPtr

nativeint

Puntatore (handle) all'oggetto non gestito.

Commenti

Questo costruttore viene richiamato dall'infrastruttura di runtime (GetNSObject(IntPtr)) per creare una nuova rappresentazione gestita per un puntatore a un oggetto Objective-C non gestito. Gli sviluppatori non devono richiamare direttamente questo metodo, invece devono chiamare il metodo GetNSObject perché impedirà due istanze di un oggetto gestito per puntare allo stesso oggetto nativo.

Si applica a