0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

C语言各种数据类型的内存映像

Linux爱好者 来源:小智雅汇 作者:小智雅汇 2022-07-06 14:49 次阅读

C语言各种数据类型的内存映像(32位平台): 38a6d21e-fce0-11ec-ba43-dac502259ad0.png

0 signed char

#include
intmain()
{
charmin=1<<7;
    char max = (1<<7)-1;
    for(int i=min;i<=max;i++)
        if(i<0)
            printf("%.2X ",(unsigned char)i);
        else
        {
            printf("%c ",i);
            if(i%32==0)
                printf("
%d ",i);
        }
    getchar();
}

output:

38bc0fee-fce0-11ec-ba43-dac502259ad0.png

1 整型的signed和unsigned

#include
intmain()
{
signedintsmin=1<<31;
    signed int smax = (1<<31)-1;
    printf("%d
",smin);    // -2147483648
    printf("%d
",smax);    // 2147483647
    unsigned int umax = -1;
    printf("%u
",umax);    // 4294967295
    umax = (1<<32)-1;
    printf("%u
",umax);    // 4294967295
}

如果一个表达式同时包含signed和unsigned整型,signed会提升为unsgined,可能会隐藏一些意想不到的错误,特别是用在比较运算时:

unsignedinta=4294967290;
intb=-6;
printf("%d
",a==b);//1,bpromotestounsigned

2 double的二进制位显示

#include
voidprintByte(doubled)
{
intbs=sizeofd;
unsignedchar*ch=(unsignedchar*)&d;
for(inti=0;i

将double分成4部分显示:

#include
typedefstructpacked_double{
unsignedintlow32;//小数位低32位
unsignedintlow20:20;//小数位低33-52位
unsignedintexp11:11;//指数位低53-63位,移码1023+二进制整数位-1
unsignedintsign:1;//符号位
}packed_double;

typedefunion{
doubled;
packed_doubleb;
}packed;
intmain()
{
packedpd;
pd.d=-15.75;
pd.d=12.3;
printf("%u%u%u%u
",pd.b.sign,pd.b.exp11,pd.b.low20,pd.b.low32);
getchar();
return0;
}
/*
0102610158080
*/

3 数组是相同数据类型的依次存储

数组名是一个存储数据首元素地址具有常量性质的特殊指针,成员是相对于基址的偏移:

#include
voidprintArr(shortarr[],intlen)
{
for(inti=0;i

4 枚举只是枚举可以取值的一些符号常量的一个特殊整型

#include
intmain()
{
enumNm{LOSS,TIE,WIN}nm;//实质是一个整型,成员只是可能的右值(符号常量)的枚举
nm=LOSS;
printf("%d",nm);//0
nm=TIE;
printf("%d",nm);//1
nm=WIN;
printf("%d",nm);//2
nm=(enumNm)3;
printf("%d",nm);//3
printf("
%d",sizeof(enumNm));//4
getchar();
}

枚举让相关符号常量内聚为一组,相对于#define,枚举对数据的描述性更清晰。

5 共用体成员的起始地址相同,共用一块内存空间,值相互覆盖

#include
intmain()
{
unionNn{inta;doubleb;}nn;//成员的起始地址相同,值相互覆盖
nn.a=123;//
printf("起始地址:%X,内存空间占用:%d
",&nn.a,sizeofnn.a);
nn.b=12.3;
printf("起始地址:%X,内存空间占用:%d
",&nn.a,sizeofnn.b);
nn.a=12;
printf("起始地址:%X,内存空间占用:%d
",&nn.a,sizeofnn.a);
getchar();
}
/*
起始地址:12FF40,内存空间占用:4
起始地址:12FF40,内存空间占用:8
起始地址:12FF40,内存空间占用:4
*/

当一些事物具有更多共性,但有少量差异时,可以只用一个内嵌一个共用体的结构体来描述:

#include
#include
#defineMAXPARTS12

structParts{//零件
intcost;
charsupplier[12];
charunit[12];
};

structAssembly{//装配件
intn_parts;
struct{
charpartno[12];
shortquan;
}parts[MAXPARTS];
};

structInventory{//存货类型,或是零件,或是装配件
charpartno[10];
intquan;
enum{PART,ASSEMBLY}type;//存货类型
union{
structPartsparts;
structAssemblyassembly;
}info;
};

intmain()
{
structInventoryscreen;
strcpy(screen.partno,"p001");
screen.quan=12;
screen.type=Inventory::PART;
screen.info.parts.cost=122;
strcpy(screen.info.parts.supplier,"hw");
strcpy(screen.info.parts.unit,"pcs");

structInventoryshell;
strcpy(shell.partno,"a001");
shell.quan=4;
shell.type=Inventory::ASSEMBLY;
shell.info.assembly.n_parts=22;
strcpy(shell.info.assembly.parts[0].partno,"d001");
shell.info.assembly.parts[1].quan=5;
intcosts;
if(shell.type==Inventory::ASSEMBLY)
costs=shell.info.assembly.n_parts;

printf("%d
",costs);//22
getchar();
return0;
}

6 结构体是不同数据类型的数据依次存储在一起

结构体各数据成员的引用可以通过其内存大小和字节对齐来相对于基址偏移来计算。结构体通常用于描述某一事物,用其成员来描述该事物的某些关键属性。让该事物既可以用结构体变量整体表示,也可以对其成员分别引用来处理该事物的各个属性。

#include

intmain()
{
structdemo{chara;shortb;intc;}abc;//成员相对于基址偏移,字节对齐
abc.b=12;
short*p=(short*)((int)&abc+sizeof(short));//模拟编译器计算第2个成员的偏移地址
printf("%d%d
",abc.b,*p);//1212
printf("%d
",sizeof(structdemo));//8
getchar();
}

7 位域是对整型数据的按位处理

(一次可以处理n个位,1<=n<=整形长度)

位域(全局)二进制位显示:

#include
voidprintBinM(unsignedintn)
{
for(inti=31;i>=0;i--)
printf("%d",(n&1<>i);
printf("
");
}
structBf{
unsigneda:3;
unsignedb:4;
unsignedc:5;
}bf;
intmain()
{
bf.a=1;
bf.b=15;
bf.c=3;
int*p=(int*)&bf;//505
printf("%d
",*p);
printBinM(*p);//00000000000000000000000111111001
getchar();
}

位域(局部)二进制位显示:

#include
voidprintBinM(unsignedintn)
{
for(inti=31;i>=0;i--)
printf("%d",(n&1<>i);
printf("
");
}

intmain()
{
structBf{
unsigneda:3;
unsignedb:4;
unsignedc:5;
}bf;
bf.a=1;
bf.b=15;
bf.c=3;
int*p=(int*)&bf;//-858996231
printf("%d
",*p);
printBinM(*p);//11001100110011001100000111111001
getchar();
}

原文标题:C 语言各数据类型的内存映像

文章出处:【微信公众号:Linux爱好者】欢迎添加关注!文章转载请注明出处。

审核编辑:彭静

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 数据
    +关注

    关注

    8

    文章

    6800

    浏览量

    88733
  • 内存
    +关注

    关注

    8

    文章

    2965

    浏览量

    73808
  • C语言
    +关注

    关注

    180

    文章

    7591

    浏览量

    135815
  • 存储数据
    +关注

    关注

    0

    文章

    85

    浏览量

    14080

原文标题:C 语言各数据类型的内存映像

文章出处:【微信号:LinuxHub,微信公众号:Linux爱好者】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    技术干货驿站 ▏深入理解C语言:基本数据类型和变量

    C语言中,数据类型和变量是编程的基础,也是理解更复杂概念的关键。数据类型决定了变量的内存分配、存储范围和操作方式,而变量则是存储
    的头像 发表于 07-26 17:53 1851次阅读
    技术干货驿站 ▏深入理解<b class='flag-5'>C</b><b class='flag-5'>语言</b>:基本<b class='flag-5'>数据类型</b>和变量

    C语言数据类型有哪些

    C 语言中,数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。变量的类型决定了变量存储占用的空间,以及如何解释存储的位模式。
    发表于 03-20 10:56 422次阅读
    <b class='flag-5'>C</b><b class='flag-5'>语言</b><b class='flag-5'>数据类型</b>有哪些

    浅谈嵌入式C语言各种数据类型内存映像

    如果一个表达式同时包含signed和unsigned整型,signed会提升为unsgined,可能会隐藏一些意想不到的错误,特别是用在比较运算时
    的头像 发表于 12-28 18:21 743次阅读
    浅谈嵌入式<b class='flag-5'>C</b><b class='flag-5'>语言</b><b class='flag-5'>各种数据类型</b>的<b class='flag-5'>内存</b><b class='flag-5'>映像</b>

    plc数据类型怎么理解和应用

    PLC(可编程逻辑控制器)是一种工业自动化设备,用于控制机械和工业过程。在PLC编程中,数据类型是非常重要的概念,因为它决定了程序中数据的存储和处理方式。正确理解和应用PLC数据类型是编写有效、可靠
    的头像 发表于 12-19 11:39 3885次阅读

    从AD7712读取的数据C语言中是保存为什么数据类型

    谁用过AD7712吗,从AD7712读取的数据C语言中是保存为什么数据类型啊,long int 吗?我用AD7712对波形进行数字化,AD7712输出的
    发表于 12-13 09:33

    详解C语言变量和数据类型

    C语言大家都不陌生吧,计算机、电子信息、通信工程、自动化等专业的必学课程,前面和大家介绍过C语言的历史和编程环境,今天再来介绍一下变量和数据类型
    的头像 发表于 12-11 10:40 780次阅读
    详解<b class='flag-5'>C</b><b class='flag-5'>语言</b>变量和<b class='flag-5'>数据类型</b>

    oracle的数据类型有哪些

    Oracle数据库中有许多数据类型可供选择,每种数据类型都有其各自的特点和适用场景。下面是对Oracle数据库中最常用的数据类型的详尽说明,
    的头像 发表于 12-05 16:45 2225次阅读

    php的数据类型主要有哪几种

    PHP是一种强类型编程语言,它支持多种数据类型。以下是PHP的主要数据类型: 字符串(String): 表示文本数据,可以使用单引号或双引号
    的头像 发表于 12-04 16:05 659次阅读

    c语言整型数据的溢出计算

    计算原理,介绍其风险及可能带来的后果,并提供一些应对策略和措施,旨在帮助程序员理解溢出问题并提供有效的解决方案。 一、溢出计算原理 1.1 数据类型与范围 C语言中的整型数据类型包括c
    的头像 发表于 11-30 11:45 2969次阅读

    c语言中decimal的含义

    C语言中的“decimal”是一种数据类型,用于表示十进制数字。在C语言中,常用的数据类型有整数
    的头像 发表于 11-30 10:57 2222次阅读

    c语言程序设计基础知识点

    程序设计的基础知识点。 首先,我们将从C语言数据类型和变量开始。C语言提供了多种数据类型,包括
    的头像 发表于 11-27 15:25 1562次阅读

    C语言里的整数数据类型

    1. 整型数据类型 C语言里面的整数数据类型 类型名称 C
    的头像 发表于 11-24 16:09 886次阅读
    <b class='flag-5'>C</b><b class='flag-5'>语言</b>里的整数<b class='flag-5'>数据类型</b>

    redis的五种数据类型底层数据结构

    Redis是一种内存数据存储系统,支持多种数据结构。这些数据结构不仅可以满足常见的存储需求,还能够通过其底层数据结构提供高效的操作和查询。以
    的头像 发表于 11-16 11:18 671次阅读

    redis的五种数据类型

    Redis是一种高性能的内存数据库,常用于缓存、任务队列、分布式锁等场景。它提供了多种数据类型来满足各种不同的需求,包括字符串(string)、哈希(hash)、列表(list)、集合
    的头像 发表于 11-16 11:06 589次阅读

    如何将ROS数据类型转换为MATLAB数据类型

    。 例如,四元数消息包含w、x、y和z属性,但该消息并不强制四元数作为一个整体是有效的。所以有可能在单独修改一个四元数信息后,这个四元数是不符合模型的。 同时消息属性还可以具有各种数据类型。MATLAB使用ROS设置的规则来确定这些数据类型。 为此,这些
    的头像 发表于 11-15 15:24 529次阅读
    如何将ROS<b class='flag-5'>数据类型</b>转换为MATLAB<b class='flag-5'>数据类型</b>