C++输出为非科学计数法不同数据类型表示范围

news2024/11/24 6:52:22

目录

一、C++数据类型

1、基本的内置类型

2、修饰符

(1)signed 和 unsigned

(2)short 和 long

(3)区别总结

默认情况

二、类型转换

1、静态转换(Static Cast)

2、动态转换(Dynamic Cast)

3、常量转换(Const Cast)

4、重新解释转换(Reinterpret Cast)

(1)语法

三、输出为非科学计数法

1、修改为非科学计数法


一、C++数据类型

编程语言在进行编程时,需要用到各种变量来存储信息。变量保留的是它所存储的内存位置,即在创建一个变量的时候,就会在内存中保留一些空间。

1、基本的内置类型

类型关键字
布尔型bool
字符型char
整型int
浮点型float
双浮点型double
无类型void
宽字符型

wchar_t

2、修饰符

一些基本类型可以使用一个或者多个类型修饰符进行修饰:

  • signed
  • unsigned
  • short
  • long

这些修饰符可以影响变量能够表示的范围和所占用的内存空间。

(1)signed 和 unsigned

  • signed:表示带符号的类型。例如,int 默认是 signed int,即可以表示正数、负数和零。
  • unsigned:表示无符号的类型,只能表示非负数(包括零)。例如,unsigned int 只能表示非负整数。

(2)short 和 long

  • short:缩短整数的存储空间。例如,short int 或简写为 short,通常比普通的 int 类型使用更少的存储空间,但能表示的范围也相应较小。
  • long:增加整数的存储空间。例如,long int 或简写为 long,通常比普通的 int 类型使用更多的存储空间,能够表示更大范围的整数值。

(3)区别总结

  • signed 和 unsigned 的区别在于能够表示的数值范围:signed 可以表示正数、负数和零,而 unsigned 只能表示非负数。
  • short 和 long 的区别在于占用的存储空间和能够表示的数值范围:short 使用较少的存储空间但表示的范围较小,long 使用较多的存储空间但能表示更大的数值范围。

默认情况

① 不同系统会有所差异,一字节为 8 位。

② 默认情况下,int、short、long都是带符号的,即 signed。

③ long int 8 个字节,int 都是 4 个字节。

3、数据类型表示范围

类型范围
char1 个字节-128 到 127 或者 0 到 255
unsigned char1 个字节0 到 255
signed char1 个字节-128 到 127
int4 个字节-2147483648 到 2147483647
unsigned int4 个字节0 到 4294967295
signed int4 个字节-2147483648 到 2147483647
short int2 个字节-32768 到 32767
unsigned short int2 个字节0 到 65,535
signed short int2 个字节-32768 到 32767
long int8 个字节-9,223,372,036,854,775,808 到 9,223,372,036,854,775,807
signed long int8 个字节-9,223,372,036,854,775,808 到 9,223,372,036,854,775,807
unsigned long int8 个字节0 到 18,446,744,073,709,551,615
float4 个字节精度型占4个字节(32位)内存空间,+/- 3.4e +/- 38 (~7 个数字)
double8 个字节双精度型占8 个字节(64位)内存空间,+/- 1.7e +/- 308 (~15 个数字)
long long8 个字节双精度型占8 个字节(64位)内存空间,表示 -9,223,372,036,854,775,807 到 9,223,372,036,854,775,807 的范围
long double16 个字节长双精度型 16 个字节(128位)内存空间,可提供18-19位有效数字。
wchar_t2 或 4 个字节1 个宽字符

二、类型转换

类型转换是将一个数据类型的值转为另一种数据类型的值。

C++ 中有四种类型转换:静态转换、动态转换、常量转换和重新解释转换。

1、静态转换(Static Cast)

  • 静态转换是将一种数据类型的值强制转换为另一种数据类型的值。
  • 静态转换通常用于比较类型相似的对象之间的转换,例如将 int 类型转换为 float 类型。
  • 静态转换不进行任何运行时类型检查,因此可能会导致运行时错误。

举个例子:

#include <iostream>
#include <typeinfo>
using namespace std;
int main(){
    int a = 10;
    float b = static_cast<float>(a);

    cout << "type(a): " << typeid(a).name() << endl;
    cout << "type(b): " << typeid(b).name() << endl;
    return 0;
}

2、动态转换(Dynamic Cast)

动态转换通常用于将一个基类指针或引用转换为派生类指针或引用。

动态转换在运行时进行类型检查,如果不能进行转换则返回空指针或引发异常。

举个例子:

#include <iostream>

