文档章节

GCC中printf四舍五入的原则

莫忆往西
 莫忆往西
发布于 2016/08/13 00:08
字数 269
阅读 32
收藏 0

###GCC中printf四舍五入的原则

  • VC++ is using Round half away from zero

  • GCC is using Round half to even which is also known as banker's rounding.

  • Nearest integer function In computer science, the nearest integer function of real number x denoted variously by Round(x), is a function which returns the nearest integer to x. To avoid ambiguity when operating on half-integers, a rounding rule must be chosen. On most computer implementations, the selected rule is to round half-integers to the nearest even integer—for example,

Test Program on gcc version 5.4.0 20160609 (Ubuntu 5.4.0-6ubuntu1~16.04.2)

#include <iostream>
#include <vector>
#include <stdio.h>
#include <algorithm>

using namespace std;

void printVector(float& elem)
{
    printf("value %f is change to %0.1f \n", elem, elem);
}

void testRoundRules()
{
    cout << "using gcc" << endl;

    float fValues[] = { 3.05f, 3.15f, 3.151f, 3.155f, 3.25f, 3.251f, 3.255f, -0.45f, -0.15f};
    // 使用vector的构造函数,将数组第一个元素开始到结束的内容拷贝到vector中
    vector<float> vDatas(fValues, fValues+sizeof(fValues)/sizeof(fValues[0]));
    
    for_each(vDatas.begin(), vDatas.end(), printVector);
}

output:

using gcc
value 3.050000 is change to 3.0
value 3.150000 is change to 3.2
value 3.151000 is change to 3.2
value 3.155000 is change to 3.2
value 3.250000 is change to 3.2
value 3.251000 is change to 3.3
value 3.255000 is change to 3.3
value -0.450000 is change to -0.4
value -0.150000 is change to -0.2
Note that 3.251 is rounding to 3.3 not 3.2, because 3.3 is nearer to 3.251.

© 著作权归作者所有

共有 人打赏支持
莫忆往西
粉丝 2
博文 14
码字总数 17277
作品 0
西安
java保留小数点后四舍五入的问题

在Java中使用一些方法进行四舍五入会出现和预期不同的结果,这是因为这些方法使用的原则实际为:四舍六入五考虑,五后非零就进一,五后皆零看奇偶,五前为偶应舍去,五前为奇要进一。 1.四舍...

塞上名猪
2017/10/11
0
0
在gcc中使用intel风格的内联汇编

很简单,内联汇编使用asm(“.intel_syntax noprefix/n”)声明一下,以后的内联汇编就可以用intel风格了,构建可执行文件时给gcc加上-masm=intel参数。 先写一个小程序测试一下: [cpp] view...

simpower
06/21
0
0
gcc的printf() 优化?

这两天在用 gcc 编译一个自定义的 printf() 的函数时,里面特意没有包含库文件。开始时 printf 工作的还不错,什么格式化字符串都能正确地输出。但是当 printf() 里面只有一个%c的格式符时,...

Fuz
2012/06/12
946
1
Linux编译工具:gcc入门

1. 什么是gcc gcc的全称是GNU Compiler Collection,它是一个能够编译多种语言的编译器。最开始gcc是作为C语言的编译器(GNU C Compiler),现在除了c语言,还支持C++、java、Pascal等语言。...

zjy900507
05/09
0
0
awk之printf详解

printf()函数是格式化输出函数, 一般用于向标准输出设备按规定格式输出信息。在编写程序时经常会用到此函数。printf()函数的调用格式为: printf("", ); 其中格式化字符串包括两部分内容: 一部...

如风达
2016/09/01
8
0

没有更多内容

加载失败,请刷新页面

加载更多

React 服务器渲染原理解析与实践

网盘下载地址 React 服务器渲染原理解析与实践 本套课程,讲解了React中SSR技术的整个搭建思路及流程,完整的从原理上讲清楚了SSR的概念,重点在于讲解编写SSR框架遇到的各种知识点,以及细节...

qq__2304636824
11分钟前
0
0
Jenkins使用

clean install -Dmaven.test.skip=true

1713716445
20分钟前
0
0
多线程

1. 多线程概念。并发和并行的概念。 多线程指的是一段时间内cpu同时执行多个线程。一个程序至少运行>=1个进程,进程就是运行中的程序,而一个进程至少运行>=1个线程,线程是操作系统能调度的...

鱼想吃肉
今天
0
0
HBase 表修复在线方式和离线方式

一、在线修复 1.1 使用检查命令 $ ./bin/hbase hbck 该命令可完整修复 HBase 元数据信息;存在有错误信息会进行输出; 也可以通过如下命令查看详细信息: $ ./bin/hbase hbck -details 1.2 ...

Ryan-瑞恩
今天
3
0
redis 系列二 -- 常用命令

1.基础命令 info ping quit save dbsize select flushdb flushall 2.键命令 2.1 set 直接赋值 set a a 2.2 get 取值 get a 2.3 exists 是否存在 exists a 2.4 expire 设置剩余时间 秒 expire......

imbiao
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部