// 1)用于创建对象和调用构造函数。例如: Class1 o = new Class1(); new 运算符还用于调用值类型的默认构造函数。例如: int i = new int(); 在上一个语句中,i 初始化为 0,它是 int 类型的默认值。该语句的效果等同于: int i = 0; // 2)在用作修饰符时,new 关键字可以显式隐藏从基类继承的成员。隐藏继承的成员意味着该成员的派生版本将替换基类版本。在不使用 new 修饰符的情况下隐藏成员是允许的,但会生成警告。使用 new 显式隐藏成员会取消此警告,并记录代之以派生版本这一事实。 若要隐藏继承的成员,请使用相同名称在派生类中声明该成员,并使用 new 修饰符修饰该成员。例如: public class BaseC { public int x; public void Invoke() {} } public class DerivedC : BaseC { new public void Invoke() {} } 在此示例中,DerivedC.Invoke 隐藏了 BaseC.Invoke。字段 x 不受影响,因为它没有被类似名称的字段隐藏。 通过继承隐藏名称采用下列形式之一: 引入类或结构中的常数、指定、属性或类型隐藏具有相同名称的所有基类成员。 引入类或结构中的方法隐藏基类中具有相同名称的属性、字段和类型。同时也隐藏具有相同签名的所有基类方法。 引入类或结构中的索引器将隐藏具有相同名称的所有基类索引器。 对同一成员同时使用 new 和 override 是错误的,因为这两个修饰符在含义上相互排斥。使用 new 会用同样的名称创建一个新成员并使原始成员变为隐藏的,而 override 则扩展继承成员的实现。 在不隐藏继承成员的声明中使用 new 修饰符将会生成警告。 示例 在该例中,基类 BaseC 和派生类 DerivedC 使用相同的字段名 x,从而隐藏了继承字段的值。该示例演示了 new 修饰符的用法。另外还演示了如何使用完全限定名访问基类的隐藏成员。 复制代码 // cs_modifier_new.cs // The new modifier. using System; public class BaseC { public static int x = 55; public static int y = 22; } public class DerivedC : BaseC { // Hide field 'x' new public static int x = 100; static void Main() { // Display the new value of x: Console.WriteLine(x); // Display the hidden value of x: Console.WriteLine(BaseC.x); // Display the unhidden member y: Console.WriteLine(y); } } 作者添加: 输出结果为: 100 55 22 // 3)new 约束指定泛型类声明中的任何类型参数都必须有公共的无参数构造函数。当泛型类创建类型的新实例时,将此约束应用于类型参数,如下面的示例所示: class ItemFactory<T> where T : new() { public T GetNewItem() { return new T(); } } 当与其他约束一起使用时,new() 约束必须最后指定: 复制代码 using System; public class ItemFactory<T> where T : IComparable, new() { } //到此结束 1本文由jvdlvcjpyf贡献 本文由iamzhangyu贡献 // 1)用于创建对象和调用构造函数。例如: Class1 o = new Class1(); new 运算符还用于调用值类型的默认构造函数。例如: int i = new int(); 在上一个语句中,i 初始化为 0,它是 int 类型的默认值。该语句的效果等同于: int i = 0; // 2)在用作修饰符时,new 关键字可以显式隐藏从基类继承的成员。隐藏继承的成员意味着该成员的派生版本将替换基类版本。在不使用 new 修饰符的情况下隐藏成员是允许的,但会生成警告。使用 new 显式隐藏成员会取消此警告,并记录代之以派生版本这一事实。 若要隐藏继承的成员,请使用相同名称在派生类中声明该成员,并使用 new 修饰符修饰该成员。例如: public class BaseC { public int x; public void Invoke() {} } public class DerivedC : BaseC { new public void Invoke() {} } 在此示例中,DerivedC.Invoke 隐藏了 BaseC.Invoke。字段 x 不受影响,因为它没有被类似名称的字段隐藏。 通过继承隐藏名称采用下列形式之一: 引入类或结构中的常数、指定、属性或类型隐藏具有相同名称的所有基类成员。 引入类或结构中的方法隐藏基类中具有相同名称的属性、字段和类型。同时也隐藏具有相同签名的所有基类方法。 引入类或结构中的索引器将隐藏具有相同名称的所有基类索引器。 对同一成员同时使用 new 和 override 是错误的,因为这两个修饰符在含义上相互排斥。使用 new 会用同样的名称创建一个新成员并使原始成员变为隐藏的,而 override 则扩展继承成员的实现。 在不隐藏继承成员的声明中使用 new 修饰符将会生成警告。 示例 在该例中,基类 BaseC 和派生类 DerivedC 使用相同的字段名 x,从而隐藏了继承字段的值。该示例演示了 new 修饰符的用法。另外还演示了如何使用完全限定名访问基类的隐藏成员。 复制代码 // cs_modifier_new.cs // The new modifier. using System; public class BaseC { public static int x = 55; public static int y = 22; } public class DerivedC : BaseC { // Hide field 'x' new public static int x = 100; static void Main() { // Display the new value of x: Console.WriteLine(x); // Display the hidden value of x: Console.WriteLine(BaseC.x); // Display the unhidden member y: Console.WriteLine(y); } } 作者添加: 输出结果为: 100 55 22 // 3)new 约束指定泛型类声明中的任何类型参数都必须有公共的无参数构造函数。当泛型类创建类型的新实例时,将此约束应用于类型参数,如下面的示例所示: class ItemFactory<T> where T : new() { public T GetNewItem() { return new T(); } } 当与其他约束一起使用时,new() 约束必须最后指定: 复制代码 using System; public class ItemFactory<T> where T : IComparable, new() { } //到此结束