// 基类
class Base {
public:
    virtual ~Base() {} // 虚析构函数确保多态性
};

// 派生类
class Derived : public Base {  // 派生类
};

int main() {
    // 创建派生类对象的基类指针
    Base* ptr_base = new Derived();

    // 尝试将基类指针转换为派生类指针
    Derived* ptr_derived = dynamic_cast<Derived*>(ptr_base);

    // 检查转换是否成功
    if (ptr_derived != nullptr) {
        std::cout << "dynamic_cast success: " << static_cast<void*>(ptr_derived) << std::endl;
        // 安全地使用ptr_derived
    } else {
        std::cout << "dynamic_cast false." << std::endl;
    }

    // 释放内存
    delete ptr_base;

    return 0;
}

3、常量转换(Const Cast)

const属性:const关键字用于声明变量,表示该变量或对象在声明后不能被修改。如果有一个const对象或者指针,不能直接通过它来修改其值或者通过它调用非const成员函数。

所以常量转换的目的是为了去除对象或指针的const属性,使得可以修改原本被声明为const的对象或者调用非const成员函数。

常量转换用于将 const 类型的对象转换为非 const 类型的对象。

常量转换只能用于转换掉 const 属性,不能改变对象的类型。(例如,如果一个对象的类型是 const T,常量转换后得到的仍然是 T 类型,只是它现在不再是 const T,可以进行修改)

举个例子:

#include <iostream>

void modifyValue(int* ptr) {
    *ptr = 20; // 修改指针所指向的值
}

int main() {
    const int x = 10; // 声明一个 const int 类型的变量 x
    
    // 使用常量转换去除 const 属性
    int* ptr = const_cast<int*>(&x);
    
    // 现在可以通过 ptr 修改原本的 const 变量 x
    modifyValue(ptr);
    std::cout << "Modified value of x: " << x << std::endl; // 输出修改后的值
    return 0;
}

在这个示例中,通过使用 const_cast 去除了 xconst 属性,使得可以通过指针 ptr 修改 x 的值。

但需要注意的是,尽管这种操作是合法的,也应该谨慎使用,因为 const 的作用通常是为了确保代码的安全性和可维护性。

4、重新解释转换(Reinterpret Cast)

用于将一个数据类型的值重新解释为另一个数据类型的值,而不进行任何类型检查(如果进行错误的转换,可能会导致未定义的行为或者程序崩溃)。

这种转换通常用于需要在不同类型之间转换的情况,尤其是在低级别的系统编程或者处理特定硬件的时候可能会用到。

(1)语法

在 C++ 中,重新解释转换使用 reinterpret_cast 运算符来执行。其语法如下:

reinterpret_cast<new_type>(expression)
  • new_type 是要转换的目标类型。
  • expression 是要转换的表达式,可以是一个指针、引用、整数或者其他表达式。

举个例子:

#include <iostream>

int main() {
    int num = 10;
    float* float_ptr = reinterpret_cast<float*>(&num);
    
    // 输出重新解释后的浮点数值
    std::cout << "num value: " << num << std::endl;
    std::cout << "Reinterpreted float value: " << *float_ptr << std::endl;
    
    return 0;
}

使用了 reinterpret_cast 将一个 int 类型的变量 num 的地址转换为一个 float* 类型的指针 float_ptr,然后尝试输出这个指针所指向的浮点数值。

使用 reinterpret_cast<float*>(&num)int 类型的地址转换为 float* 类型的指针时,实际上是将 num 的二进制表示在浮点数格式下进行了解释。

  • 根据输出结果 "1.4013e-44",这意味着在系统或者编译器中,将 int 类型的变量 num 的地址解释为 float* 类型指针所得到的浮点数值非常接近于 1.4013 乘以 10 的负 44 次方。
  • 这个值非常接近于浮点数表示的最小正规范化值(normalized value),通常表示非常接近于 0 的数值。

三、输出为非科学计数法

在正常使用基本内嵌类型的时候,打印出来的数值就是科学计数法。

#include <iostream>

int main() {
    int num = 558558571;
    float num_float = num * 0.33;
    double num_double = num * 0.33;
    
    std::cout << "num value: " << num << std::endl;
    std::cout << "num_float value: " << num_float << std::endl;
    std::cout << "num_double value: " << num_double << std::endl;
    return 0;
}

1、修改为非科学计数法

#include <iostream>
#include <iomanip>

