c语言详解sizeof

一、sizeof的概念  

  sizeof是C语言的一种单目操作符,如C语言的其他操作符++、--等。

它并不是函数。

sizeof操作符以字节形式给出了其操作数的存储大小。

操作数可以是一个表达式或括在括号内的类型名。

操作数的存储大小由操作数的类型决定。 

二、sizeof的使用方法  

  1、用于数据类型 

  sizeof使用形式: sizeof(type)
  数据类型必须用括号括住: sizeof(int)

  2、用于变量 

  sizeof使用形式: sizeof(var_name) 或 sizeof var_name    
  变量名可以不用括号括住.如sizeof (var_name),sizeof var_name等都是正确形式

带括号的用法更普遍,大多数程序员采用这种形式。 

  注意:sizeof操作符不能用于函数类型,不完全类型或位字段。

不完全类型指具有未知存储大小的数据类型,

如未知存储大小的数组类型、未知内容的结构或联合类型、void类型等。    
  例如: sizeof(max)        --若此时变量max定义为int max();

sizeof(char_v)    --若此时char_v定义为char char_v[MAX]且MAX未知,

sizeof(void)

以上都是不正确形式。 

三、sizeof的结果(以下结果都是在Linux v2.6 gcc v4获取)

  sizeof操作符的结果类型是size_t

它在头文件中定义为: typedef unsigned int size_t;

该类型保证能容纳实现所建立的最大对象的字节大小.

  1、ANSI C正式规定字符类型为1字节。    
    sizeof(char)          = 1;

sizeof(unsigned char) = 1;

sizeof(signed char)   = 1;
  
  2、其他类型在ANSI C中没有具体规定,大小依赖于实现。

    
    sizeof(int)            = 4;

sizeof(unsigned int)   = 4;

sizeof(short int)      = 2;

sizeof(unsigned short) = 2;

sizeof(long int)       = 4;

sizeof(unsigned long)  = 4;

sizeof(float)          = 4;

sizeof(double)         = 8;

sizeof(long double)    = 12;

  3、当操作数是指针时,sizeof依赖于编译器。

Microsoft C/C++7.0中,near类指针字节数为2,far、huge类指针字节数为4。

一般Unix/Linux的指针字节数为4。 

例如: char *p;      //Linux中

sizeof(p) = 4;

  4、当操作数具有数组类型时,其结果是数组的总字节数。

例如: char a[5];

int  b[5];

sizeof(a) = 5;

sizeof(b) = 20;

5、当操作数是具体的字符串或者数值时,会根据具体的类型进行相应转化。

例如: sizeof(8)    = 4;  //自动转化为int类型

sizeof(8.8)  = 8;  //自动转化为double类型,注意,不是float类型

sizeof("ab") = 3   //自动转化为数组类型,

//长度是4,不是3,因为加上了最后的‘\n‘符

//有资料说,会自动转化为指针类型(Linux为4)

//可能和操作系统与编译器有关系

  6、当操作数是联合类型时,sizeof是其最大字节成员的字节数。

当操作数是结构类型时,sizeof是其成员类型的总字节数,包括补充字节在内。 

还是让我们拿例子来说话:

union  u{             //对union来说

char c;

double d;

}u;

sizeof(u) = max(sizeof(c),sizeof(d)) = sizeof(1,8) = 8;

  struct a{             //对struct来说

char b; 

double x;

}a;   
  在Linux上: sizeof(a) = 12;

而一般sizeof(char) + sizeof(double) = 9; 
  这是因为编译器在考虑对齐问题时,在结构中插入空位以控制各成员对象的地址对齐。

但如果全对齐的话,sizeof(a) = 16, 这是因为b被放到偏移量为0的地址,占1个字节;

在存放x时,double类型长度为8,需要放到能被8整除的偏移量上,这时候需要补7个空字节,

达到8个,这时候偏移量为8,放上x后长度为16。

在此例中,所有的结构成员都要放在被4整除的地址(Linux的存放方式),这里补3个字节,所以为12。

  7、当操作数是函数中的数组形参或函数类型的形参:

sizeof给出其指针的大小,Linux中值为4。

四、sizeof与其他操作符的关系  

  sizeof的优先级为2级,比/、%等3级运算符优先级高。

它可以与其他操作符一起组成表达式:

例如: int i = 10;

i * sizeof(int);

五、sizeof的主要用途  

  1、主要用途是与存储分配和I/O系统那样的例程进行通信。

例如: void *malloc(size_t size);
        size_t fread(void *ptr, size_t size, size_t nmemb, FILE * stream); 

  2、另一个的主要用途是计算数组中元素的个数。

例如: void *memset(void *s, int c, sizeof(s)); 

时间: 2024-10-06 21:05:03

c语言详解sizeof的相关文章

邻接表无向图(一)之 C语言详解

