一、数据更新或者不更新都显示#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;

详细使用方法,可以参考如下博客内容: