程序输出

1. copy from blog

main()
{
  int a[5]={1,2,3,4,5};
  int *ptr=(int *)(&a+1);
  
  printf("%d,%d",*(a+1),*(ptr-1));
}

输出:2,5

*(a+1)就是a[1],*(ptr-1)就是a[4],执行结果是2,5

&a+1不是首地址+1,系统会认为加一个a数组的偏移,是偏移了一个数组的大小(本例是5个int)

int *ptr=(int *)(&a+1);

则ptr实际是&(a[5]),也就是a+5

原因如下

&a是数组指针,其类型为 int (*)[5];

而指针加1要根据指针类型加上一定的值,

不同类型的指针+1之后增加的大小不同

a是长度为5的int数组指针,所以要加 5*sizeof(int)

所以ptr实际是a[5]

但是prt与(&a+1)类型是不一样的(这点很重要)

所以prt-1只会减去sizeof(int*)

a,&a的地址是一样的,但意思不一样,a是数组首地址,也就是a[0]的地址,&a是对象(数组)首地址,a+1是数组下一元素的地址,即a[1],&a+1是下一个对象的地址,即a[5].

2.

char* s="AAA";
printf("%s",s);

s[0]='B'; // error because s point to string constant which is readonly.
printf("%s",s);

3.

char c=128;
printf("c=%d\n",c);

输出-128. 128是1000 0000b,char是signed,所以第一位是符号位,1000 0000b是有符合数-128.

4.

#include <stdio.h>

typedef struct AA {
    int b1:5;
    int b2:2;
}AA;

void main()
{
    AA aa;
    char cc[100];

    strcpy(cc,"0123456789abcdefghijklmnopqrstuvwxyz");
    memcpy(&aa,cc,sizeof(AA));

    printf("b1: %d\n", aa.b1);
    printf("b2: %d\n", aa.b2);
}

b1: -16
b2: 1

首先sizeof(AA)的大小为4,b1和b2分别占5bit和2bit.

经过strcpy和memcpy后,aa的4个字节所存放的值是:

0,1,2,3的ASC码,即00110000,00110001,00110010,00110011

所以,最后一步:显示的是这4个字节的前5位,和之后的2位

分别为:10000,和01

因为int是有正负之分 所以:答案是-16和1

这个结果应该是在小端系统上的,大端系统应该不是这样的

5.

char *a = "hello";
char *b = "hello";

if(a==b)
   printf("YES");
else
   printf("NO");

// gcc输出YES,主要是hello是常量字符串,在数据段只存一份,所以两个指针指向同一个地址

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章