本章介绍邻接表无向图.在"图的理论基础"中已经对图进行了理论介绍,这里就不再对图的概念进行重复说明了.和以往一样,本文会先给出C语言的实现:后续再分别给出C++和Java版本的实现.实现的语言虽不同,但是原理如出一辙,选择其中之一进行了解即可.若文章有错误或不足的地方,请不吝指出! 目录 1. 邻接表无向图的介绍 2. 邻接表无向图的代码说明 3. 邻接表无向图的完整源码 转载请注明出处:http://www.cnblogs.com/skywang12345/ 更多内容:数据结构与算法

Prim算法(一)之 C语言详解

本章介绍普里姆算法.和以往一样,本文会先对普里姆算法的理论论知识进行介绍,然后给出C语言的实现.后续再分别给出C++和Java版本的实现. 目录 1. 普里姆算法介绍 2. 普里姆算法图解 3. 普里姆算法的代码说明 4. 普里姆算法的源码 转载请注明出处:http://www.cnblogs.com/skywang12345/ 更多内容:数据结构与算法系列 目录 普里姆算法介绍 普里姆(Prim)算法,和克鲁斯卡尔算法一样,是用来求加权连通图的最小生成树的算法. 基本思想 对于图G而言,V是所

哈夫曼树(一)之 C语言详解

本章介绍哈夫曼树.和以往一样,本文会先对哈夫曼树的理论知识进行简单介绍,然后给出C语言的实现.后续再分别给出C++和Java版本的实现:实现的语言虽不同,但是原理如出一辙,选择其中之一进行了解即可.若文章有错误或不足的地方,请帮忙指出! 目录 1. 哈夫曼树的介绍 2. 哈夫曼树的图文解析 3. 哈夫曼树的基本操作 4. 哈夫曼树的完整源码 转载请注明出处:http://www.cnblogs.com/skywang12345/ 更多内容:数据结构与算法系列 目录 哈夫曼树的介绍 Huffman

原来Github上的README.md文件这么有意思——Markdown语言详解(sublime text2 版本)

一直想学习 Markdown 语言,想起以前读的一篇 赵凯强 的 博客 <原来Github上的README.md文件这么有意思——Markdown语言详解>,该篇博主 使用的是Mac系统,所以推荐使用Mou,本人使用 Win7 系统所以想写一篇 sublime text2 的版本

邻接矩阵有向图(一)之 C语言详解

本章介绍邻接矩阵有向图.在"图的理论基础"中已经对图进行了理论介绍,这里就不再对图的概念进行重复说明了.和以往一样,本文会先给出C语言的实现:后续再分别给出C++和Java版本的实现.实现的语言虽不同,但是原理如出一辙,选择其中之一进行了解即可.若文章有错误或不足的地方,请不吝指出! 目录 1. 邻接矩阵有向图的介绍 2. 邻接矩阵有向图的代码说明 3. 邻接矩阵有向图的完整源码 转载请注明出处:http://www.cnblogs.com/skywang12345/ 更多内容:数据结

README.md文件 github Markdown语言详解 md文件用法和说明

本人使用.md文档完全为了记录日常的编译和工作中遇到的问题,需要用到的功能大概就是常用的语法,强调,引用,代码,链接等.对于图片的插入需求不高,因此本文主要介绍一些语法特点,最后涉及一点可能用到的其他功能. 000-->功能函数详细条目: 区块元素 段落和换行 一个 Markdown 段落是由一个或多个连续的文本行组成,它的前后要有一个以上的空行(空行的定义是显示上看起来像是空的,便会被视为空行.比方说,若某一行只包含空格和制表符,则该行也会被视为空行).普通段落不该用空格或制表符来缩进. 「由

原来Github上的README.md文件这么有意思——Markdown语言详解

转载请注明出处:http://blog.csdn.net/zhaokaiqiang1992 之前一直在使用github,也在上面分享了不少的项目和Demo,每次创建新项目的时候,使用的都是默认的README.md文件,也不曾对这个文件有 过什么了解.但是在看到别人写的项目的README.md里面竟然有图片.链接什么的,就感到很好奇,这效果是什么加上去的?于是便查了一下资料,结果, 竟迁出了一门从来没有了解过的语言— —Markdown! github上的README.md文件就是使用的Markd

Django 模版语言详解

一.简介 模版是纯文本文件.它可以产生任何基于文本的的格式(HTML,XML,CSV等等). 模版包括在使用时会被值替换掉的 变量,和控制模版逻辑的 标签. 例: {% extends "base_generic.html" %} {% block title %}{{ section.title }}{% endblock %} {% block content %} <h1>{{ section.title }}</h1> {% for story in s

Kruskal算法(一)之 C语言详解

最小生成树 在含有n个顶点的连通图中选择n-1条边,构成一棵极小连通子图,并使该连通子图中n-1条边上权值之和达到最小,则称其为连通网的最小生成树.  例如,对于如上图G4所示的连通网可以有多棵权值总和不相同的生成树. 克鲁斯卡尔算法介绍 克鲁斯卡尔(Kruskal)算法,是用来求加权连通图的最小生成树的算法. 基本思想:按照权值从小到大的顺序选择n-1条边,并保证这n-1条边不构成回路. 具体做法:首先构造一个只含n个顶点的森林,然后依权值从小到大从连通网中选择边加入到森林中,并使森林中不产生