1.为什么重复定义不报错
如下程序编译通过,运行正常
#include
int a;
int a = 3;
int main(void)
{
printf("%d\n", a);
return 0;
}
原因:
在C语言中.
int a; 这条语句为暂时定义.
int a = 3; 这条语句则是正式定义.
暂时定义可以出现无数次, 如果在链接时系统全局空间没有相同名字的变量定义, 则暂时定义"自动升级"为正式定义, 这时系统会为暂时定义的变量分配存储空间.
×××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××
2.gcc -D_REENTRANT
其中-D_REENTRANT是定义宏选项, 相当于在源程序中加上了#define _REENTRANT
××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××
3.*str="resource" 和 str[] = "resource"的区别
对于 char *str = "resource";
把"resource"的值----也就是字符串常量字面值,也就是"resource"的地址,准确来说是起始地址----赋给字符指针 str,Linux下,"resource"字符串常量是存放于只读数据区的,一般来说,32位机器上,在Linux中,堆,全局数据,常量等都是存放于从0x8048000开始的内存地址,向上增长。可以打印一下"resource"的地址来进行验证。char *str = "resource",就是把"resource"的首地址赋给str,所以str 存放的是一个只读数据区的地址,对只读区的数据进行写操作是禁止,具体由相应的操作系统进行判断以及处理。
而对于 char str[] = "resource";
str[]是一个字符数组,编译器首先在栈中分配一定的连续空间用于存放“resource”中的字符以及结尾符,然后把字符串常量的内容,也就是
"resource"中的各个字符和结尾符复制到这个栈中的连续空间中。str是数组名,用来表示这个连续栈空间的起始地址,所以str中存放的是栈地址,这个地址的数据是可写的。一般来说,32位机器上,在Linux中,栈地址空间从3G(0xbfffffff)开始向下增长。
可以用语句printf("%x\n", str)来打印出str中存放的地址,来验证一下这个地址属于栈还是属于只读数据区。
×××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××
4.如下这段代码可以通过
#include
extern int a;
int a=1;
int main(void)
{
printf("a=%d\n", a);
return 0;
}
**********************************************************************************
5.如果表达式中存在无符号数和有符号数时,所有的有符号数自动转换成无符号数参与运算,这个在频繁使用无符号数的嵌入式开发中要非常注意的一个问题
×××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××××
6.
阅读(782) | 评论(0) | 转发(0) |