如何在 C++ 中把浮点数转换为整数

Jinku Hu 2023年10月12日
  1. 使用直接赋值将浮点数转换为整数
  2. 使用 C-style Cast 将浮点数转换为整数
  3. 使用 static_cast 将浮点数转换为整数
如何在 C++ 中把浮点数转换为整数

本文将演示如何在 C++ 中把浮点型转换为整型的多种方法。

使用直接赋值将浮点数转换为整数

浮点数和整数值之间的转换可以使用赋值运算符来完成。在这种情况下,浮点型变量将被隐式转换为整型类型,值将被缩小到第二种类型,失去小数点后的所有数字。注意,我们使用 int 的向量来存储 float,然后将每个整数输出到控制台,以便更好的演示。

#include <iostream>
#include <string>
#include <vector>

using std::cout;
using std::endl;
using std::vector;

int main() {
  vector<float> f_vec{12.123, 32.23, 534.333333339};
  vector<int> i_vec;

  i_vec.reserve(f_vec.size());
  for (const auto &f : f_vec) {
    i_vec.push_back(f);
  }

  for (const auto &i : i_vec) {
    cout << i << "; ";
  }
  cout << endl;

  return EXIT_SUCCESS;
}

输出:

12; 32; 534;

使用 C-style Cast 将浮点数转换为整数

另一种解决方案是用 (typename) 符号进行 C 风格的转码。这种方法在现代 C++ 中通常被认为是不安全的,但如果程序员正确使用它,代码就会按预期运行。注意千万不要将指针投向不完整的类,因为它可能导致未定义的行为。

#include <iostream>
#include <string>
#include <vector>

using std::cout;
using std::endl;
using std::vector;

int main() {
  vector<float> f_vec{12.123, 32.23, 534.333333339};
  vector<int> i_vec;

  i_vec.reserve(f_vec.size());
  for (const auto &f : f_vec) {
    i_vec.push_back(int(f));
  }

  for (const auto &i : i_vec) {
    cout << i << "; ";
  }
  cout << endl;

  return EXIT_SUCCESS;
}

输出:

12; 32; 534;

使用 static_cast 将浮点数转换为整数

根据现代 C++ 的建议,应该利用命名转换法将浮点数值转换为整数。static_cast 转换类型而不检查值;因此程序员有责任确保正确性。需要注意的是,命名转换和它们的行为相当复杂,需要通过一个概述来掌握,所以这里是 static_cast完整手册,列出了所有的边缘情况和特性。

#include <iostream>
#include <string>
#include <vector>

using std::cout;
using std::endl;
using std::vector;

int main() {
  vector<float> f_vec{12.123, 32.23, 534.333333339};
  vector<int> i_vec;

  i_vec.reserve(f_vec.size());
  for (const auto &f : f_vec) {
    i_vec.push_back(static_cast<int>(f));
  }

  for (const auto &i : i_vec) {
    cout << i << "; ";
  }
  cout << endl;

  return EXIT_SUCCESS;
}

输出:

12; 32; 534;
作者: Jinku Hu
Jinku Hu avatar Jinku Hu avatar

DelftStack.com 创始人。Jinku 在机器人和汽车行业工作了8多年。他在自动测试、远程测试及从耐久性测试中创建报告时磨练了自己的编程技能。他拥有电气/电子工程背景,但他也扩展了自己的兴趣到嵌入式电子、嵌入式编程以及前端和后端编程。

LinkedIn Facebook

相关文章 - C++ Float