int main() {
    int num = 558558571;
    float num_float = static_cast<float>(num) * 0.33;
    double num_double = static_cast<double>(num) * 0.33;
    
    std::cout << "num value: " << num << std::endl;
    std::cout << std::fixed << std::setprecision(2);
    std::cout << "num_float value: " << num_float << std::endl;
    std::cout << "num_double value: " << num_double << std::endl;
    return 0;
}

其中

设置 std::cout 的输出格式,具体包含两个操作:

  1. std::fixed

    • std::fixediomanip 头文件中的一个标志,用于设置浮点数的输出格式为固定小数点表示法。这意味着浮点数将以小数点形式输出,而不是科学计数法。
    • 例如,一个浮点数 12.3456 在使用 std::fixed 后输出为 12.35,即小数点后保留固定位数的数字。
  2. std::setprecision(2)

    • std::setprecision(2)iomanip 头文件中的一个函数,用于设置浮点数输出的精度,即小数点后的位数。
    • 在这里,2 表示将浮点数的小数部分保留两位有效数字。例如,如果一个浮点数是 12.3456,设置精度为 2 后输出为 12.35

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1986583.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C语言——函数(1)

函数 定义&#xff1a; 函数就是用来完成一定功能的一段代码&#xff08;程序&#xff09;模块。 在设计较大的程序时&#xff0c;一般将其分为若干个程序模块&#xff0c;每个模块用来实现一定的功能。 函数优势&#xff1a; 我们可以通过函数提供功能给别人使用&#xff0c…

美国商超入驻Homedepot,传统家织厂家跨境赛道新选择?——WAYLI威利跨境助力商家

美国商超入驻Homedepot为传统家织厂家提供了新跨境选择。据《Interactive Home Shopping》一文&#xff0c;电子购物让消费者更易定位和比较产品。传统家织厂家可通过Homedepot等大型零售商&#xff0c;利用其平台优势&#xff0c;接触更广泛消费者。 根据《Homedepot之争——家…

【八股文】Redis

1.Redis有哪些数据类型 常用的数据类型&#xff0c;String&#xff0c;List&#xff0c;Set&#xff0c;Hash和ZSet&#xff08;有序&#xff09; String&#xff1a;Session&#xff0c;Token&#xff0c;序列化后的对象存储&#xff0c;BitMap也是用的String类型&#xff0c;…

案例:LVS+Keepalived集群

目录 Keepalived 原理 Keepalived案例 双机高可用热备案例 配置 修改配置文件 测试 严格模式测试 修改配置文件 测试 模拟故障测试 LVSKeepalived高可用 案例拓扑图 初步配置 关闭服务 主调度器配置 健康状态检查的方式 调整内核参数 从调度器配置 服务器池…

失业后才会明白,职场上有4个扎心的现象

最近一段时间&#xff0c;因为疫情的原因&#xff0c;很多企业都在经历着前所未有的困难&#xff0c;其中就包括华为这样的大型企业。 任正非在接受媒体采访的时候表示&#xff1a;“全球经济持续衰退&#xff0c;未来3到5年内都不可能转好……把寒气传递给每个人。 这句话一…

python中的魔术方法(特殊方法)

文章目录 1. 前言2. __init__方法3. __new__方法4. __call__方法5. __str__方法6. __repr__方法7. __getitem__方法8. __setitem__方法9. __delitem__方法10. __len__方法11. 富比较特殊方法12. __iter__方法和__next__方法13. __getattr__方法、__setattr__方法、__delattr__方…

深度学习DeepLearning Inference 学习笔记

神经网络预测 术语 隐藏层神经元多层感知器 神经网络概述 应当选择正确的隐藏层数和每层隐藏神经元的数量&#xff0c;以达到这一层的输出是下一层的输入&#xff0c;逐层变得清晰&#xff0c;最终输出数据的目的。 在人脸识别的应用中&#xff0c;我们将图片视作连续的像…

【Java 第九篇章】多线程实际工作中的头大的模块

多线程是一种编程概念&#xff0c;它允许多个执行路径&#xff08;线程&#xff09;在同一进程内并发运行。 一、多线程的概念和作用 1、概念 线程是程序执行的最小单元&#xff0c;一个进程可以包含多个线程。每个线程都有自己的程序计数器、栈和局部变量&#xff0c;但它们…

Motionface ai工具有哪些?

Motionface Android/PC 用一张静态含有人脸相片来生成一个能说会唱的虚拟主播。使用简单便捷&#xff0c;极致的流畅度体验超乎您的想象。 免费下载 Respeak PC电脑软件 任意视频一键生成虚拟主播&#xff0c;匹配音频嘴型同步&#xff0c;保留原视频人物神态和动作&#xff0c…

