(int)a&a(int)&a(int&)a的区别,很偏僻的题

#include <iostream>

#include <stdio.h>

#include <string.h>

#include <conio.h>

using namespace std;

int main()

{

float a = 1.0f;

cout <<
sizeof(int) <<endl;//4

cout << sizeof(float) <<endl;//4

cout << (int)a
<< endl;//1

cout << &a << endl; /*取a的地址十六进制0012FF7C*/

cout << (int)&a << endl;/*(int)&a:把a的地址强制转换成十进制的整型1245052*/

cout << (int&)a << endl;

/*(int&)a:将a的引用强制转换为整型,意思是a所在的内存,本来定义的时候为float类型,并初始为1.0f,

但现在我要按int类型解释这段内存(也就是说a所在的内存地址中的数据本来是按float型存储表示的,你非要按int型来解释不可)。

1.0f   在内存中的存储为

0   011   1111   1   000  
0000   0000   0000   0000   0000.

把他按整型数解释为2^29+2^28+2^27+2^26+2^25+2^24+2^23=1065353216

(int&)a 相当于

    *(int*)&a

*(int*)(&a)

*((int*)&a)

*/     



cout << boolalpha << ((int)a == (int&)a ) <<
endl;//   输出false.因为1!=1065353216.

float b = 0.0f;

cout << (int)b << endl;//0

cout << &b << endl;/*取b的地址十六进制0012FF78*/

cout << (int&)b << endl;//0

cout << boolalpha << ((int)b == (int&)b ) <<
endl;//   输出true,因为0==0;

/*

(int&)a   不经过转换,   直接得到a在内存单元(就是地址)的值   

(int)a     a在内存中的值转换成int类型   

    

float类型在内存中存储的形式是   ,符号位   指数   尾数   

由754标准:阶码采用增码(该数补码的反符号),尾数采用原码   

所以1.0f   在内存中的形式为   

0011   1111   1000   0000  
0000   0000   0000   0000   

所以输出的是   0x3f800000   

0   在内存中的的存储形式   

0000   0000   0000   0000  
0000   0000   0000   0000 

*/

return 0;

}

========================c语言中FLOAT 是如何表示的===========================

c语言中FLOAT 是如何表示的?尾数,阶码是如何在32位上安排的,即哪几位是 

尾数,哪几位是阶码,那一位是符号位。听说与CPU有关,是真的吗?

在C++里,实数(float)是用四个字节即三十二位二进制位来存储的。其中

有1位符号位,8位指数位和23位有效数字位。实际上有效数字位是24位,因为第

一位有效数字总是“1”,不必存储。 

    有效数字位是一个二进制纯小数。8位指数位中第一位是符号位,这符号位和

一般的符号位不同,它用“1”代表正,用”0“代表负。整个实数的符号位用“

1”代表负,“0”代表正。 

    在这存储实数的四个字节中,将最高地址字节的最高位编号为31,最低地址

字节的最低位编号为0,则实数各个部分在这32个二进制位中的分布是这样的:3

1位是实数符号位,30位是指数符号位,29---23是指数位,22---0位是有效数字

位。注意第一位有效数字是不出现在内存中的,它总是“1”。 

     

    将一个实数转化为C++实数存储格式的步骤为: 

    (1)先将这个实数的绝对值化为二进制格式,注意实数的整数部分和小数部

分化为二进制的方法是不同的。 

    (2)将这个二进制格式实数的小数点左移或右移n位,直到小数点移动到第

一个有效数字的右边。 

    (3)从小数点右边第一位开始数出二十三位数字放入第22到第0位。 

    (4)如果实数是正的,则在第31位放入“0”,否则放入“1”。 

    (5)如果n 是左移得到的,说明指数是正的,第30位放入“1”。如果n是右

移得到的或n=0,则第30位放入“0”。 

    (6)如果n是左移得到的,则将n减去一然后化为二进制,并在左边加“0”

补足七位,放入第29到第23位。如果n是右移得到的或n=0,则将n化为二进制后在

左边加“0”补足七位,再各位求反,再放入第29到第23位。 

     

    将一个计算机里存储的实数格式转化为通常的十进制的格式的方法如下: 

    (1)将第22位到第0位的二进制数写出来,在最左边补一位“1”,得到二十

