• C语言指针面试题——第二弹


    目录

    第一题

    第二题 

     第三题

     第四题

     第五题

    第六题 

     第七题

     第八题


     

    第一题

    1. #include<stdio.h>
    2. int main()
    3. {
    4. int a[5] = { 1, 2, 3, 4, 5 };
    5. int* ptr = (int*)(&a + 1);
    6. printf("%d,%d", *(a + 1), *(ptr - 1));
    7. return 0;
    8. }

     

    &a的类型是int(*)[5],这里的(int*)是强制类型转换把&a类型转换为int*

    ptr-1之后会指到5,然后再解引用,最终结果*(ptr-1)等于5

    a指向首元素,a+1指向第二个元素

    第二题 

    1. #include<stdio.h>
    2. struct Test
    3. {
    4. int Num;
    5. char* pcName;
    6. short sDate;
    7. char cha[2];
    8. short sBa[4];
    9. }*p=(struct Test*)0x100000;
    10. //假设p 的值为0x100000。 如下表表达式的值分别为多少?
    11. //已知,结构体Test类型的变量大小是20个字节
    12. int main()
    13. {
    14. printf("%p\n", p + 0x1);
    15. printf("%p\n", (unsigned long)p + 0x1);
    16. printf("%p\n", (unsigned int*)p + 0x1);
    17. return 0;
    18. }

     

    由于Test类型的大小是20个字节,而p正好是test类型 ,0x1是16进制下的数字1,是1*16^0,

    p+0x1:相当于给p加了二十个字节,而p的内容是0x1000000,这是16进制下的数字,我们应把这20转换为16进制下的数字,转换结果为14,所以答案是0x100000+14=0x100014

    (unsigned long)p+0x1:就是把p强制转换为整形(无符号长整形),转为整形后结果是1048576,之后再加1(16进制的1和10进制的1相同),变为1048577,转为16进制为0x100001

    (unsigned int*)p:把p强制转换为(unsigned int *)类型,这个类型的权限大小是四个字节,当p+0x1=p+1之后,由于权限大小为4个字节,所以p跨过4个字节因此结果为0x100004

     第三题

    1. int main()
    2. {
    3.    int a[4] = { 1, 2, 3, 4 };
    4.    int *ptr1 = (int *)(&a + 1);
    5.    int *ptr2 = (int *)((int)a + 1);
    6.    printf( "%x,%x", ptr1[-1], *ptr2);
    7.    return 0;
    8. }

     

    ptr1的类型原来是int(*)[4],强制类型转换为(int*)ptr[-1]如何得来,请看上图,ptr[-1]=*(ptr1+(-1))=*(ptr1-1)

    *ptr2,最终结果是因为*ptr是整形解引用,所以访问了后面的四个字节,最终结果和小端存储有关

     

     第四题

    1. #include <stdio.h>
    2. int main()
    3. {
    4. int a[3][2] = { (0, 1), (2, 3), (4, 5) };
    5. int* p;
    6. p = a[0];
    7. printf("%d", p[0]);
    8. return 0;
    9. }

     ​​​​​​​

     第五题

    1. int main()
    2. {
    3.    int a[5][5];
    4.    int(*p)[4];
    5.    p = a;
    6.    printf( "%p,%d\n", &p[4][2] - &a[4][2], &p[4][2] - &a[4][2]);
    7.    return 0;
    8. }

     

     

     

    这里把-4当作地址去打印了 

    第六题 

    1. int main()
    2. {
    3.    int aa[2][5] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
    4.    int *ptr1 = (int *)(&aa + 1);
    5.    int *ptr2 = (int *)(*(aa + 1));
    6.    printf( "%d,%d", *(ptr1 - 1), *(ptr2 - 1));
    7.    return 0;
    8. }

     

     

     第七题

    1. #include <stdio.h>
    2. int main()
    3. {
    4. char *a[] = {"work","at","alibaba"};
    5. char**pa = a;
    6. pa++;
    7. printf("%s\n", *pa);
    8. return 0;
    9. }

     

     

    因为pa指向的对象是char *的,所以每次加1,加一个char *类型大小 

     第八题

     

    1. #include <stdio.h>
    2. int main()
    3. {
    4. char* c[] = { "ENTER","NEW","POINT","FIRST" };
    5. char** cp[] = { c + 3,c + 2,c + 1,c };
    6. char*** cpp = cp;
    7. printf("%s\n", **++cpp);
    8. printf("%s\n", *-- * ++cpp + 3);
    9. printf("%s\n", *cpp[-2] + 3);
    10. printf("%s\n", cpp[-1][-1] + 1);
    11. return 0;
    12. }

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

  • 相关阅读:
    MES系统以全流程优化为核心,实现全闭环的生产
    RocketMQ 5.0 可观测能力升级:Metrics 指标分析
    HVIDB!人类病毒蛋白互作数据库介绍
    随笔 | 写在七月末的这一天
    1.顺序表-头插、头删、尾插、尾删
    深度神经网络的matlab实现,深度神经网络代码matlab
    HashMap JDK1.7与1.8的区别
    具有通信时延的多自主体系统时变参考输入的平均一致性跟踪
    广和通5G模组FM650助力阿里云打造无影魔方Pro
    IP地址在各行业中的常见应用场景
  • 原文地址:https://blog.csdn.net/weixin_49449676/article/details/125586072