null (C# リファレンス)

更新 : 2008 年 7 月

null キーワードは、null 参照を表すリテラル キーワードです。null 参照はオブジェクトを一切参照しません。null は参照型変数の既定値です。値型には、通常、null を設定できません。しかし、C# 2.0 には、値型に null を設定できるようにする方法が用意されています。null 許容型 (C# プログラミング ガイド) を参照してください。

null キーワードの動作を示す例を次に示します。

class Program
    class MyClass
        public void MyMethod() { }

    static void Main(string[] args)
        // Set a breakpoint here to see that mc = null.
        // However, the compiler considers it "unassigned."
        // and generates a compiler error if you try to
        // use the variable.
        MyClass mc;

        // Now the variable can be used, but...
        mc = null;

        // ... a method call on a null object raises 
        // a run-time NullReferenceException.
        // Uncomment the following line to see for yourself.
        // mc.MyMethod();

        // Now mc has a value.
        mc = new MyClass();

        // You can call its method.

        // Set mc to null again. The object it referenced
        // is no longer accsessible and can now be garbage-collected.
        mc = null;

        // A null string is not the same as an empty string.
        string s = null;
        string t = String.Empty; // Logically the same as ""

        // Equals applied to any null object returns false.
        bool b = (t.Equals(s));

        // Equality operator also returns false when one
        // operand is null.
        Console.WriteLine("Empty string {0} null string", s == t ? "equals": "does not equal");

        // Returns true.
        Console.WriteLine("null == null is {0}", null == null);

        // A value type cannot be null
        // int i = null; // Compiler error!

        // Use a nullable value type instead:
        int? i = null;

        // Keep the console window open in debug mode.
        System.Console.WriteLine("Press any key to exit.");


C# 言語仕様

詳細については、「C# 言語仕様」の次のセクションを参照してください。

  • null リテラル



C# プログラミング ガイド


C# のキーワード

リテラル キーワード (C# リファレンス)


C# リファレンス

既定値の一覧表 (C# リファレンス)





2008 年 7 月


コンテンツ バグ修正