核显硬刚RTX 4070,AMD全新APU杀疯了

这年头&#xff0c;一台平民玩家低预算主流桌面电脑主机是什么配置&#xff1f; Intel i5 12400F CPU、B760 主板、NVIDIA RTX 4060 显卡、双 8G DDR4 内存、1T 固态硬盘的组合&#xff0c;想必相当具有代表性了吧&#xff01; 但仔细掰开后我们不难发现&#xff0c;这套不到…

生物信息学入门:Linux学习指南

还没有使用过生信云服务器&#xff1f;快来体验一下吧 20核心256G内存最低699元半年。 更多访问 https://ad.tebteb.cc 介绍 大家好&#xff01;作为一名生物信息学的新人&#xff0c;您可能对Linux感到陌生&#xff0c;但别担心&#xff0c;本教程将用简单明了的方式&#xff…

Cache结构

Cache cache的一般设计 超标量处理器每周期需要从Cache中同时读取多条指令&#xff0c;同时每周期也可能有多条load/store指令会访问Cache&#xff0c;因此需要多端口的Cache L1 Cache&#xff1a;最靠近处理器&#xff0c;是流水线的一部分&#xff0c;包含两个物理存在 指…

解决windows安装docker desktop打开报错问题

下载docker windows版本: https://desktop.docker.com/win/main/amd64/Docker%20Desktop%20Installer.exe?utm_sourcedocker&utm_mediumwebreferral&utm_campaigndd-smartbutton&utm_locationmodule 正常安装&#xff0c;然后运行&#xff0c;弹出这个报错: 试了…

力扣 两数之和

致每一个初学算法的你。 题目 时间复杂度&#xff1a;O(N^2)&#xff0c; 空间复杂度&#xff1a;O(1) 。 class Solution {public int[] twoSum(int[] nums, int target) {int n nums.length;for (int i 0; i < n; i) {for (int j i 1; j < n; j) {if (nums[i] …

RK3568平台开发系列讲解(文件系统篇)Linux内核中 文件的三个数据结构

在内核中,与文件描述符相关的三个主要数据结构分别是: 文件描述符表(进程级):这是每个进程所拥有的数据结构,用于维护进程中打开的所有文件描述符。每个 fd 在这个表中都有一个对应的条目,指向更底层的文件表示结构。 打开文件列表(系统级):这是一个全系统范围内的数…

DC-5靶场实战模拟

信息收集 端口和网段信息&#xff1a;使用nmap扫描 //扫描网段中存货的主机 nmap -sP 192.168.10.0/24 //进行对主机进行猜测-》发现接口&#xff1a;80存活 nmap -sV 192.168.10.245 目录信息 &#xff1a;使用dirbuster 指纹信息 找漏洞 发现web 中contact有提交界面进行…

[设备] 关于手机设备中几种传感器的研究

一、手机设备中三位坐标系概念 X轴的方向&#xff1a;沿着屏幕水平方向从左到右&#xff0c;如果手机如果不是是正方形的话&#xff0c;较短的边需要水平 放置&#xff0c;较长的边需要垂直放置。Y轴的方向&#xff1a;从屏幕的左下角开始沿着屏幕的的垂直方向指向屏幕的顶端Z轴…

linux操作——yum、systemctl、firewall、hostname、、、

一、什么是yum yum是一种在Linux操作系统中使用的软件包管理器。它可以用来从软件仓库中下载、安装、更新和删除软件包。yum可以自动解决软件包之间的依赖关系&#xff0c;并且可以方便地查找和安装各种软件。在大多数基于Red Hat的Linux发行版中&#xff0c;如CentOS和Fedora&…

牛客 JZ31.栈的压入,弹出序列 C++写法

牛客 JZ31.栈的压入&#xff0c;弹出序列 C写法 思路&#x1f914;&#xff1a; 创建一个栈&#xff0c;push压入序列&#xff0c;然后用栈顶跟弹出序列比&#xff0c;如果一样就出栈并且继续比较&#xff0c;不一样就再次push入栈&#xff0c;直到压入序列走完&#xff0c;如果…

部署伪分布式 Hadoop集群

部署伪分布式 Hadoop集群 一、JDK安装配置1.1 下载JDK1.2 上传解压1.3 java环境配置 二、伪分布式 Hadoop 安装配置2.1 Hadoop 下载2.2 上传解压2.3 Hadoop 文件目录介绍2.4 Hadoop 配置2.4.1 修改 core-site.xml 配置文件2.4.2 修改 hdfs-site.xml 配置文件2.4.3 修改 hadoop-…