下面列举了Dev-C++下基本类型所占位数和取值范围:

基本型                          所占位数              取值范围                输入符举例                                 输出符举例

-- -- char                            8                        -2^7 ~ 2^7-1              %c                                         %c、%d、%u
    
    signed -- char                    8                         -2^7 ~ 2^7-1              %c                                           %c、%d、%u
    
    unsigned -- char                8                          0 ~ 2^8-1                  %c                                            %c、%d、%u
    
    [signed] short [int]            16                            -2^15 ~ 2^15-1        %hd                                              %hd
    
    unsigned short [int]           16                            0 ~ 2^16-1           %hu                                  %hu、%ho、%hx
    
    [signed] -- int                    32                        -2^31 ~ 2^31-1         %d
    
    unsigned -- [int]                 32                        0 ~ 2^32-1              %u、%o、%x
    
    [signed] long [int]              32                       -2^31 ~ 2^31-1         %ld
    
    unsigned long [int]             32                         0 ~ 2^32-1               %lu、%lo、%lx
    
    [signed] long long [int]       64                        -2^63 ~ 2^63-1              %I64d
    
    unsigned long long [int]      64                    0 ~ 2^64-1                 %I64u、%I64o、%I64x
    
    -- -- float                            32                    +/- 3.40282e+038              %f、%e、%g
    
    -- -- double                        64                +/- 1.79769e+308                   %lf、%le、%lg %f、%e、%g
    
    -- long double                    96                   +/- 1.79769e+308          %Lf、%Le、%Lg

注意:int型数据  在不同位数的系统中   所占位数不一样   一些编译器不同也有影响

16         2*8位

32         4*8位

64         8*8位

1 BYTE=8 BIT

内存对齐可以用一句话来概括:

“数据项只能存储在地址是数据项大小的整数倍的内存位置上”

例如int类型占用4个字节,地址只能在0,4,8等位置上。

double类型占用8个字节,地址只能在0,8,16等位置上面

如果代码之中有特别规定的话     对齐方式以程序为主

#pragma pack(n)

如果在代码之中出现了上面的语句

那么对齐机制   为地址只能在0,n,2*n,3*n等位置上面

 #include <iostream>
#include <cstdlib>
#include <pthread.h>
#include <windows.h>
using namespace std;
struct X1
{
int i;//4个字节
char c1;//1个字节
char c2;//1个字节
long a;//4个字节
float b;
} x1;
struct X2
{
char c1;//1个字节
int i;//4个字节
char c2;//1个字节
long a;//4个字节
float b;
} x2;
struct X3
{
char c1;//1个字节
char c2;//1个字节
int i;//4个字节
long a;//4个字节
float b;
} x3;
struct X4
{
int i;//4个字节
char c1;//1个字节
char c2;//1个字节
long a;//4个字节
float b;
} x4;
int main()
{
cout<<"long "<<sizeof(long)<<"\n";
cout<<"float "<<sizeof(float)<<"\n";
cout<<"int "<<sizeof(int)<<"\n";
cout<<"char "<<sizeof(char)<<"\n";
cout<<"x1 的大小 "<<sizeof(x1)<<"\n";
cout<<"x2 的大小 "<<sizeof(x2)<<"\n";
cout<<"x3 的大小 "<<sizeof(x3)<<"\n";
cout<<"x4 的大小 "<<sizeof(x4)<<"\n";
return ;
}
运行结果:
long
float
int
char
x1 的大小
x2 的大小
x3 的大小
x4 的大小

三个结构体   结构体中的数据都是一样的  但是结构体所占的空间不一样   这就是对齐机制对于存储的影响

C/C++ 面试-内存对齐 即不同数据类型存储空间的更多相关文章

  1. 【校招面试 之 C/C++】第3题 为什么要内存对齐?以及内存对齐的方式

    1.为什么要进行内存对? 参考:https://blog.csdn.net/a369000753/article/details/51188915 所谓内存对齐,是为了让内存存取更有效率而采用的一种编 ...

  2. C/C++: C++位域和内存对齐问题

    1. 位域: 1. 在C中,位域可以写成这样(注:位域的数据类型一律用无符号的,纪律性). struct bitmap { unsigned a : ; unsigned b : ; unsigned ...

  3. C/C++ 知识点1:内存对齐

    预备知识:基本类型占用字节 在32位操作系统和64位操作系统上,基本数据类型分别占多少字节呢? 32位操作系统: char : 1    int :4    short : 2    unsigned ...

  4. C语言再学习之内存对齐

    昨天看Q3的代码,看到有个_INTSAIZEOF的宏,着实晕了一阵.一番google后,终于明白,这个宏的作用是求出变量占用内存空间的大小,先看看_INTSAIZEOF的定义吧: #define _I ...

  5. C结构体中数据的内存对齐问题

    转自:http://www.cnblogs.com/qwcbeyond/archive/2012/05/08/2490897.html 32位机一般默认4字节对齐(32位机机器字长4字节),64位机一 ...

  6. struct内存对齐1:gcc与VC的差别

    struct内存对齐:gcc与VC的差别 内存对齐是编译器为了便于CPU快速访问而采用的一项技术,对于不同的编译器有不同的处理方法. Win32平台下的微软VC编译器在默认情况下采用如下的对齐规则:  ...

  7. C++成员变量内存对齐问题,ndk下非对齐的内存访问导致BUS_ADRALN

    同样的代码,在vs下运行正常,在android ndk下却崩溃: signal 7(SIGBUS),code 1 (BUS_ADRALN),fault addr 0xe6b82793 Func(sho ...

  8. c语言内存对齐问题

    #include <stdio.h>#pragma pack(4)struct stu{char a;short b;int c;char d;};int main(){printf(&q ...

  9. 【转】C/C++ struct/class/union内存对齐

    原文链接:http://www.cnblogs.com/Miranda-lym/p/5197805.html struct/class/union内存对齐原则有四个: 1).数据成员对齐规则:结构(s ...

随机推荐

  1. 【Beta】Scrum meeting3

    第三天:2019/6/26 前言: 第3次会议于6月26日在教9-501召开. 对每个人负责撰写的文档进行分配,并讨论其中模糊的问题,时长30min. 本日任务完成情况 成员 今日完成任务情况 成员贡 ...

  2. Python开发应用-正则表达进行排序搜索

    re模块提供了3个方法对输入的字符串进行确切的查询,match和search最多只会返回一个匹配条件的子串,可以理解为非贪婪模式,而findall会返回N个匹配条件的子串,可以理解为贪婪模式 re.m ...

  3. postgresql从库提升为主库

    一.停主库 1.查看当前连接 select pid,datname,usename,client_addr,client_port, application_name from pg_stat_act ...

  4. 读取txt写入excel

    import csv #实现的思想:首先从txt中读取所有的内容,NUM=1当做键,其他当做值,如果查找缺少a,b,c,d,e,f,g# 则NUM不会添加到字典中,然后通过所有的NUM和字典中的KEY ...

  5. 使用mybatis框架实现带条件查询-单条件

    之前我们写的查询sql都是没有带条件的,现在来实现一个新的需求,根据输入的字符串,模糊查询用户表中的信息 UserMapper.xml UserMapper.java 与jdbc的比较: 编写测试方法 ...

  6. 【NOIP 2017】宝藏 D2 T2

    参考From 传送门 写的很清晰了 AC code: #include <bits/stdc++.h> using namespace std; const int MAXN = 12; ...

  7. Codeforces Round #605 (Div. 3) C. Yet Another Broken Keyboard

    链接: https://codeforces.com/contest/1272/problem/C 题意: Recently, Norge found a string s=s1s2-sn consi ...

  8. 3-ESP8266 SDK开发基础入门篇--点亮一个灯

    https://www.cnblogs.com/yangfengwu/p/11072834.html 所有的源码 https://gitee.com/yang456/Learn8266SDKDevel ...

  9. 分类模型的性能评价指标(Classification Model Performance Evaluation Metric)

    二分类模型的预测结果分为四种情况(正类为1,反类为0): TP(True Positive):预测为正类,且预测正确(真实为1,预测也为1) FP(False Positive):预测为正类,但预测错 ...

  10. 前端微信小程序生鲜类仿爱鲜蜂微信小程序

    需求描述及交互分析设计思路和相关知识点首页界面布局设计闪送超市纵向导航设计商品添加到购物车设计购物车商品显示设计收货地址列表显示设计新增收货地址设计 交互分析(1)底部标签导航有首页.闪送超市.购物车 ...