sizeof和volatile相关的知识。
希望大家每天都是心情愉悦的来学习。(加油)
一 .sizeof
1.关于sizeof的简单使用
sizeof用来求内置数据类型和自定义类型的所占字节个数,但是不能计算void相关类型的大小,这点后面讲void再进行详解。
那么下面就举个例子看看sizeof到底怎么使用吧。
例 1:
typedef struct str
{
int age;
char name[20];
}str;
int main()
{
int a = 100;
str ret = { 15, "胡杨树下" };
//printf("a = %d\n", sizeof int );//err:不允许使用类型名
printf("a = %d\n", sizeof(a));
printf("a = %d\n", sizeof(int));
printf("a = %d\n", sizeof a );
printf("ret = %d\n", sizeof(ret));
printf("ret = %d\n", sizeof(str));
printf("ret = %d\n", sizeof ret );
//printf("ret = %d\n", sizeof str );//err:不允许使用类型名
return 0;
}
把报错的代码注释掉,运行下看看
所以可以总结出sizeof使用的的细节
1.sizeof后面不能直接跟类型名,必须要(类型名)这样使用。
2.sizeof后面可以直接变量名,但是尽量使用(变量名)。
3.sizeof也可以计算数组和指针的大小,这点等到后面指针,和数组会写到
未完待续~~~
2.sizeof它是不是函数呢?
首先我们要明确一点的是sizeof不是函数,而是关键字,那么为什么会被误认为函数呢?
首先函数体和sizeof很像,后面都有(),跟的是变量。
那么函数没有()是绝对不行的,那sizeof没有()行不行呢?看看下列代码
例 2:
void test(int a)
{
printf("test 打印:%d\n", sizeof(a));
}
int main()
{
int a = 0;
test(a);
printf("sizeof打印 :%d", sizeof a );
return 0;
}
突然发现,在计算变量时没有(),sizeof也可以正常运行,这也就证明了,sizeof不是函数。
二 . volatile
下面进入volatile的学习,可能有人没听过这关键字,下面就一起简单了解下吧。
1.volatile使用
volatile 关键字和 const 一样是一种类型修饰符,用它修饰的变量表示可以被某些编译器未知的因素更改,比如操作系统、硬件或者其它线程等。遇到这个关键字声明的变量,编译器对访问该变量的代码就不再进行优化,从而可以提供对特殊地址的稳定访问。
再说明白点就是:
有些时候编译器会对代码进行一定程度的优化,比如说
例 3:
int a = 1;
while (a)
{
;
}
对a进行死循环判定,有的时候编译器进行优化就会使程序发生点变化,可能会有一个寄存器b,把a的值存入进去了,每次访问b,进步在访问内存中的a了。
优化后(不是实际情况,只是举例子)
int a = 1;
register b = a;
while (b)
{
;
}
因为在windows下不好演示volatile的例子,后续在Linux下演示汇编的形式,更直观。
总的来说:
volatile这个关键字修饰的变量,希望编译器不要对其进行代码优化,按照原来的执行逻辑,每次访问内存,不要把数据转移到寄存器或者其他地方。
2.volatile优点,缺点
那么上述说过了,编译器会在编译时对代码进行优化,而使用volatile则不希望代码被优化。代码优化后运行速度会更快了,内存占用情况也会更合理,但是,缺点是代码优化后,可能会出错,可能不再符合预期,这种情况也是有的。
本期遗留问题
1.首先是sizeof中关于指针和数组的一些情况。
2.还有就是volatile的例子将来在Linux中实现。
下期预告
关于关键字将在C语言关键字专栏不定时更新。,因为void比较重要,所以留在指针时讲解。
从下期开始将进入符号篇的讲解。
敬请期待~~~
各位看官,看到这个了,留下你的三连吧。