C++不使用任何 include文件得到+inf,-inf和nan

2024-06-15 20:58
文章标签 c++ 使用 include nan inf 得到

本文主要是介绍C++不使用任何 include文件得到+inf,-inf和nan,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景:

最近在看网易的公开课《斯坦福大学公开课:编程范式》,才知道大学的时候错过了一个多么好玩的课程。不过重点不在这里,而是终于能理解了之前一直没什么心情看的一些东西。代码部分用了《编程范式》提到的一些操作指针的技巧,当然单纯实现标题的要求完全可以不这样做。

相关知识:

现在所有的计算机都支持一个被称为IEEE浮点标准。

IEEE浮点数表示法:

        IEEE浮点标准用的形式来表示一个数。分为以下3个部分:

l  符号:s决定这个数是负数还是正数。

l  尾数:M是一个二进制小数。

l  阶码:E的作用是对浮点加权,可能是负数。

在单精度浮点格式(C 语言中的float)中,s、exp 和 frac 字段分别为s=1 位、阶码字段k = 8 位和尾数n = 23 位,得到一个 32 位的表示。

在双精度浮点格式(C 语言中的 double)中,s、exp 和 frac 字段分别为 1 位、k = 11 位和n = 52 位,得到一个 64 位的表示。

更多的东西请参考《深入理解计算机系统(原书第2版)》

代码:

#include <iostream>
#define ECHO(str) std::cout << str << std::endl
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
//将char类型 指定l位填1 
char pow(int l){
char g;
g = 1;
for(int i=2;i<=l;i++){
g*=2;
}
return g;
}
//将char类型 从指定i位到j位填1(包含两端) 
char full(int i,int j){
char ret;
ret = 0;
for(int index=i;index<=j;index++){
ret += pow(index);
}
return ret;
}
int main(int argc, char** argv) {
char h[4]={0};


//展示单精度和字符型的长度 : 4 1 4
ECHO(sizeof(float) << " " << sizeof(char) << " " << sizeof(int));

//得到正无穷大:  0111 1111 1000 0000 0000 0000 0000 0000
h[3] = full(1,7);
h[2] = pow(8);
ECHO(*(float *)h);

//得到负无穷大: 1111 1111 1000 0000 0000 0000 0000 0000
h[3] = full(1,8);
h[2] = pow(8);
ECHO(*(float *)h);

//得到nan:  1111 1111 1000 0000 0000 0000 0000 0001
h[3] = full(1,8);
h[2] = pow(8);
h[0] = pow(1);
ECHO(*(float *)h);

return 1;
}

结果:

4 1 4
inf
-inf
nan


--------------------------------
Process exited with return value 1
Press any key to continue . . .


这篇关于C++不使用任何 include文件得到+inf,-inf和nan的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1064562

相关文章

Python FastAPI入门安装使用

《PythonFastAPI入门安装使用》FastAPI是一个现代、快速的PythonWeb框架,用于构建API,它基于Python3.6+的类型提示特性,使得代码更加简洁且易于绶护,这篇文章主要介... 目录第一节:FastAPI入门一、FastAPI框架介绍什么是ASGI服务(WSGI)二、FastAP

Spring-AOP-ProceedingJoinPoint的使用详解

《Spring-AOP-ProceedingJoinPoint的使用详解》:本文主要介绍Spring-AOP-ProceedingJoinPoint的使用方式,具有很好的参考价值,希望对大家有所帮... 目录ProceedingJoinPoijsnt简介获取环绕通知方法的相关信息1.proceed()2.g

Maven pom.xml文件中build,plugin标签的使用小结

《Mavenpom.xml文件中build,plugin标签的使用小结》本文主要介绍了Mavenpom.xml文件中build,plugin标签的使用小结,文中通过示例代码介绍的非常详细,对大家的学... 目录<build> 标签Plugins插件<build> 标签<build> 标签是 pom.XML

JAVA虚拟机中 -D, -X, -XX ,-server参数使用

《JAVA虚拟机中-D,-X,-XX,-server参数使用》本文主要介绍了JAVA虚拟机中-D,-X,-XX,-server参数使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录一、-D参数二、-X参数三、-XX参数总结:在Java开发过程中,对Java虚拟机(JVM)的启动参数进

Java中使用注解校验手机号格式的详细指南

《Java中使用注解校验手机号格式的详细指南》在现代的Web应用开发中,数据校验是一个非常重要的环节,本文将详细介绍如何在Java中使用注解对手机号格式进行校验,感兴趣的小伙伴可以了解下... 目录1. 引言2. 数据校验的重要性3. Java中的数据校验框架4. 使用注解校验手机号格式4.1 @NotBl

Python使用DeepSeek进行联网搜索功能详解

《Python使用DeepSeek进行联网搜索功能详解》Python作为一种非常流行的编程语言,结合DeepSeek这一高性能的深度学习工具包,可以方便地处理各种深度学习任务,本文将介绍一下如何使用P... 目录一、环境准备与依赖安装二、DeepSeek简介三、联网搜索与数据集准备四、实践示例:图像分类1.

Linux系统之authconfig命令的使用解读

《Linux系统之authconfig命令的使用解读》authconfig是一个用于配置Linux系统身份验证和账户管理设置的命令行工具,主要用于RedHat系列的Linux发行版,它提供了一系列选项... 目录linux authconfig命令的使用基本语法常用选项示例总结Linux authconfi

Windows server服务器使用blat命令行发送邮件

《Windowsserver服务器使用blat命令行发送邮件》在linux平台的命令行下可以使用mail命令来发送邮件,windows平台没有内置的命令,但可以使用开源的blat,其官方主页为ht... 目录下载blatBAT命令行示例备注总结在linux平台的命令行下可以使用mail命令来发送邮件,Win

Tomcat的下载安装与使用教程

《Tomcat的下载安装与使用教程》本文介绍了Tomcat的下载、安装和使用方法,包括在本机和云服务器上部署Tomcat的过程,以及解决启动失败问题的方法... 目录Tomcat的下载安装与使用Tomcat的下载与安装Tomcat在本机运行使用Tomcat在php云服务器上的使用总结Tomcat的下载安装与

Python使用PIL库将PNG图片转换为ICO图标的示例代码

《Python使用PIL库将PNG图片转换为ICO图标的示例代码》在软件开发和网站设计中,ICO图标是一种常用的图像格式,特别适用于应用程序图标、网页收藏夹图标等场景,本文将介绍如何使用Python的... 目录引言准备工作代码解析实践操作结果展示结语引言在软件开发和网站设计中,ICO图标是一种常用的图像