• C# 中 New 关键词的几种用法


    前段时间一个朋友问到 C# 的 New 关键字有几种用法,虽说在日常编程中经常用到这个关键字,但它到底有几种用法还真没有留意过,现将从网上总结出的资料记下来。

    • new 运算符:用于创建对象和调用构造函数。
    • new 修饰符:用于隐藏基类成员的继承成员。
    • new 约束:用于在泛型声明中约束可能用作类型参数的参数的类型。

    一、new 运算符

    1、用于创建对象和调用构造函数

    Class_Test MyClass = new Class_Test();

    2、也用于为值类型调用默认的构造函数

    int myInt = new int();

    myInt 初始化为 0,它是 int 类型的默认值。该语句的效果等同于:int myInt = 0;

    3、不能重载 new 运算符。

    4、如果 new 运算符分配内存失败,则它将引发 OutOfMemoryException 异常。

    二、new 修饰符

    使用 new 修饰符显式隐藏从基类继承的成员。若要隐藏继承的成员,请使用相同名称在派生类中声明该成员,并用 new 修饰符修饰它。

    请看下面的类:

    public class MyClass
     {
         public int x;
      
         public void Invoke() {}
     }

    在派生类中用 Invoke 名称声明成员会隐藏基类中的 Invoke 方法,即:

    public class MyDerivedC : MyClass
    {
        new public void Invoke() {}
    }

    但是,因为字段 x 不是通过类似名隐藏的,所以不会影响该字段。

    通过继承隐藏名称采用下列形式之一:

    1、引入类或结构中的常数、指定、属性或类型隐藏具有相同名称的所有基类成员。

    2、引入类或结构中的方法隐藏基类中具有相同名称的属性、字段和类型。同时也隐藏具有相同签名的所有基类方法。

    3、引入类或结构中的索引器将隐藏具有相同名称的所有基类索引器。

    4、在同一成员上同时使用 new 和 override 是错误的。

    注意:在不隐藏继承成员的声明中使用 new 修饰符将生成警告。

    在下面的示例中,嵌套类 MyClass 隐藏了基类中具有相同名称的类。该例不仅说明了如何使用完全限定名访问隐藏类成员,同时也说明了如何使用 new 修饰符消除警告消息。

    using System;
    public class MyBaseC
    {
        public class MyClass
        {
            public int x = 200;
            public int y;
        }
    }
    public class MyDerivedC : MyBaseC
    {
        new public class MyClass // nested type hiding the base type members    
        {
            public int x = 100;
            public int y;
            public int z;
        }
        public static void Main()
        {
            // Creating object from the overlapping class:    
            MyClass S1 = new MyClass();
            // Creating object from the hidden class:    
            MyBaseC.MyClass S2 = new MyBaseC.MyClass();
            Console.WriteLine(S1.x);
            Console.WriteLine(S2.x);
        }
    }
  • 相关阅读:
    sql经典语句大全
    经典SQL语句大全
    Bat命令学习
    [Microsoft][ODBC 驱动程序管理器] 在指定的 DSN 中,驱动程序和应用程序之间的体系结构不匹配
    配置WebSite的IIS时遇到的问题与解决方法
    数据库SQL优化大总结之 百万级数据库优化方案
    数据库索引以及优化
    搭建android开发环境
    SQL2008根据日志恢复
    WebService处理大数据量数据
  • 原文地址:https://www.cnblogs.com/weisenz/p/2446482.html
Copyright © 2020-2023  润新知