/*指针 : 专于保存地址的数据结构,占用8个字节,并且可以通过指针保存的地址访问指针指向的内存空间的值;    定义格式 : 指针所指向的数据类型 *指针名称;    初始化 ; 1,定义的同时初始化,如 : int *[n]numP = #    //定义几级指针,则写几个"*";             2,定义后,再初始化,如 : int *[n]numP; numP = #             //注 : 变量名称往往决定了从内存哪里开始取值;数据类型决定了从内存取值时,决定要取多少个字节的值,                    当然取出来的只是二进制而已;而占位符则决定了将取出来的二进制转换成怎样的形式进行输出;指向数组的指针 :     定义格式 : 数组数据类型 *指针名称;    //注 : 数组名称保存的即为数组的地址,即为数组中第一个元素的地址;因此,在对指向数组的指针初始化时,可直接将数组名称赋值给指针即可;    //注 : 指针可做加减运算,如某个指针加1,这里的1指的是单位1,也即指针所指向的数据类型占用的字节数;    案例 : 利用指针遍历字符串 :    char string[] = "acssd";    char *stringP = string;    while (*stringP != '\0')    {        printf("%c",*stringP);        stringP++;    }    printf("\n");指针和字符串 :    保存字符串的两种方式 :        通过数组保存字符串,如 : char string[] = "adsdds";    //字符串保存位置: 栈中,生命周期 : 自创建起至return或"}";        通过指针保存字符串,如 : char *string = "assd";    //字符串保存位置 : 常量区中,生命周期 : 自创建起,始终存在,且在常量区中,值相同的变量指向同一块内存空间;                                                          //应用场景 : 当需要频繁使用某一个常量时,可避免内存空间的频繁创建和释放,提升程序执行效率;指针数组 : 就是保存有多个指针的数组    指针指向的数据类型 *数组名称[元素个数];指向函数的指针 :     //注 : 函数也会占据一块内存空间,因此函数也会有自己的地址,保存在函数名中;    定义格式 : 函数返回值的数据类型 (*指针名称) (形参)    //形参名称可省略不写;    通过指针调用函数 : 1,(*指针名称)(实参)                       2,指针名称(实参)    应用场景 : 实现入口或类;        常可通过指针实现一个入口,根据用户需求不同,调用不同的函数以实现不同的动作或功能.由此,我们也可以理解"类"这一概念,如在python中的print函数,时间上print函数        仅仅只是一个打印入口而已,print函数会根据用户要求打印的内容不同,调用不同的打印函数,打印相应的内容,如打印整型数据和打印浮点型数据,调用的打印函数就不同;*/