- 指向数组的指针,跨度为一个数组
int a[5]={1,2,3,4,5};
int *p=(int*)(&a+1);
运算符优先级是取地址高于+的,&a和&a[0]的值是一样的,但是偏移量是不一样的,或者说用跨度更好理解,sizeof(a)=20,sizeof(a[0])=4,
这里做了一个强制类型转换(int*),把指向数组的指针变为指向int的指针,值不变,但是跨度变成4个字节,理解更进一步,因此*(p-1)=5
- 关于int main(char* argc,char**argv)
argv为指针的指针 argc为整数 char **argv or: char *argv[ ] or: char argv[ ][ ] main()括号内是固定的写法。 下面给出一个例子来理解这两个参数的用法: 假设程序的名称为prog,
1.当只输入prog,则由操作系统传来的参数为:
argc=1,表示只有一程序名称。 argc只有一个元素,argv[0]指向输入的程序路径及名称:./prog2.当输入prog para_1,有一个参数,则由操作系统传来的参数为:
argc=2,表示除了程序名外还有一个参数。 argv[0]指向输入的程序路径及名称。 argv[1]指向参数para_1字符串。3.当输入prog para_1 para_2 有2个参数,则由操作系统传来的参数为:
argc=3,表示除了程序名外还有2个参数。 argv[0]指向输入的程序路径及名称。 argv[1]指向参数para_1字符串。 argv[2]指向参数para_2字符串。
char **argv : argv是一个指针数组,他的元素个数是argc,存放的是指向每一个参数的指针,他的第一个元素即argv[0]为编译生成的可执行文件名(包括路径eg:”F:\VC\Ex1\Debug\Ex1.exe”),从二个元素(argv[1])开始,是每一个参数 .
int argc 表示argv的大小,是实际参数个数+1,其中+1是因为argv[0]是编译后的可执行文件名
说白了argv就是字符串数组,类型为char**,char*是字符串,
argv[1]就是两次解引用写法和argv[1][0],(*(argv)+1)相同
- 对齐方式
昨天的对齐问题也通过一个预编译命令巩固了一下
int main ()
{
#pragma pack(4)
struct
{
char m1;
double m4;
int m3;
}tt;
#pragma pack(pop)
printf("%d\n",&tt.m1);
printf("%d\n",&tt.m4);
printf("%d\n",&tt.m3);
return 0;
}
关于结构大小的规则:结构的总大小也有个约束条件,分下面两种情况:如果n大于所有成员变量类型所占用的字节数,那么结构的总大小必须为占用空间最大的变量占用的空间数的倍数;否则必须为n的倍数。