在工作中,我们常常碰到需要使用sizeof的场合,例如:使用内存“拷贝函数memcpy”,计算数组元素的个数等。。
但是你真的了解sizeof的用法吗?请看下面的题目(摘自《程序员面试宝典 第5版》)
-----------------------------------------------------------------------------------
例题1:下面的代码的输出结果是什么?(美国某著名计算机软硬件公司2005年、2007年面试题)
#include "stdio.h"
#include <iostream>
using namespace std;
struct
{
short a1;
short a2;
short a3;
}A;
struct
{
long a1;
short a2;
}B;
int main()
{
char *ss1 = "0123456789";
char ss2[] = "0123456789";
char ss3[100] = "0123456789";
int ss4[100];
char q1[] = "abc";
char q2[] = "a\n";
char *q3 = "a\n";
char *str1 = (char *)malloc(100);
void *str2 = (void *)malloc(100);
cout << sizeof(ss1) << " ";
cout << sizeof(ss2) << " ";
cout << sizeof(ss3) << " ";
cout << sizeof(ss4) << " ";
cout << sizeof(q1) << " ";
cout << sizeof(q2) << " ";
cout << sizeof(q3) << " ";
cout << sizeof(A) << " ";
cout << sizeof(B) << " ";
cout << sizeof(str1) << " ";
cout << sizeof(str2) << " ";
}
答案:
下面为结果分析:
(1)ss1是一个字符指针, 尽管它指向了占有11字节大小的常量子串,但是指针的大小是一定的,4个字节
(2)ss2 是一个字符数组,这个数组最初并未指定大小,它的大小由具体填充值来决定,填充值占11个字节,所以sizeof(ss2)的结果为11个字节
请注意ss1和ss2的区别,ss1是字符指针,ss2代表的是整个字符数组(),但他们2个不是同一类型,所以用sizeof得出的结果是不一样的
可以通过在程序后面加上下面两句
cout << typeid(ss1).name() << " ";
cout << typeid(ss2).name() << " ";
可以看到ss1和ss2的类型
(3)ss3是字符数组,它的大小已经定义为100,不会因为你存储的有效字节而改变它的大小,在本例中前11个字节存储为存储''0123456789"这个字串,后面会用0填充,所以结果为sizeof(ss3)的结果100
(4)对于ss4来说,请注意它存储的每个元素类型为int型,一个int占4个字节,100个元素自然就是占400个字节,结果为400
(5)q1占4个字节,结果为4
(6)q2占3个字节,'\n'是用转义字符表现的换行,占一个字符,结果为3
(7)q3为字符指针,指针占4个字节,结果为4
(8) A结构体占6个字节(3个short的大小),结果为6
(9)B结构体占 8个字节(考虑到内存对齐),结果为8
(10)str1为字符指针占4个字节,结果为4
(11) str2为void *指针,指针占4个字节,结果为4