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

c – 为什么编译器允许缩小转换

发布时间:2020-12-16 03:20:04 所属栏目:百科 来源:网络整理
导读:任何人都可以向我解释一下,如果初始化器可能导致信息丢失,为什么编译器允许初始化内置类型的变量? 例如,第5版的C Primer说,编译器将不会让我们列出内置类型的初始化变量. 但是我的编译器gcc v 4.7.1在以下代码中成功初始化了变量a: long double ld = 3.141
任何人都可以向我解释一下,如果初始化器可能导致信息丢失,为什么编译器允许初始化内置类型的变量?

例如,第5版的C Primer说,编译器将不会让我们列出内置类型的初始化变量.

但是我的编译器gcc v 4.7.1在以下代码中成功初始化了变量a:

long double ld = 3.1415926536; 
int a{ld};

只有警告:缩小’ld’从’long double’到’int’的转换{} [-Wararrowing].

解决方法

初始化列表的一个功能是不允许缩小转换.但语言定义不区分警告和错误;当代码格式错误时,它需要“诊断”,它被定义为来自一组实现定义的消息的任何消息.警告满足此要求.这是非标准扩展的机制:发出警告后,编译器可以自由地做任何想做的事情,包括根据特定于实现的规则编译.

(编辑:李大同)

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

    推荐文章
      热点阅读