sizeof && strlen 的区别
本文主要记录了 sizeof 操作符 和 strlen() 函数的区别,以及各自的用途。(在下才疏学浅,发现错误,还请留言指正)
sizeof 和 strlen 的区别
示例代码如下:
#include<stdio.h>
int main()
{
char str[]="";
printf("strlen(str)==%d\n",strlen(str));//计算字符串的长度(不包括0x00),结果:10
printf("sizeof(str)==%d\n",sizeof(str));//大小不退化,结果:20 char* ss = "";
printf("strlen(ss)==%d\n",strlen(ss));//结果:10
printf("sizeof(ss)==%d\n",sizeof(ss));//计算ss指针占用内存空间的大小,结果:4
return ;
}
- 从代码着色我们就可以看出来,sizeof是操作符,strlen是函数。
- sizeof操作符的结果类型是size_t,它的头文件在typedef为unsigned int类型,无符号,可以存储最大对象字节的大小。
- sizeof可以用数据类型做参数,strlen只能使用char*做参数,且必须是以'\0'结尾的。
- 数组做sizeof不退化,但是,传递给strlen就退化为指针了。
- 大部分编译器在编译的时候sizeof就计算好了,这就是sizeof(x)可以用来定义数组维数的原因。strlen的结果要在运行的时候才能计算出来,他用来计算字符串的长度,不是类型占内存的大小。
- sizeof如果是类型的话,必须加括号,但是如果是变量名的话,可以不加括号,因为sizeof是个操作符,而不是函数。
sizeof有哪些作用?
- 与存储分配和i/o系统的例程进行通信。
void* malloc(size_t size);
size_t fread(void* ptr,size_t size,size_t nmemb,FILE* stream);
- 查看某个类型对象在内存中所占的单元字节。
void* memset(void* s,int c,sizeof(s));
- 在系统分配一对象时,让系统知道要分配多少个内存。
- 便于一些类型的扩充,在windows中很多结构类型就有一个专用的字段是用来存放该类型的字节的大小的。
- 由于操作符的字节数在实现时可能出现变化,建议在涉及操作数字节大小时用sizeof来代替常量计算。
- 如果,操作数是函数中的数值形参或函数类型的参数,则sizeof给出其指针的大小。
试着用sizeof 替换 strlen计算字符串的长度
像这种替换是很少用到的,之所以这样写,仅仅方便知识点的掌握。
//题意:计算字符串的长度,并转化大写。
#include <iostream>
#include<string>
using namespace std;
void upperCase(char str[])
{
int test = sizeof(str);//strlen(str)
int test2 =sizeof(str[]);
for(size_t i=;i<test/test2;++i)//i<test
{
if( 'a' <= str[i] && str[i] <= 'z' )
str[i] -= ('a' - 'A');
}
}
int main()
{
char str[] = "aBcDe";
//从上面我们知道sizeof(数组),是不退化的,返回的结果是整个数组的大小,而不是里面元素的个数。
//如果数组的初始化为 char str[9] = "aBcDe",那么结果就不正确了。
cout<<"The length of str is:"<<sizeof(str)/sizeof(str[])<<endl;//strlen(str)
upperCase(str);
cout << str << endl;
return ;
}
sizeof计算 union联合体的大小
示例代码1:
#include <iostream>
using namespace std;
union u
{
double a;
int b;
};
union u2
{
char a[];
int b;
};
union u3
{
char a[];
char b;
};
int main()
{
cout<<"sizeof(u) == "<<sizeof(u)<<endl;//结果:8
cout<<"sizeof(u2) == "<<sizeof(u2)<<endl;//结果:16(使用了字节对齐)
cout<<"sizeof(u3) == "<<sizeof(u3)<<endl;//结果:13(使用了字节对齐)
return ;
}
union的大小取决于成员中占用空间最大的那个成员(考虑字节的对齐),同时,考虑字节对齐的符合数据类型有:union,class,struct
CPU对齐的问题,编译器会尽量把数据放在它的对齐上以提高CPU的命中率。可以使用#pragma pack(x)来修改编译器的对齐方式。
C++固有类型的对齐取编译器对齐方式与自身大小中较小的一个。例如:编译器以2对齐,int类型大小是4,则int的对齐是2和4中最小的2.因为默认的对齐是8(long double),所以固有类型的对齐方式就是自身。如果是符合类型,则都小于8的话,取成员类型最大的对齐。
示例代码2:
#include <iostream>
using namespace std;
#pragma pack(2)//手动将对齐方式修改为2,所以int的对齐也为2了。所以结果10,如果去掉这一句,则为12
union u
{
char buf[];
int a;
};
int main()
{
cout<<"sizeof(u) == "<<sizeof(u)<<endl;
return ;
}
sizeof && strlen 的区别的更多相关文章
- sizeof和strlen的区别
一.sizeof sizeof(...)是运算符,而不是一个函数. sizeof操作符的结果类型是size_t,在头文件中typedef为unsigned int,其值在编译时即计算好了, ...
- Sizeof与Strlen的区别与联系
转自:http://www.cnblogs.com/carekee/articles/1630789.html 一.sizeof sizeof(...)是运算符,在头文件中typedef为uns ...
- Sizeof与Strlen的区别与联系(转)
Sizeof与Strlen的区别与联系 一.sizeof sizeof(...)是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可以是数组.指针.类型 ...
- C++-sizeof和strlen的区别
一.sizeof sizeof(...)是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可以是数组.指针.类型.对象.函数等. 它的功能是:获得保 ...
- sizeof和strlen的区别和联系总结
link:http://blog.csdn.net/ghevinn/article/details/9974967 strlen所作的仅仅是一个计数器的工作,它从内存的某个位置(可以是字符串开头 ...
- 【转】Sizeof与Strlen的区别与联系
原文地址:http://www.cnblogs.com/carekee/articles/1630789.html 1.sizeof sizeof(...)是运算符,在头文件中typedef为uns ...
- C++Sizeof与Strlen的区别与联系
一.sizeof sizeof(...)是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可以是数组.指针.类型.对象.函数等. 它的功能是:获得保 ...
- Sizeof与Strlen的区别【转】
本文转载自:http://www.cnblogs.com/carekee/articles/1630789.html Sizeof与Strlen的区别与联系 一.sizeof sizeof(.. ...
- sizeof, strlen区别
strlen与sizeof的区别 .sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型. 该类型保证能容纳实现所建立的最大对象的字节大小. .size ...
随机推荐
- PS:缝线颜色随着鞋帮颜色的改变发生改变.files
1.绘制逼真缝线 (1)新建两个图层,并且命名为“针眼”和“缝线”: (2)选择“铅笔”工具,像素为“2”: (3)在针孔图层上进行缝线路径描边,并双击图层,弹出“图层样式”窗口,选择“斜面与浮雕”- ...
- <%%>标签 什么意思
<%%>是说这里面的文本不是普通直接输出到客户端的文本,而是需要服务器来解释的.不光是可以写JAVA脚本,这要看具体服务器端使用的是什么技术ASP/JSP/PHP/ASP.NET都使用相同 ...
- codesmith生成java类
今天生成的时候的时候找不到类型转换的文件JavaAlias 后台发现我装完codesmith后,没有把类型转换类放入对应的文件 把System-JavaTableNameComments.csmap和 ...
- Java并发
Java并发编程:Thread类的使用 http://www.cnblogs.com/dolphin0520/p/3920357.html 一.线程的状态 在正式学习Thread类中的具体方法之前,我 ...
- python中zipfile文件名编码的问题
在python中编程导入压缩包,利用zipfile包,从zipinfo读取文件名总是出错,创建的文件名是乱码,写入pgsql更是出错. 但在ubuntu下测试却正常,在windows下测试总是失败. ...
- JavaScript-location:封装当前窗口正在打开的url的对象
location:封装当前窗口正在打开的url的对象 href:完整的url protocol:协议 host:主机名+端口 hostname:主机名 port:端口 pathname:路径 hash ...
- java获取文件名的三种方法
import java.io.File; import java.util.Arrays; public class FileName { /** * @param args */ public st ...
- java 线程安全不线程不安全
经常看到一些类,有的说线程安全,有的说线程不安全,顿时懵逼. 线程安全不安全,主要是在多线程执行的情况下,如果由于线程之间抢占资源而造成程序的bug即为线程不安全,下面就拿arraylist 和Vec ...
- 使用doxygen制作C代码文档
使用doxygen制作C代码文档 C 代码注释风格约定 行间注释 /*! * * 这里是注释 * */ 行内注释 <code here> /*! 这里是注释 */ doxygen 风格的宏 ...
- MIPS ABI n32意味着什么?
ABI是应用程序二进制接口的简称,用于标识处理器的工作模式及规范目标文件的编码格式. MIPS指令集架构自MIPS3起正式支持64位工作模式,故编码可以遵从o32(o意思是old).n32(n意思是n ...