一、数据更新或者不更新都显示#name
步骤如下:
1.首先,我们打开我们电脑上面的excel,然后在里面输入一些数字;
2.之后我们在这组数字下方的单元格中输入=averege(B2:B4),然后我们按回车键;
3.这样就出现了#NAME?这个状况了,其实这是因为我们的公式输入错误导致的;
4.我们将公式改为正确的average,然后我们按回车键;
二、c语言的************name意思
##连接符号由两个井号组成,其功能是在带参数的宏定义中将两个子串(token)联接起来,从而形成一个新的子串。但它不可以是第一个或者最后一个子串。所谓的子串(token)就是指编译器能够识别的最小语法单元。
简单的说,“##”是一种分隔连接方式,它的作用是先分隔,然后进行强制连接。其中,分隔的作用类似于空格。我们知道在普通的宏定义中,预处理器一般把空格解释成分段标志,对于每一段和前面比较,相同的就被替换。但是这样做的结果是,被替换段之间存在一些空格。如果我们不希望出现这些空格,就可以通过添加一些##来替代空格。
举列–试比较下述几个宏定义的区别
#define A1(name, type) type name_##type##_type或
#define A2(name, type) type name##_##type##_type
A1(a1, int);
A2(a1, int);
解释:
1)在第一个宏定义中,”name”和第一个”_”之间,以及第2个”_”和第二个”type”之间没有被分隔,所以预处理器会把name_##type##_type解释成3段:“name_”、“type”、以及“_type”,这中间只有“type”是在宏前面出现过
的,所以它可以被宏替换。
2)而在第二个宏定义中,“name”和第一个“_”之间也被分隔了,所以预处理器会把name##_##type##_type解释成4段:“name”、“_”、“type”以及“_type”,这其间,就有两个可以被宏替换了。
3) A1和A2的定义也可以如下:
#define A1(name, type) type name_##type##_type
<##前面随意加上一些空格>
#define A2(name, type) type name##_##type##_type
结果是##会把前面的空格去掉完成强连接,得到和上面结果相同的宏定义。
或再比如
#define LINK_MULTIPLE(a,b,c,d) a##_##b##_##c##_##d
typedef struct _record_type LINK_MULTIPLE(name,company,position,salary);
//这里这个语句将展开为:
// typedef struct _record_type name_company_position_salary;
详细使用方法,可以参考如下博客内容: