1. 分析字节对齐:
分析一:int 4,enum 4,union 14(因为 pack(2)),总22.
分析二:int i:4字节;
union:13字节(共用内存),2字节对齐,13+1=14字节。
enum:3字节。2字节对齐,3+1=4
分析三:
int i,得到4个字节。
union对齐方法:
char buff[13]与int i,char类型1个字节,int 4个字节,取较大的4个字节;然后与系统默认对比,由于设置了pack(2),系统默认为2。取较小的,即2个字节对齐。union就是2字节对齐。
但是union本身占用13个字节,以2对齐,所以最终为14个字节。
最后那个4字节,不用说了。
需要注意,不论char buff[]有都大,对齐是根据数据类型对齐。
还有一点,由于各个数据成员都可以乘除2,所以数据成员之间不需要padding,并且结构体中最长为4,系统默认为2,所以最终结构体也不需要padding。
union和struct类型的大小计算
2、关于下列程序:
unsigned long val= 0;
char a= 0x48;
char b= 0x52;
val = b<<8 |a;
执行完代码,VAL的值是:21064
分析:
val = b << 8 | a; //0x52=01010010左移8位为:010100100000000
=010100100000000|01001000
=0101001001001000
=0x5248 //16进制
=21064 //10进制
3、
分析:
理由如下:
1.c_str()返回值是const char*,返回一个指向正规C字符串的指针;
2.string b=a是C++中string类的赋值操作,b会开辟一个与a同等长度的内存空间,把a的字符串拷贝到b的内存空间中;
所以if(a.c_str()==b.c_str())比较的是2个const char*,很显然是不等的。
c++中c_str()的用法详解
c++中string类成员函数c_str()的用法
语法:
const char *c_str();
c_str()函数返回一个指向正规C字符串的指针, 内容与本string串相同.
这是为了与c语言兼容,在c语言中没有string类型,故必须通过string类对象的成员函数c_str()把string 对象转换成c中的字符串样式。
注意:一定要使用strcpy()函数 等来操作方法c_str()返回的指针
比如:最好不要这样:
char* c;
string s="1234";
c = s.c_str(); //c最后指向的内容是垃圾,因为s对象被析构,其内容被处理
应该这样用:
char c[20];
string s="1234";
strcpy(c,s.c_str());
这样才不会出错,c_str()返回的是一个临时指针,不能对其进行操作
再举个例子
c_str() 以 char* 形式传回 string 内含字符串
如果一个函数要求char*参数,可以使用c_str()方法:
string s = "Hello World!";
printf("%s", s.c_str()); //输出 "Hello World!"