四位有效数字。将小数点点在最左边那个“1”的右边。 

    (2)取出第29到第23位所表示的值n。当30位是“0”时将n各位求反。当30

位是“1”时将n增1。 

    (3)将小数点左移n位(当30位是“0”时)或右移n位(当30位是“1”时)

,得到一个二进制表示的实数。 

    (4)将这个二进制实数化为十进制,并根据第31位是“0”还是“1”加上正

号或负号即可。

特别地,实数0用C++的float格式表示是0000000000000000000000000000000

0。 





如果还不太明白,这里举几个例子。 

    一。将23.56化为C++的float格式。 

    (1)将23.56化为二进制后大约是“10111.1000111101011100001”。 

    (2)将小数点左移四位,得到“1.01111000111101011100001”。 

    (3)这已经有了二十四位有效数字,将最左边一位“1”去掉,得到“0111

1000111101011100001”。将它放入第22到第0位。 

    (4)因为23.56是正数,因此在第31位放入“0”。 

    (5)由于我们把小数点左移,因此在第30位放入“1”。 

    (6)因为我们是把小数点左移4位,因此将4减去1得3,化为二进制,并补足

七位得到0000011,放入第29到第23位。 

    完毕。 

    如果把最左边定为第31位,最右边定为第0位,那么在C++里,float格式的2

3.56是这样表示的:01000001101111000111101011100001。相应地-23.56就是这

样表示的:11000001101111000111101011100001。

二。将实数0.2356化为C++的float格式。 

    (1)将0.2356化为二进制后大约是0.00111100010100000100100000。 

    (2)将小数点右移三位得到1.11100010100000100100000。 

    (3)从小数点右边数出二十三位有效数字,即11100010100000100100000放

入第22到第0位。 

    (4)由于0.2356是正的,所以在第31位放入“0”。 

    (5)由于我们把小数点右移了,所以在第30位放入“0”。 

    (6)因为小数点被右移了3位,所以将3化为二进制,在左边补“0”补足七

位,得到0000011,各位取反,得到1111100,放入第29到第23位。 

    完毕。因此0.2356用C++的float格式表示是:00111110011100010100000100

100000。其中最左边一位是第31位,最右边一位是第0位。

三。将实数1.0化为C++的float格式。 

    (1)将1.0化为二进制后是1.00000000000000000000000。 

    (2)这时不用移动小数点了,这就是我们在转化方法里说的n=0的情况。 

    (3)将小数点右边的二十三位有效数字00000000000000000000000放入第22

到第0位。 

    (4)因为1.0是正的,所以在第31位里放入“0”。 

    (5)因为n=0,所以在第30位里放入“0”。 

    (6)因为n=0,所以将0补足七位得到0000000,各位求反得到1111111,放入

第29到第23位。 

    完毕。所以实数1.0用C++的float格式表示是:0011111110000000000000000

0000000。其中最左边一位是第31位,最右边一位是第0位。

