c语言大括号的用法for语句中(*ptr)和*ptr有什么区别,为什么要加括号,不加括号会发生什么

博客访问: 222980
博文数量: 162
博客积分: 786
博客等级: 军士长
技术积分: 1551
注册时间:
IT168企业级官微
微信号:IT168qiye
系统架构师大会
微信号:SACC2013
分类: C/C++
此文为转载
for循环后有时候有大括号,有时候没有, 比如: for(i=1;i<=10;i++){.......} 或for(i=1;i<=10;i++) p=i;..... 那么到底什么时候应该加人大括号什么时候不加?还有就是for循环的作用域多大?也就是说到底从哪儿到哪儿属于循环的内容? 下面我们将告诉大家区分这个问题。 若不加大括号,则它只包含下面的一条语句或一个循环,若加了括号,则它包含所有括号内的语句 细说:
如果不加大括号,就是作用域就是紧跟着for的那一条语句 如果加大括号,作用域就是这个大括号括起来的内容 如果循环的语句只有一句的话,可以不加大括号,如果有多条,就要加大括号
for(i=1;i<=10;i++) &p=i; &j=10; 与 for(i=1;i<=10;i++) { && p=i; &} &j=10; 相同
如果说for里有一句循环语句,那么就不用加大括号,这是简便的写法!如: for(1=0;i<10;i++) printf(\"*****\"); 这样就不用加打括号,如果是下面这样, for(i=0;i<10;i++) { printf(\"***\"); printf(\"循环10次\"); } 那就要加大括号,因为里面有2句是循环语句,不加大括号的情况下,这能认为语句里面的第一句是要执行的,比如: for(i=0;i<10;i++) printf(\"***\"); printf(\"循环10次\"); 屏幕上出现***循环10次的结果,而“循环10次”只被输出了一次! 这种方法不仅在for可以出现,在if等都可以出现 ---------------------------- 作用域的问题: 如果不加大括号,那么作用域就是下面数第一句话,如果有大括号,那么就是大括号里面的所有内容,如: for(i=-;i<10;i++) { printf(\"***\"); printf(\"***\"): } 作用域就是两句printf for(i=-;i<10;i++) printf(\"***\"); printf(\"***\"):] 作用域就是第一句printf
阅读(2344) | 评论(0) | 转发(1) |
相关热门文章
给主人留下些什么吧!~~
请登录后评论。关于C语言中的volatile变量
volatile的解释:是一个类型修饰符(const也是一个类型修饰符),它是被设计用来修饰被不同线程访问和修改的变量。
volatile的作用:作为指令关键字,确保本条指令不会因编译器的优化而省略,且要求每次直接读值。
&&&&&&&&&&&&&&&&&&&&&&&&&&&& 简单地说就是防止编译器对代码进行优化。
volatile的例子:
&并行设备的硬件寄存器(如:状态寄存器)   
&一个中断服务子程序中会访问到的非自动变量(Non-automatic variables)   
多线程应用中被几个任务共享的变量
volatile面试题:
一个参数既可以是const还可以是volatile吗?解释为什么。   
一个指针可以是volatile 吗?解释为什么。   
下面的函数有什么错误:
int square(volatile int *ptr){&&
&&& return *ptr * *&
&&&&&& 解答:
是的。一个例子是只读的状态寄存器。它是volatile因为它可能被意想不到地改变。它是const因为程序不应该试图去修改它。
是的。尽管这并不很常见。一个例子是当一个中断服务子程序修改一个指向一个buffer的指针时。
这段代码的目的是用来返指针*ptr指向值的平方,但是,由于*ptr指向一个volatile型参数,编译器将产生类似下面的代码:
int square(volatile int *ptr){&
&&& int a,b;&
&&& a = *&
&&& b = *&
&&& return a *&
由于*ptr的值可能被意想不到地改变,因此a和b可能是不同的。结果,这段代码可能返不是你所期望的平方值!正确的代码如下:
long square(volatile int *ptr){&
&&& a = *&
&&& return a *&
volatile实例(VC6):
#include &stdio.h&&
void main()&
&&& int i=10;&
&&& int a =&
&&& printf(&i= %d/n&,a);&
&&& //下面汇编语句的作用就是改变内存中i的值,但是又不让编译器知道&
&&& __asm {&
&&&&&&& mov dword ptr [ebp-4], 20h&
&&&&&&& }&
&&&&&&& int b =&
&&&&&&& printf(&i= %d/n&,b);&
然后,在调试版本模式运行程序,输出结果如下:
然后,在release版本模式运行程序,输出结果如下:
输出的结果明显表明,release模式下,编译器对代码进行了优化,第二次没有输出正确的i值。
但是如果在 i的声明加上volatile关键字,调试版本和release版本运行程序,输出都是:
作者:deqingguo}

我要回帖

更多关于 c语言括号表达式 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信