• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

c语言获取符号位整数和浮点

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

1. 为什么你应该得到的签位


非常多的时间,我们需要推断的数目值正和负,做了相应的逻辑处理。完成这一要求条件推断语句可以很好。

有时会出现以下情况,

if (x > 0) {
    x = x - 1;
} else {
    x = 1 - x;
}

if (x < 0) {
   x = -x;
}

正负仅仅是数值的符号位变化。或是计算结果的符号位变化。可是我们须要用一个推断,首先条件推断会影响效率,其次格式不够简洁美观。所以,有时候希望能不用条件推断也解决这个问题。而数值的符号位已经被存储在了数值的最高位,能够利用这点来避免条件推断。



2.  怎样得到符号位


可能有非常多种方法。可是通过移位来获得符号位是最直接想到的。

移位有左移右移, 右移由于有符号位的问题。所以。有2个情况,有符号右移和无符号右移。

有符号右移空位补符号位,无符号右移空位补0。当把有符号数,符号位移动到右边第一位的时候。结果-1就是负数。0就是正数。

当把无符号数,符号位移动到右边第一位时候。结果1是负数。0正数。



3. 一种实现方法


由于浮点数无法移位,所以要么强转成整数处理,要么就要拆成数组处理。这里我们使用当做数组处理。

首先,我们把数值不管什么类型当做char[]数组来处理,

(signed char*) &x

这样数值就被切割都多个char类型的空间中,符号位就存储在最高位的char空间中。

((signed char*) &x)[sizeof(x) - 1]

我们假定小端存储模式,那么符号位就在char数组的最后一个空间。我们拿到了有符号位的char数据而且当做有符号数来处理。

((signed char*) &x)[sizeof(x) - 1] >> 7


右移7位表示把符号移动到右边第一位,那么,正数就是0,负数就是-1

最后,完整的宏定义

/**
 * Get x sign bit only for little-endian
 * if x >= 0 then  1
 * if x <  0 then -1
 */
#define MathUtils_SignBit(x) \
	(((signed char*) &x)[sizeof(x) - 1] >> 7 | 1)

结果与1或。是把[0, -1]映射到[1, -1], 这样我们就能够把最開始的样例写成这样:

x   = (x - 1) * MathUtils_SignBit(x)

x *= MathUtils_SignBit(x)

版权声明:本文博客原创文章。博客,未经同意,不得转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
C#保存Base64格式图片发布时间:2022-07-14
下一篇:
OpenJudge2680化验诊断C++发布时间:2022-07-14
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap