没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
试读
4页
个人整理sizeof()用法汇总 sizeof()用法汇总 sizeof()功能:计算数据空间的字节数 1.与strlen()比较 strlen()计算字符数组的字符数,以"\0"为结束判断,不计算为'\0'的数组元素。 而sizeof计算数据(包括数组、变量、类型、结构体等)所占内存空间,用字节数表示。 2.指针与静态数组的sizeof操作 指针均可看为变量类型的一种。所有指针变量的sizeof 操作结果均为4。 注意:int *p; sizeof(p)=4; 但sizeof(*p)相当于sizeof(int); 对于静态数组,sizeof可直接计算数组大小; 例:int a[10];char b[]="hello"; sizeof(a)等于4*10=40; sizeof(b)等于6; 注意:数组做型参时,数组名称当作指针使用!! void fun(char p[]) {sizeof(p)等于4}
资源推荐
资源详情
资源评论
sizeof()用法汇总
sizeof()功能:计算数据空间的字节数
1.与 strlen()比较
strlen()计算字符数组的字符数,以" "为结束判断,不计算为' '的数组元素。
而 sizeof 计算数据(包括数组、变量、类型、结构体等)所占内存空间,用字节数表示。
2.指针与静态数组的 sizeof 操作
指针均可看为变量类型的一种。所有指针变量的 sizeof 操作结果均为 4。
注意:int *p; sizeof(p)=4;
但 sizeof(*p)相当于 sizeof(int);
对于静态数组,sizeof 可直接计算数组大小;
例:int a[10];char b[]="hello";
sizeof(a)等于 4*10=40;
sizeof(b)等于 6;
注意:数组做型参时,数组名称当作指针使用!!
void fun(char p[])
{sizeof(p)等于 4}
经典问题:Y
double* (*a)[3][6];
cout<<sizeof(a)<<endl; // 4a 为指针
cout<<sizeof(*a)<<endl; // 72*a 为一个有 3*6 个指针元素的数组
cout<<sizeof(**a)<<endl; // 24**a 为数组一维的 6 个指针
cout<<sizeof(***a)<<endl; // 4***a 为一维的第一个指针
cout<<sizeof(****a)<<endl; // 8****a 为一个 double 变量
问题解析:a 是一个很奇怪的定义,他表示一个指向 double*[3][6]类型数组的指针。既然
是指针,所以 sizeof(a)就是 4。Y
既然 a 是执行 double*[3][6]类型的指针,*a 就表示一个 double*[3][6]的多维数组类型,
因此 sizeof(*a)=3*6*sizeof(double*)=72。同样的,**a 表示一个 double*[6]类型的数组,
所以 sizeof(**a)=6*sizeof (double*)=24。***a 就表示其中的一个元素,也就是 double*
了,所以 sizeof(***a)=4。至于****a,就是一个 double 了,所以
sizeof(****a)=sizeof(double)=8。Y
3.格式的写法
sizeof 操作符,对变量或对象可以不加括号,但若是类型,须加括号。
4.使用 sizeof 时 string 的注意事项
string s="hello";
sizeof(s)等于 string 类的大小,sizeof(s.c_str())得到的是与字符串长度。
5.union 与 struct 的空间计算
总体上遵循两个原则:
(1)整体空间是Y占用空间最大的成员(的类型)所占字节数的整倍数
(2)数据对齐原则----内存按结构成员的先后顺序排列,当排到该成员变量时,
其前面已摆放的空间大小必须是该成员类型大小的整倍数,如果不够则补齐,
以此向后类推。。。。。
注意:数组按照单个变量一个一个的摆放,而不是看成整体。如果成员中有
自定义的类、结构体,也要注意数组问题。
资源评论
feiniao200201
- 粉丝: 0
- 资源: 910
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- Screenshot_20240427_031602.jpg
- 网页PDF_2024年04月26日 23-46-14_QQ浏览器网页保存_QQ浏览器转格式(6).docx
- 直接插入排序,冒泡排序,直接选择排序.zip
- 在排序2的基础上,再次对快排进行优化,其次增加快排非递归,归并排序,归并排序非递归版.zip
- 实现了7种排序算法.三种复杂度排序.三种nlogn复杂度排序(堆排序,归并排序,快速排序)一种线性复杂度的排序.zip
- 冒泡排序 直接选择排序 直接插入排序 随机快速排序 归并排序 堆排序.zip
- 课设-内部排序算法比较 包括冒泡排序、直接插入排序、简单选择排序、快速排序、希尔排序、归并排序和堆排序.zip
- Python排序算法.zip
- C语言实现直接插入排序、希尔排序、选择排序、冒泡排序、堆排序、快速排序、归并排序、计数排序,并带图详解.zip
- 常用工具集参考用于图像等数据处理
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功