题目:
下面程序结果是多少?
(一)
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <conio.h>
using namespace std;
int main(){
float a=1.0f;
cout<<(int)a<<endl;
cout<<&a<<endl;
cout<<(int &)a<<endl;//输出1065353216,(int&)a相当于将该浮点数地址开始的sizeof(int)个字节当成int数据输出
cout<<boolalpha<<((int)a==(int &)a)<<endl;
float b=0.0f;
cout<<(int)b<<endl;
cout<<&b<<endl;
cout<<(int &)b<<endl;
cout<<boolalpha<<((int)b==(int &)b)<<endl;
return 0;
}解析:该题实质上是考察了数据在内存中的存储方式以及数据的表示,是计算机组成原理中的内容
该题核心主要是对(int &)a的理解:
对于(int )a:这一点大家都知道,就是a的值强制转化成int型值,考察的是存储方式的内容
对于(int &)a:将a的引用强制转化成整型,意思是a所在的内存本来定义的时候为float类型,初始化为1.0f,但现在要按int类型解释这段程序,相当于*(int *)&a(将a的地址强制转化成int型指针,再取其内容)
(二)
#include <stdio.h>
int main(){
unsigned int a=0xfffffff7;
unsigned char i=(unsigned char)a;
char *b=(char*)&a;
printf("%08x, %08x",i,*b);
return 0;
}#include <stdio.h>
int main(){
unsigned int a=0xfffffff7;
unsigned char i=(unsigned char)a;
unsigned int *p=&a;
char *b=(char*)p;
printf("%08x, %08x",(++p),(++b));
return 0;
}原文:http://blog.csdn.net/starcuan/article/details/19707757