zoukankan      html  css  js  c++  java
  • 指针的强制类型转换

    1.什么是数据类型?数据类型的作用是什么?

    int a = 10;

    int数据类型规定了变量a的大小的存储方式。数据类型就只有两种作用,内存那么大,如何进行分配使用,都是靠数据类型。

    int short char 数据类型的存储方式相同,只是所规定的内存大小不同,而float 和double和他们都不同。

    2.指针的数据类型是什么?
    准确的来说,指针是没有数据类型的,所有的指针的类型都是指针类型,也就是说,论是int*p,float *p,还是char*p,都是指针类型,而前面的int,float,char是表明该指针指向的变量的数据类型。

    分析:

    2.1. 
       int a = 10;
       int * p;
       p = & a;

    p是指针类型,p指向一个int类型的变量,也就是说如果p本身的地址是0x11111111,那0x11111111,0x111111120x111111130,x11111114这四个地址存放的是一个int类型的变量,要用int去解析该数据得到一个int类型的变量。

    2.2.

     int a = 10;
     float * p = & a;

    一个float指针去解析int类型的数据百分之百会出错。类型不同,存储方式不同。

    2.3.

     int a[] = {0x11223344};
            char * p = a;
            printf("*p = %d
    ",*p);
            printf("*(p+1)
    ",*(p+1));
            printf("*(p+2)
    ",*(p+2));
            printf("*(p+3)
    ",*(p+3)); 

    分析: p是数组的首元素的首地址,p 打印的是第一个元素,这时候看数组时int类型的,每一元素占4个字节,而p是char类型的指针,一个字节8位存放两个十六进制的数。也就是说*p只能打印出原来数组的一个字节的内容。(p+1)打印数组第二个字节的内容,(p+2)打印数组第三个字节的内容,(p+3)打印数组第四个字节的内容。也就是说打印四次才能把原来的数组0x11223344四个字节的内容打印出来。

    3.总结:所有的指针的解析方式都是相同的,指针的类型只是表明这个指针32位存储了一个地址。该地址上存放了一个变量,该变量是什么类型要根据指针的类型。

  • 相关阅读:
    利用python登录网页并自动签到
    链表的学习--创建、添加和删除元素
    Nginx指定IP无须通过认证
    curl命令获取站点的各类响应时间
    django中的Q和F方法
    python subprocess重定向标准输出
    python创建虚拟环境
    flask-sqlalchemy的使用
    sqlachelmy的使用
    wtforms的使用
  • 原文地址:https://www.cnblogs.com/1024E/p/13209624.html
Copyright © 2011-2022 走看看