• 指针的回忆


    这道题很好,可以复习对指针和数组的理解。

    char *c[] = { "ENTER", "NEW", "POINT", "FIRST" }; //指针数组,数组里存放的都是char型指针
    char **cp[] = { c+3, c+2, c+1, c }; 
    char ***cpp = cp;    //这里要注意,cp是存储着二级指针的数组的首地址,也是一个以三级指针,
                //cpp是一个存储着二级指针地址的三级指针,这里仅仅是将三级指针cp赋值于三级指针cpp,
    int main(void) { 1 printf("%s", **++cpp); 2 printf("%s", *--*++cpp+3); 3 printf("%s", *cpp[-2]+3); 4 printf("%s ", cpp[-1][-1]+1); return 0;
    }

    1.  ++cpp; ~> cpp = cp+1; ~> *(cp+1)=c+2; ~> *(c+2)=c[2]  故第一个printf打印的是c[2]的值,POINT

    2. 由于1.对cpp进行了操作,cpp=cp+1,则++cpp=cp+2; ~> *cpp=c+1; ~> --(c+1)=c ; ~>*c=ENTER, *c+3=c[0]+3=ER

    3.  cpp=cp+2, cpp[-2]=cp; ~> *cp=c+3=c[3]; ~> c[3]+3=ST

    4.  cpp=cp+2=cp[2], cpp[-1]=cp[1]=c+2; ~>(c+2)[-1]=c[1] ; ~> c[1]+1=EW;

    其中用到了优先级的问题。

    初等单目一二级, // 初等运算符和单目运算符分别是第1、2优先级

    乘除求余加减移, // 这句里面的运算符全归为算术运算符,移表示移位

    关系等于不等于, // 关系运算符(<  <=  >  >=)

    按位与来异或或, // 位运算符优先级顺序: & -> ^ -> |

    逻辑与或条件弱, // 逻辑运算符优先级顺序: && -> ||,后面跟着优先级比较低(弱)的条件运算符

    赋值逗号一点破。 // 赋值,逗号最低

  • 相关阅读:
    人工智能-实验一策略迭代和值迭代
    Lecture 3: Planning by Dynamic Programming
    Lecture 2: Markov Decision Processes
    Software Testing -- LAB02-Selenium上机实验
    数据结构-王道2017-第4章 树与二叉树-二叉树的遍历
    数据结构-王道2017-第4章 树与二叉树
    PHP-基础知识
    nginx的安装与配置
    在Linux上部署项目
    zk 命令
  • 原文地址:https://www.cnblogs.com/sjxbg/p/6574379.html
Copyright © 2020-2023  润新知