加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

隐式铸造一个浮动常数

发布时间:2020-12-16 07:53:06 所属栏目:百科 来源:网络整理
导读:请看这个代码: #include stdio.hint main(void){ short s; int i = 65696; float f = 65696.0F; printf("sizeof(short) = %lun",sizeof(short)); s = i; printf("s = %hdn",s); s = f; printf("s = %hdn",s); s = 65696; printf("s = %hdn",s); s = 656
请看这个代码:
#include <stdio.h>

int main(void)
{
    short s;
    int i = 65696;
    float f = 65696.0F;

    printf("sizeof(short) = %lun",sizeof(short));

    s = i;
    printf("s = %hdn",s);
    s = f;
    printf("s = %hdn",s);

    s = 65696;
    printf("s = %hdn",s);
    s = 65696.0F;
    printf("s = %hdn",s);

    return 0;
}

它输出为:

sizeof(short) = 2
s = 160
s = 160
s = 160
s = 32767

最后一行为什么是32767而不是160?说f = 65696.0F有什么区别? s = f; s = 65696.0F; ?

解决方法

因为如果浮点值的积分部分不能在新类型中表示,则转换是未定义的行为.

在你的情况下,SHRT_MAX大概是32767,因此65696.0F的组成部分然后不能在一个短对象中表示.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读