C中的括号是否会导致隐式演员?

背景

我最后一次询问括号是否导致隐式转换(here)时,@ pmg足以指出“C中的任何内容都不在int下面”但是,那里的讨论是关于按位运算符,括号结果是只是分心.

介绍

下面,括号是主要的吸引力.或者,为了更无聊但更精确,我看到的唯一运算符是括号和赋值运算符.

At this reference about the C parentheses operator,我没有看到有关括号更改类型的任何内容(在类型转换语法之外,这不是这种情况).

同时,here’s a reference that reminds that there is automatic type conversion on assignment,但我认为这不会解释我将在这里描述的静态分析工具行为.

与前一个问题一样,“OK”表示静态分析工具没有警告隐式类型转换,“NOT OK”表示它确实存在.

int main(void)
{
    unsigned int  ui;
    int i;

    ui = (256U); // NOT OK (*) (1)
    i = (256U); // NOT OK (*)  (2)

    i = 256; // OK
    i = 256U; // NOT OK
    ui = 256U; // OK   (3)
    ui = 256; // NOT OK

 return(0);
}

除了前两个,我能理解它们 – 括号的作用是什么?如果他们没有采取隐式类型转换的方式,那么我希望(1)没问题,(2)不行.如果他们对int小于int的类型进行自动类型提升,那么我希望(1)不正常,(2)没问题.但是这个工具说两者都不行.

这是一个静态分析工具错误,还是工具正确,我还需要了解C中隐式类型转换的其他内容

(顺便说一句,我希望值256足够小,不会导致我的机器溢出……)

解决方法

首先,让我们澄清一些术语.没有什么可以导致“隐性演员”,因为没有这样的事情.强制转换是一个显式运算符,由表达式前面括号中的类型名称组成,例如(double)42;它指定转换.转换可以是显式的(由强制转换运算符指定)也可以是隐式的,如double x = 42;.所以你真正要问的是括号是否会导致隐式转换.

至少在你向我们展示的代码中,答案是否定的.

引用C99 standard(3.7 MB PDF),第6.5.1p5节:

A parenthesized expression is a primary expression. Its type and value
are identical to those of the unparenthesized expression. It is an
lvalue,a function designator,or a void expression if the
unparenthesized expression is,respectively,an lvalue,a function
designator,or a void expression.

因为256U已经是主要表达式,所以括号根本没有区别;括号通常表示优先级,但在这种情况下,没有预先指示.

你使用什么静态分析工具?您应该提交错误报告.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...