C# 主要运算符中的成员访问

在开发过程中,我遇到了一种null 条件成员访问的写法,开始不太理解,之后专门查了微软的官方文档,下面是具体内容:

    三种成员访问的三种形式

(1)x.y:成员访问。

(2)x?.y:null 条件成员访问。 如果左操作数计算结果为 null,则返回 null

(3)x?[y]:null 条件数组元素或类型索引器访问。 如果左操作数计算结果为 null,则返回 null。  

其中,我主要介绍一下第二和第三种,x?.y以及x?[y]的语法:Null 条件运算符在 C# 6 及更高版本中可用,仅当操作数的计算结果为非 null 时,null 条件运算符才会将成员访问 ?. 或元素访问 ?[] 运算应用于其操作数。 如果操作数的计算结果为 null,则应用运算符的结果为 null。 Null 条件成员访问运算符 ?. 也称为 Elvis 运算符。更多

具体实例:

  

namespace ConsoleApp_Test
{
    delegate int NumChange(int n);//定义委托
    class Program
    {
        static int num = 10;
        public static int AddNum(int n)
        {
            num += n;
            return num;
        }

        static void Main(string[] args)
        {
            //委托是null时
            NumChange nc = new NumChange(AddNum);
            nc = null;
            int? result = nc?.Invoke(1);

            //委托不为null时
            NumChange nc1 = new NumChange(AddNum);
            int? result1 = nc1?.Invoke(1);

            //输出结果
            Console.WriteLine(string.Format("第一个结果:{0},第二个结果:{1}", result, result1));

            Console.ReadKey();
        }

    }
}

  总结:Null 条件运算符在 C# 6 及更高版本中可用,主要应用在委托为空的判断,保证线程安全。

以上就是今天分享的内容,希望可以帮助大家!

原文地址:https://www.cnblogs.com/cjygrow/p/10993917.html

时间: 2024-11-06 17:39:11

C# 主要运算符中的成员访问的相关文章

C++ Primer笔记12_运算符重载_递增递减运算符_成员访问运算符

1.递增递减运算符 C++语言并不要求递增递减运算符必须是类的成员.但是因为他们改变的正好是所操作对象的状态,所以建议设定为成员函数. 对于递增与递减运算符来说,有前置与后置两个版本,因此,我们应该为类定义两个版本的递增与递减运算符. 问题来了,程序是如何区分前置和后置呢?因为都是++和-- 为了解决这个问题,后置版本的递增递减运算符接受一个额外的(不被使用)int类型的形参.当我们使用后置运算符时,编译器为这个形参提供一个值为0的实参.这个形参唯一的作用就是区分前置和后置运算符函数. 因为不会

【转】C++对成员访问运算符->的重载

运算符->的重载比较特别,它只能是非静态的成员函数形式,而且没有参数. 1.如果返回值是一个原始指针,那么就将运算符的右操作数当作这个原始指针所指向类型的成员进行访问: 2.如果返回值是另一个类型的实例,那么就继续调用这个返回类型的operator->(),直到有一个调用返回一个原始指针为止,然后按第一种情况处理. 如果上述条件不满足(如:右操作数不是返回的原始指针指向的类型中的成员,或者,返回的非指针类型(另一个类型的实例)没有重载operator->()),那么编译将报错. 以下是用

重载运算与类型转换——基本概念,输入和输出运算符,算术和关系运算符,赋值运算符,下标运算符,递增和递减运算符,成员访问运算符

一.基本概念 重载的运算符时具有特殊名字的函数:它们的名字由关键字operator和其后要定义的运算符号共同组成.和其他函数一样,重载的运算符也包含返回类型.参数列表以及函数体. 重载运算符函数的参数数量与该运算符作用的运算对象数量一样多.一元运算符有一个参数,二元运算符有两个.对于二元运算符来说,左侧运算对象传递给第一个参数,而右侧运算对象传递给第二个参数.除了重载的函数调用运算符operator()之外,其他重载运算符不能含有默认实参. 当一个重载的运算符时成员函数时,this绑定到左侧运算

C++学习笔记(十一):成员访问运算符(点运算和箭头运算)

成员访问运算符 点运算符"."和箭头运算符"->",都可以用于访问成员,其中点运算获取类对象的一个成员,箭头运算获取指针指向对象的成员.表达式ptr->men等价于(*ptr).mem: string s = "hello",  *p = &s; auto n = s.size();                        //获取string对象的成员 n = (*p).size();                

JavaSE8基础 当父类与子类中的成员变量重名了,使用super.名字 来访问父类的成员变量

os :windows7 x64    jdk:jdk-8u131-windows-x64    ide:Eclipse Oxygen Release (4.7.0)        代码: /* * 当父类与子类中的成员变量重名了,使用super.名字 来访问父类的成员变量 */ //基类 class Person { public int num = 1; } //子类 class Javaer extends Person { //子类中的成员变量与父类重名了 public int num

【共读Primer】26.<4.6>成员访问运算符 Page133

成员访问运算符: . 点运算符 -> 箭头运算符 string s1="a string", *p = &s1; auto n = s1.size(); // 运行string对象s1的size成员 n = (*p).size(); // 运行p所知对象的size成员 n = p->size(); // 等价于(*p).size() 因为皆因用运算符的优先级低于点运算符,所以执行解引用运算的子表达式两端必须加括号. 如果不加括号则含义会不同 // 含义是:运行p的s

统计对象中某个成员变量的访问次数

实例1:适用于非const对象 #include <iostream> #include <string> using namespace std; class Test { private: int m_value; int m_count; public: Test(int value = 0) { m_value = value; m_count = 0; } int getValue() { m_count++; return m_value; } void setValu

C# 中4个访问符和8个修饰符详解

4个访问修饰符(是添加到类.结构或成员声明的关键字) Public:公有的,是类型和类型成员的访问修饰符.对其访问没有限制. Internal:内部的,是类型和类型成员的访问修饰符.同一个程序集中的所有类都可以访问 Private:私有的,是一个成员访问修饰符.只有在声明它们的类和结构中才可以访问. Protected::受保护的,是一个成员访问修饰符.只能在它的类和它的派生类中访问. protected internal:访问级别为 internal 或 protected.即,“同一个程序集

在拷贝构造函数中为什么可以访问引用对象的私有变量? [问题点数:0分]

在拷贝构造函数中为什么可以访问引用对象的私有变量? 例如: class Point { public:         Point(int xx=0,int yy=0){X=xx;Y=yy;}         Point(Point &p); private:         int X,Y; }; Point::Point(Point &p) {         X=p.X;         Y=p.Y; } 更多 0 分享到: 相关主题推荐: 对象 class yy x 相关帖子推荐: