C++主要数据类型在计算机中所占字节大小

遇到了数据存储的大端和小端问题,这你妹的看的一头雾水,发现我基本知识严重匮乏啊,先了解C++各数据类型在自己机子上占多少字节吧,以及这些数据类型所占字节大小与神马有关。各种查资料然后写代码检验,小结于本文中,给自己补补基础知识。

先来列一下C++的数据类型:

整型:int,long。这两个还分signed(有符号)和unsigned(无符号)的,当然有符号和无符号所占字节大小是一样的,就不管他了。

布尔型:bool

字符型:char,wchar_t

浮点型:float,double

这只能上代码验证了,貌似机子不同数据类型所占大小也不同,太威武了,我就检查下我这个32位windows系统电脑吧。我用的IDE是Code::Blocks,发现挺好用的,主要是工程文件小,不像vs2010建个工程就大得很,哥这小硬盘吃不消啊(题外话)。

先看整型的吧,代码如下:


1

2

3

4

5

6

7

8

9

10

11

12

13

14

#include <iostream>

using namespace std;

int main()

{

    int a;

    long b;

    int Byteof_int=sizeof(a);

    int Byteof_long=sizeof(b);

    cout << "int:" <<Byteof_int<<endl;

    cout << "long:" <<Byteof_long<<endl;

    return 0;

}

结果显示:

int:4

long:4

int和long都是占4个字节(即32位)。

其他数据类型验证吧上面代码数据类型替换下就是了,得出下面的结果:

bool:1

char:1

wchar_t:2

float:4

double:8

特别要注意的时,对于指针类型,都占4个字节,因为指针指向的是一个地址,32位操作系统就是4字节。当然如果是64位操作系统那就是8字节了。

此外,int这个类型占操作系统一个内存单元大小。早先16位操作系统一个内存单元是64位,所以是2个字节;32位系统一个内存单元是是32位,所以是4字节;64位操作系统一个内存单元是16位,故占8个字节。

因为用到MFC编程,mfc里还有很多数据类型啊,看看吧(这只是一部分,还有很多用typedef和宏定义的类型)。

BOOL:int型,Boolean值(TRUE or FALSE)

BSTR:32-bit字符指针

BYTE:8-bit整数,无正负号

COLORREF:32-bit数值,代表一个颜色值

DWORD:32-bit整数,无正负号

LONG:32-bit整数,有正负号

LPARAM:32-bit数值,作为窗口函数或callback函数的一个参数

LPCSTR:32-bit指针,指向一个常数字符串

LPSTR:32-bit指针,指向一个字符串

LPCTSTR:32-bit指针,指向一个常数字符串。此字符串可移植到Unicode

LPTSTR:32-bit指针,指向一个字符串。此字符串可移植到Unicode

LPVOID:32-bit指针,指向一个未指定类型的数据

LPRESULT:32-bit数值,作为窗口函数或callback函数的返回值

UINT:Win16中,16-bit无正负号,Win32中,32-bit无正负号

WNDPROC:32-bit

WORD:16-bit整数,无正负号

WPARAM:窗口函数的一个参数,Win16中16bits,Win32中32bits

时间: 2024-11-02 11:28:01

C++主要数据类型在计算机中所占字节大小的相关文章

结构体在内存中所占字节大小计算

作者 :卿笃军 今天上课,老师给我们演示了一下,计算结构体在内存中所占的字节大小.开始给了我们几个例子,然后要我们自己摸索出规律. 注:以下测试全是在win7_64bit  Devcpp 5.5.3环境下测试的.(char 1字节,int 4字节, double 8字节). 也许:你可能认为下面这个答案是 1+4 = 5   (×) #include <stdio.h> struct node { char a; int b; }; int main() { struct node QING;

sizeof运算符来获取各种数据类型在内存中所占字节数--gyy整理

