Movatterモバイル変換


[0]ホーム

URL:


Skip to main contentSkip to in-page navigation

This browser is no longer supported.

Upgrade to Microsoft Edge to take advantage of the latest features, security updates, and technical support.

Download Microsoft EdgeMore info about Internet Explorer and Microsoft Edge
Table of contentsExit editor mode

Nullable<T> Struct

Definition

Namespace:
System
Assemblies:
mscorlib.dll, System.Runtime.dll
Assemblies:
netstandard.dll, System.Runtime.dll
Assembly:
System.Runtime.dll
Assembly:
mscorlib.dll
Assembly:
netstandard.dll
Source:
Nullable.cs
Source:
Nullable.cs
Source:
Nullable.cs
Source:
Nullable.cs

Important

Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.

Represents a value type that can be assignednull.

generic <typename T> where T : value classpublic value class Nullable
public struct Nullable<T> where T : struct
[System.Serializable]public struct Nullable<T> where T : struct
type Nullable<'T (requires 'T : struct)> = struct
[<System.Serializable>]type Nullable<'T (requires 'T : struct)> = struct
Public Structure Nullable(Of T)

Type Parameters

T

The underlying value type of theNullable<T> generic type.

Inheritance
Nullable<T>
Attributes

Examples

The following code example defines three rows of a table in the Microsoft Pubs sample database. The table contains two columns that are not nullable and two columns that are nullable.