(int)a、&a、(int)&a、(int&)a的区别,很偏僻的题的更多相关文章

  1. (转载)(int)a、&a、(int)&a、(int&)a的区别,很偏僻的题

    #include <iostream>#include <stdio.h>#include <string.h>#include <conio.h>us ...

  2. C#中(int)a和Convert.ToInt32(a)有什么区别

    首先,在 C# 中,int 其实就是 System.Int32,即都是32位的. 其次,(int) 和 Convert.ToInt32 是两个不同的概念,前者是类型转换,而后者则是内容转换,它们并不总 ...

  3. c语言检测文件是否存在int __cdecl access(const char *, int);

    最近写代码,遇到很多地方需要判断文件是否存在的.网上的方法也是千奇百怪,“百家争鸣”. fopen方式打开的比较多见,也有其他各种方式判断文件是否存在的,由于其他方法与本文无关,所以不打算提及. 笔者 ...

  4. (int),Int32.Parse() 和 Convert.toInt32() 的区别

    在 C# 中,(int),Int32.Parse() 和 Convert.toInt32() 三种方法有何区别? int 关键字表示一种整型,是32位的,它的 .NET Framework 类型为 S ...

  5. int main(int argc,char *argv[])与int main(int argc,char **argv)区别?

    int main(int argc,char *argv[])与int main(int argc,char **argv)区别? 这两种是一个等价的写法 而int main(int argc,cha ...

  6. Number (int float bool complex)--》int 整型、二进制整型、八进制整型、十六进制整型

    # ### Number (int float bool complex) # (1) int 整型 (正整数 0 负整数) intvar = 15 print(intvar) intvar = 0 ...

  7. int(a) 和 (int &) a 及 数据存储地址的探究

    做题做到一个很有意思的题 void main() { float a = 1; cout << boolalpha << ((int)a == (int &)a); f ...

  8. 字符串转换成整型,到底使用int.Parse,Convert.ToInt32还是int.TryParse?

    当我们想把一个字符串转换成整型int的时候,我们可能会想到如下三种方式:int.Parse,Convert.ToInt32和int.TryParse.到底使用哪种方式呢? 先来考虑string的可能性 ...

  9. ( ( (int(*)(uint, ushort, uint *, uint, int)) (*((uint *)(TCM_BASE + 0x8))) ) (a,b,c,d,e) )

    (  (  (int(*)(uint, ushort, uint *, uint, int))  (*((uint *)(TCM_BASE + 0x8)))  ) (a,b,c,d,e)  ) 首先红 ...

随机推荐

  1. Requests方法 -- 参数关联

    一.删除草稿箱1.参数这篇https://www.cnblogs.com/Teachertao/p/11144726.html 2.删除刚才保存的草稿 3.用 fiddler 抓包,抓到删除帖子的请求 ...

  2. XIN队算法

    XIN队算法 注:名称由莫队算法改编而来 从luogu搬过来了... \(newly\;upd:2021.7.8\) \(newly\;upd:2021.6.6\) OI至高算法,只要XIN队算法打满 ...

  3. ifix vba 读取计算机中的txt文件,截取字符串显示

    利用vba脚本,使用Scripting.FileSystemObject对象可以实现对文本文件的操作,下面以一个朋友的实际例子为例将截获的字符串进行页面显示. Private Sub CommandB ...

  4. 【Azure 应用服务】Azure Function HTTP 触发后, 230秒就超时。而其他方式触发的Function, 执行5分钟后也超时,如何调整超时时间?

    问题描述 Azure Function HTTP 触发后, 230秒就超时,而其他方式触发的Function, 执行5分钟后也超时,如何调整超时时间? 问题分析 查阅官方文档,对函数应用超时持续时间有 ...

  5. 小马哥的 Java 项目实战营学习笔记(1)

    小马哥的 Java 项目实战营 小马哥的 Java 项目实战营 第二节:数据存储之 JDBC JDBC 核心 API 数据源 接口 - javax.sql.DataSource获取方式 1.普通对象初 ...

  6. vue传值 ---- >> 子传父,$emit()

    划重点: $emit 绑定一个自定义事件event,当这个这个语句被执行到的时候,就会将参数arg传递给父组件,父组件通过@event监听并接收参数.   子组件:   1 <template& ...

  7. 『go成长之路』 defer 作用、典型用法以及多个defer调用顺序,附加defer避坑点,拿来吧你

    预习内容 defer 的作用有哪些? 多个 defer 的执行顺序是怎样的? defer,return,函数返回值 三者之间的执行顺序 defer的作用 go中的defer是延迟函数,一般是用于释放资 ...

  8. Redis实战-详细配置-优雅的使用Redis注解/RedisTemplate

    1. 简介 当我们对redis的基本知识有一定的了解后,我们再通过实战的角度学习一下在SpringBoot环境下,如何优雅的使用redis. 我们通过使用SpringBoot内置的Redis注解(文章 ...

  9. 01 CTF从0到。。。。

    无意间在前段时间接触到了CTF,感觉很有意思,就参加了个单位的短期培训,并且参加了比赛,也是无意混进了决赛.感觉自己不会的还很多!SO,开始写博客开始刷题,自己很菜,不会C,不会Python,不会汇编 ...

  10. 跟我一起写 Makefile(五)

    六.多目标 Makefile的规则中的目标可以不止一个,其支持多目标,有可能我们的多个目标同时依赖于一个文件,并且其生成的命令大体类似.于是我们就能把其合并起来.当然,多个目标的生成规则的执行命令是同 ...