24小时热门版块排行榜    

Znn3bq.jpeg
查看: 908  |  回复: 4

ddcy

捐助贵宾 (正式写手)

[求助] 一个C语言中的小问题 已有1人参与

我刚开始学语言。为什么C语言中实数要起个“浮点数”的名称?它在编程中有什么特殊的作用吗?
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Chris_D

银虫 (初入文坛)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
ddcy: 金币+8, ★★★很有帮助, good 2015-05-05 19:05:09
ddcy: 金币+8, ★★★很有帮助 2015-05-05 19:11:58
引用自 http://blog.163.com/wmk_2000_ren ... 461922010342395113/
什么是定点数、浮点数?
    首先我们要认清一个概念,定点数不一定是整数,浮点数不一定是小数。
    如其名,浮点数和定点数的区别就在于浮点和定点上,点就是指小数点。浮点数就是小数点是浮动的,定点数就是小数点是固定不动的。
   具体,什么是浮点数?
    浮点数是在计算机中用以近似表示任意某个实数。具体的说,这个实数由一个整数或定点数(即尾数)乘以某个基数(计算机中通常是2)的整数次幂得到,这种表示方法类似于基数为10的科学记数法。
   一个浮点数a由两个数m和e来表示:a = m × b^e。在任意一个这样的系统中,我们选择一个基数b(记数系统的基)和精度p(即使用多少位来存储)。m(即尾数)是形如±d.ddd...ddd的p 位数(每一位是一个介于0到b-1之间的整数,包括0和b-1)。如果m的第一位是非0整数,m称作规格化的。有一些描述使用一个单独的符号位(s 代表+或者-)来表示正负,这样m必须是正的。e是指数。
   对于一些外文资料中,指数即:exponent,尾数即:mantissa。
   在IEEE 754中,定义了两种浮点数,即我们熟悉的float和double型。对于float型的浮点数来说,最高一位是符号位,不用说了,1为负号,0为正。紧跟着指数位是8位,尾数是23位。由于尾数是规格化的,最高一位肯定非零,并且最高一位隐藏。所以对于尾数来说,实际上可以有 23+1=24位。
    比如说,如果mantissa为010,exponent为3,s为0,则尾数实际上是1.010,因此这个数是+1.010*2^3=1010b,即为十进制10.0。
    Double的位数说明类似于float。

什么是定点数?
    我们在上述的浮点数中可以看到,浮点的小数位是可变的(随exponent变化),因此浮点数可表达的小数范围非常广。但浮点数运算量非常大(从它的定义上就知道了)。并且在目前市场占有量最大的定点DSP并不支持浮点运算。
    因此,定点数应运而生。定点数就是指在一个数中,整数部分和小数部分位数固定。比如,我们定点数总共32位,其中小数占低13位:
typedef int fix_t;
#define FIX_FRACBITS 13

如何将一个int型的整数转化为定点数?
   Int类型转定点数最简单。上面的定义,小数位占低13位。

#define INTTOFIX(fix_t, fracbits, x)  fix_t((x) << (fracbits))

    即我们只需要将x左移就行了,当然要注意,如果x本身超过了整数部分的最大位数,则会产生溢出。
如何将一个double型小数转化为定点数?

    浮点数转为定点数与int型转为定点数类似,比如说1.1101,转为有13位小数的定点数就是1 1 1010 0000 0000,也就是1.1101*2^13。
    当然,在int型转定点时,我们使用了逻辑运算,而不是直接乘以2^13,是因为逻辑运算的速度一般比算术运算快几十倍。但是逻辑左移并不能运用于小数,double转定点时于是只能用算术乘法了。
    下面是double转定点:

#define DBLTOFIX(fix_t, fracbits, x) \

     fix_t(((x) * (double)((fix_t)(1) << (fracbits)))) )

   

定点数直接如何相加?

   很简单,如下。如下,下面的宏定义的定点数相加没有考虑到数据溢出的问题,如果当x和y同号并且两数足够大时,是会产生数据位溢出的。在具体编程实现时要特别注意。

#define FIX_ADD(fix_t, fracbits, x, y) ((x) + (y))

定点数如何相乘?

    乘法更容易产生数据位溢出的问题,因此,如果我们运算时就要特别小心。同样,也是没有考虑到数据溢出的问题。

Typedef _int64 fixbig_t;

#define FIX_MUL(fix_t, fracbits, bigfix_t, x, y) \

    Fix_t((bigfix_t(x) * bigfix_t(y)) >> (fracbits))

