. * ./ \ ##测试

以前一直奇怪. * ./有什么用,今天测试了下。

直接输入代码

#include<stdio.h>
 
void main()
{
float aa=10;
float bb=10;
aa=10. *8;
bb=10. /8;
printf("%f,%f",aa,bb);
}
 
输出80。000000,1.250000。
可见,该运算可保留小数后面6位。、
另外,即使不留空格也完全没有问题。
 
另测了一下经常在句末风到的右斜杆\
如:
#define CHECK( name, limit, val ) \
    if( (val) > (limit) ) \
        ERROR( name " (%d) > level limit (%d)\n", (int)(val), (limit) );
又如:
if(1)\
printf("%f,%f\n",aa,bb);\
发现对输出没有任何影响。
 
今天找到一一篇博文

C语言宏定义中的两个井号(##)和一个井号(#)和反斜杆(\)

发表于 20111116  温泉

()宏定义中的## 连接符与# 
##
 连接符号由两个井号组成,其功能是在带参数的宏定义中将两个子串(token)联接起来,从而形成一个新的子串。但它不可以是第一个或者最后一个子串。所谓的子串(token)就是指编译器能够识别的最小语法单元。具体的定义在编译原理里有详尽的解释,但不知道也无所谓。同时值得注意的是#符是把传递过来的参数当成字符串进行替代。下面来看看它们是怎样工作的。这是MSDN上的一个例子。
假设程序中已经定义了这样一个带参数的宏:
#define paster( n )         printf( “token” #n ” = %d”, token##n )
同时又定义了一个整形变量:
int token9 = 9;
现在在主程序中以下面的方式调用这个宏:
paster( 9 );
那么在编译时,上面的这句话被扩展为:
printf( “token” “9″ ” = %d”, token9 );
注意到在这个例子中,paster(9);中的这个”9”被原封不动的当成了一个字符串,与”token”连接在了一起,从而成为了token9。而#n也被”9”所替代。
可想而知,上面程序运行的结果就是在屏幕上打印出token9=9

()”\”与一个较长占多行的宏
宏定义中允许包含两行以上命令的情形,此时必须在最右边加上”\”且该行”\”后不能再有任何字符,连注释部分都不能有,下面的每行最后的一定要是”\”,”\”后面加一个空格都会报错,更不能跟注释。
#define exchange(a,b) {\
int t;\
t=a;\
a=b;\
b=t;\
}

这里注意printf的用法:

printf("123\n" "456\n" "789\n");的输出结果与printf("123\n");printf("456\n");printf("789\n");相同。

因此输出多行时,也并不需要每行调用一次printf

 

 右斜杆果然是有用的。我太肤浅了。

posted @ 2013-02-24 13:32  yurius  阅读(230)  评论(0编辑  收藏  举报