using System;class Sample{    // Define the "titleAuthor" table of the Microsoft "pubs" database.    public struct titleAuthor    {      // Author ID; format ###-##-####      public string au_id;      // Title ID; format AA####      public string title_id;      // Author ORD is nullable.      public short? au_ord;      // Royalty Percent is nullable.      public int? royaltyper;    }    public static void Main()    {      // Declare and initialize the titleAuthor array.      titleAuthor[] ta = new titleAuthor[3];      ta[0].au_id = "712-32-1176";      ta[0].title_id = "PS3333";      ta[0].au_ord = 1;      ta[0].royaltyper = 100;      ta[1].au_id = "213-46-8915";      ta[1].title_id = "BU1032";      ta[1].au_ord = null;      ta[1].royaltyper = null;      ta[2].au_id = "672-71-3249";      ta[2].title_id = "TC7777";      ta[2].au_ord = null;      ta[2].royaltyper = 40;      // Display the values of the titleAuthor array elements, and      // display a legend.      Display("Title Authors Table", ta);      Console.WriteLine("Legend:");      Console.WriteLine("An Author ORD of -1 means no value is defined.");      Console.WriteLine("A Royalty % of 0 means no value is defined.");    }    // Display the values of the titleAuthor array elements.    public static void Display(string dspTitle,                               titleAuthor[] dspAllTitleAuthors)    {      Console.WriteLine("*** {0} ***", dspTitle);      foreach (titleAuthor dspTA in dspAllTitleAuthors) {         Console.WriteLine("Author ID ... {0}", dspTA.au_id);         Console.WriteLine("Title ID .... {0}", dspTA.title_id);         Console.WriteLine("Author ORD .. {0}", dspTA.au_ord ?? -1);         Console.WriteLine("Royalty % ... {0}", dspTA.royaltyper ?? 0);         Console.WriteLine();      }    }}// The example displays the following output://     *** Title Authors Table ***//     Author ID ... 712-32-1176//     Title ID .... PS3333//     Author ORD .. 1//     Royalty % ... 100////     Author ID ... 213-46-8915//     Title ID .... BU1032//     Author ORD .. -1//     Royalty % ... 0////     Author ID ... 672-71-3249//     Title ID .... TC7777//     Author ORD .. -1//     Royalty % ... 40////     Legend://     An Author ORD of -1 means no value is defined.//     A Royalty % of 0 means no value is defined.
open System// Define the "titleAuthor" table of the Microsoft "pubs" database.type titleAuthor =  struct    // Author ID format ###-##-####    val mutable au_id: string    // Title ID format AA####    val mutable title_id: string    // Author ORD is nullable.    val mutable au_ord: Nullable<int16>    // Royalty Percent is nullable.    val mutable royaltyper: Nullable<int>  end// Display the values of the titleAuthor array elements.let display dspTitle (dspAllTitleAuthors: #seq<titleAuthor>) =    printfn $"*** {dspTitle} ***"    for dspTA in dspAllTitleAuthors do        printfn $"Author ID ... {dspTA.au_id}"        printfn $"Title ID .... {dspTA.title_id}"        printfn $"Author ORD .. {dspTA.au_ord.GetValueOrDefault -1s}"        printfn $"Royalty %% ... {dspTA.royaltyper.GetValueOrDefault -1}\n"// Declare and initialize the titleAuthor array.let ta = Array.zeroCreate<titleAuthor> 3ta[0].au_id <- "712-32-1176"ta[0].title_id <- "PS3333"ta[0].au_ord <- Nullable 1sta[0].royaltyper <- Nullable 100ta[1].au_id <- "213-46-8915"ta[1].title_id <- "BU1032"ta[1].au_ord <- Nullable()ta[1].royaltyper <- Nullable()ta[2].au_id <- "672-71-3249"ta[2].title_id <- "TC7777"ta[2].au_ord <- Nullable()ta[2].royaltyper <- Nullable 40// Display the values of the titleAuthor array elements, and// display a legend.display "Title Authors Table" taprintfn "Legend:"printfn "An Author ORD of -1 means no value is defined."printfn "A Royalty %% of 0 means no value is defined."// The example displays the following output://     *** Title Authors Table ***//     Author ID ... 712-32-1176//     Title ID .... PS3333//     Author ORD .. 1//     Royalty % ... 100////     Author ID ... 213-46-8915//     Title ID .... BU1032//     Author ORD .. -1//     Royalty % ... 0////     Author ID ... 672-71-3249//     Title ID .... TC7777//     Author ORD .. -1//     Royalty % ... 40////     Legend://     An Author ORD of -1 means no value is defined.//     A Royalty % of 0 means no value is defined.
Class Sample    ' Define the "titleAuthor" table of the Microsoft "pubs" database.     Public Structure titleAuthor       ' Author ID; format ###-##-####        Public au_id As String        ' Title ID; format AA####        Public title_id As String        ' Author ORD is nullable.        Public au_ord As Nullable(Of Short)        ' Royalty Percent is nullable.        Public royaltyper As Nullable(Of Integer)    End Structure         Public Shared Sub Main()        ' Declare and initialize the titleAuthor array.        Dim ta(2) As titleAuthor        ta(0).au_id = "712-32-1176"        ta(0).title_id = "PS3333"        ta(0).au_ord = 1        ta(0).royaltyper = 100                ta(1).au_id = "213-46-8915"        ta(1).title_id = "BU1032"        ta(1).au_ord = Nothing        ta(1).royaltyper = Nothing                ta(2).au_id = "672-71-3249"        ta(2).title_id = "TC7777"        ta(2).au_ord = Nothing        ta(2).royaltyper = 40               ' Display the values of the titleAuthor array elements, and        ' display a legend.        Display("Title Authors Table", ta)        Console.WriteLine("Legend:")        Console.WriteLine("An Author ORD of -1 means no value is defined.")        Console.WriteLine("A Royalty % of 0 means no value is defined.")    End Sub        ' Display the values of the titleAuthor array elements.    Public Shared Sub Display(ByVal dspTitle As String, _                              ByVal dspAllTitleAuthors() As titleAuthor)         Console.WriteLine("*** {0} ***", dspTitle)        Dim dspTA As titleAuthor        For Each dspTA In dspAllTitleAuthors            Console.WriteLine("Author ID ... {0}", dspTA.au_id)            Console.WriteLine("Title ID .... {0}", dspTA.title_id)            Console.WriteLine("Author ORD .. {0}", dspTA.au_ord.GetValueOrDefault(-1))            Console.WriteLine("Royalty % ... {0}", dspTA.royaltyper.GetValueOrDefault(0))            Console.WriteLine()        Next     End SubEnd Class 'This example displays the following output:'     *** Title Authors Table ***'     Author ID ... 712-32-1176'     Title ID .... PS3333'     Author ORD .. 1'     Royalty % ... 100'     '     Author ID ... 213-46-8915'     Title ID .... BU1032'     Author ORD .. -1'     Royalty % ... 0'     '     Author ID ... 672-71-3249'     Title ID .... TC7777'     Author ORD .. -1'     Royalty % ... 40'     '     Legend:'     An Author ORD of -1 means no value is defined.'     A Royalty % of 0 means no value is defined.

Remarks

For more information about this API, seeSupplemental API remarks for Nullable<T>.

Constructors

NameDescription
Nullable<T>(T)

Initializes a new instance of theNullable<T> structure to the specified value.

Properties

NameDescription
HasValue

Gets a value indicating whether the currentNullable<T> object has a valid value of its underlying type.

Value

Gets the value of the currentNullable<T> object if it has been assigned a valid underlying value.

Methods

NameDescription
Equals(Object)

Indicates whether the currentNullable<T> object is equal to a specified object.

GetHashCode()

Retrieves the hash code of the object returned by theValue property.

GetValueOrDefault()

Retrieves the value of the currentNullable<T> object, or the default value of the underlying type.

GetValueOrDefault(T)

Retrieves the value of the currentNullable<T> object, or the specified default value.

ToString()

Returns the text representation of the value of the currentNullable<T> object.

Operators

NameDescription
Explicit(Nullable<T> to T)

Defines an explicit conversion of aNullable<T> instance to its underlying value.

Implicit(T to Nullable<T>)

Creates a newNullable<T> object initialized to a specified value.

Applies to

See also

Collaborate with us on GitHub
The source for this content can be found on GitHub, where you can also create and review issues and pull requests. For more information, seeour contributor guide.

Feedback

Was this page helpful?

YesNoNo

Need help with this topic?

Want to try using Ask Learn to clarify or guide you through this topic?

Suggest a fix?

In this article

Was this page helpful?

YesNo
NoNeed help with this topic?

Want to try using Ask Learn to clarify or guide you through this topic?

Suggest a fix?