定点数如何实现除法?

   如下式所示,我们把移位放到被除数那里,是因为这样的处理基本上不会产生下溢出,提高了精度。

#define    JAS_FIX_DIV_FAST(fix_t, fracbits, bigfix_t, x, y) \

    JAS_CAST(fix_t, (JAS_CAST(bigfix_t, x) << (fracbits)) / (y))
2楼2015-05-05 09:19:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

jsnail

新虫 (初入文坛)

可以简单理解就是
顾名思义,“浮点数”就是指在计算机表示数据时,小数点的位置可以浮动(移动)的,是相对于定点数而言的
所以浮点数在表示一般都可以表示非常大的数据
浮点数在计算机里是以10的幂次来表示的,所以存在一定的精度问题
定点数则不会
3楼2015-05-05 16:27:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liaor1999

银虫 (小有名气)

引用回帖:
2楼: Originally posted by Chris_D at 2015-05-05 09:19:00
引用自 http://blog.163.com/wmk_2000_ren/blog/static/1388461922010342395113/
什么是定点数、浮点数?
    首先我们要认清一个概念,定点数不一定是整数,浮点数不一定是小数。
    如其名,浮点数和定点数的 ...

受教了!!
飞在风中的小雨
4楼2015-05-13 17:04:08
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liu2012huan

铜虫 (正式写手)

没意思,不需要了解,你就知道有这么回事就可以了
图像检索,图像处理,机器学习。
5楼2015-05-14 23:10:46
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 ddcy 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[基金申请] 面上本子正文33页,违规吗?会被低分嘛? +7 1234567wang 2026-05-17 9/450 2026-05-18 16:19 by 1234567wang
[基金申请] 今年审到国自然15份,谈谈感受 +16 国自然国社科中 2026-05-17 16/800 2026-05-18 14:58 by gy116024
[硕博家园] 考博自荐 +5 科研狗111 2026-05-13 6/300 2026-05-18 11:22 by 糊糊涂涂好
[基金申请] 重磅!青年科学基金项目(C类)资助增幅预计超过50% +7 水和泥不是水泥 2026-05-13 10/500 2026-05-18 07:50 by 水和泥不是水泥
[文学芳草园] 半夜喝咖啡 +3 myrtle 2026-05-15 5/250 2026-05-18 01:03 by 小沈2018
[找工作] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +4 ky2p12rrjj 2026-05-15 4/200 2026-05-17 19:47 by Equinoxhua
[硕博家园] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +6 l7k6xnh0yc 2026-05-14 7/350 2026-05-17 19:42 by Equinoxhua
[基金申请] 这年头没有找到涵评专家,还有中面上的可能吗 +13 dd921ww 2026-05-12 16/800 2026-05-17 12:38 by 于轩
[硕博家园] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +4 v9tggjlwd0 2026-05-15 4/200 2026-05-17 08:06 by 11n4dfd8yn
[找工作] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +3 l7k6xnh0yc 2026-05-14 6/300 2026-05-17 07:31 by 11n4dfd8yn
[考研] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +4 l7k6xnh0yc 2026-05-14 8/400 2026-05-17 07:26 by 11n4dfd8yn
[考博] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +6 l7k6xnh0yc 2026-05-14 6/300 2026-05-17 07:11 by 11n4dfd8yn
[考研] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +3 k37jurhrau 2026-05-16 3/150 2026-05-17 01:25 by ue3ir18jc3
[考研] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +3 ky2p12rrjj 2026-05-15 4/200 2026-05-17 00:50 by ue3ir18jc3
[考研] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +4 x0mp7owy2b 2026-05-15 4/200 2026-05-17 00:25 by ue3ir18jc3
[基金申请] 请问大佬b0816评完了吗 +4 市民华南虎 2026-05-12 8/400 2026-05-16 19:54 by Equinoxhua
[有机交流] 求助2,4-二氯-5-嘧啶甲醛的合成方法 20+3 光吃不拉 2026-05-14 6/300 2026-05-16 19:46 by Equinoxhua
[有机交流] 如何实现卤原子转化 +3 BT20230424 2026-05-15 5/250 2026-05-16 16:20 by czyzsu
[硕博家园] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +3 k37jurhrau 2026-05-16 3/150 2026-05-16 13:57 by vcdazktkjx
[考博] 26应届毕业生考博求助 +3 wo一定上岸 2026-05-13 3/150 2026-05-14 21:47 by 明海天涯
信息提示
请填处理意见