C++并没有规定各种数据类型在内存中的存储大小,依赖于不同的编译器的不同而不同,要想获知当前编译器对各种数据类型分配的大小,可以通过sizeof运算符来获取. 使用方法1: sizeof(数据类型)   使用方法2: sizeof(变量名   或 常量名 或 表达式  ) sizeof(int)      或 int  a: sizeof(a) [cpp] view plain copy //数据类型空间分配情况 #include <iostream> using namespace std;

计算机中地址和内存大小的计算和编译出来的数据段

由地址计算内存大小(消除模糊认知) 在计算机中一个地址代表一个字节的内存的位置,即这个byte的门牌号,所以如果给出地址空间的起始地址是可以计算出内存大小的,比如STM32中Flash可编程的地址是从0x0800 0000开始到0x0801FFFF结束的所以内存大小的计算过程如下: 地址差 = 结束地址 - 开始地址  =  0x0001FFFF:他们可以表示的Byte的个数是N = 0x0001 FFFF + 1即0x00020000将N变换为十进制是131072. 内存大小 = N/1024

C语言的常用的数据类型有哪些_所占字节分别是多少

整型 整形打印使用%d short:短整型,占16位,2个字节 int:占32位,4个字节 long:长整型,占4个字节,本来意思比int更多,但是目前来看基本都是和int一样 浮点型 浮点型计算会影响计算机性能,所以不是做科学计算尽量不用浮点型 浮点型打印使用%f float:占32位,4个字节,精度会低一点 double:占32位,4个字节,精度会高一点 字符类型 字符类型打印使用:%c char:占8位,1个字节 无符号类型 void:空类型,一般在使用指针的时候会使用 原文地址:http

结构体所占字节大小计算以及共用体大小计算

#include<stdio.h> struct student{ int num; char sex; float score; } ; union data{ int k; char ch; float f; }; int main(void){ printf("%d\n",sizeof(struct student)); printf("%d",sizeof(union data)); } 详细计算见:https://blog.csdn.net/u

负数在计算机中的表示 Byte-128

http://blog.csdn.net/njuitjf/article/details/4585247 今天,老大让我调查一个浮点数转换为整数的问题.自己就查了些资料,顺便复习一下原码.反码和补码. 原码:将一个整数,转换成二进制,就是其原码.如单字节的5的原码为:0000 0101:-5的原码为1000 0101. 反码:正数的反码就是其原码:负数的反码是将原码中,除符号位以外,每一位取反.如单字节的5的反码为:0000 0101:-5的原码为1111 1010. 补码:正数的补码就是其原码

原码、反码、补码,计算机中负数的表示

原码:将一个整数,转换成二进制,就是其原码.                如单字节的5的原码为:0000 0101:-5的原码为1000 0101. 反码:正数的反码就是其原码:负数的反码是将原码中,除符号位以外,每一位取反.                如单字节的5的反码为:0000 0101:-5的反码为1111 1010. 补码:正数的补码就是其原码:负数的反码+1就是补码.                如单字节的5的补码为:0000 0101:-5的原码为1111 1011. 在计

计算机中信息表示

1.概述 现在的我们无时无刻不在接触计算机,即常说的电脑.计算机能干很多事,比如浏览网页.看视频.玩游戏.办公等,实现这些功能都需要计算机有信息存储和处理的能力.现代计算机的信息存储和处理都以二进制为基础,简单来说我们在电脑上看到的信息(比如文字.图片.音频.视频)都是以二进制表示的形式存储在计算机上或被计算机以二进制这种形式处理的.比如我们在计算机上的记事本中写日记,写入的是中文,在计算机中是以二进制编码(01010......)存储的,同时会给这些二进制编码指定一种解释方式,比如GB2312

c++中各种数据类型所占字节

求各种数据类型所占用的字节数可调用sizeof函数,求各种数据类型的最大值可以调用limits标准库中的numeric_limits<T>::max(),numeric_limits<T>::min()函数 #include<iostream> #include<string> #include <limits> using namespace std; int main() { cout << "type: \t\t&qu