1、char *p =&a;
char修饰访问空间一个字节一个字节访问,*p存地址标识*p的大小取决于操作系统位数;
2、假设设计了一个0x20008000的地址位置上,向这个位置填入0x12345678的值;
int *p1 = (int *)0x20008000;强转
p1[0] = 0x12345678;
向0x20008004填值将p1[1] = 即可;0改1即可;
*((int*)0x20008000) = 0x12345678;等价于;使用int*把数字强转为指针地址;再将该指针地址当作一个整体前面加*类似于p[0];
保存地址的容器也占据了内存空间,叫做地址变量;
地址常量:这个值是没有能力被修改;
数组:
char data[5];
申请5个char的基本类型,用data数组名来标记第一个元素的首地址;
数组是列表;data无法标记五个空间;没有专门的空间来存data,data的值只是一个标签,不占用内存空间
data = {1,2}常量不能放到等号的左边;
数组空间要填充内容,
1、逐一赋值编写代码麻烦,c语言提供初始化方法,简写写法
char data[5] = {1,2,3};没有提高程序执行效率;//
char data[5] = "abc";内部会调用strcpy;//有些不提供该函数,无库函数支撑;
2、本质:逐一赋值;
data[3] = 0x11;
&data不合法;本来没有空间分配;c语言编译器将不合法的表达式自定义了语法行为;
1、对数组名获取他的地址,值还是数组空间首地址的值;
2、地址访问行为:一个数组一个数组的访问;data访问以char为单位访问;
&data + 1 = 400 +5 =405;
data + 1=401;
因为数组不是数据类型,不具备拷贝和赋值操作;
函数的参数传递行为:函数的数组空间传递,只能传递首地址;范围也要告诉函数设计者;
strlen:能不能计算数组的空间容量;strlen[buf]以buf为首地址直到遇到结束符0为止
str前缀 它处理的空间默认是字符空间,结束标志0;遇到0结束