MSVC 的 C4138 警告 ( "'*/' found outside of comment" ) 是否应该被禁用?
Should MSVC's C4138 warning ("'*/' found outside of comment") be disabled?
使用MSVC2017
编译以下代码时void Foo::bar(A */*a*/)
我得到了此警告:
foo.cpp:38: warning: C4138: '*/' found outside of comment
我可以通过在星号之后添加一个空间来解决此问题:
void Foo::bar(A * /*a*/)
但是,我必须在很多地方进行此操作,如果我不选出参数,则由于额外的空间而不会遵循我使用的编码样式。
由于我对GCC或Clang没有相同的警告,我想知道这是否是可以安全禁用的MSVC特定怪癖。
是的,这是一个不必要的警告;您提出的代码没有错。实际上,在函数定义中评论变量名称可以很有用,例如,当您想在函数参数列表中抑制"未使用的变量"警告时。
-
关闭警告,并依靠编译器在您的代码中确实存在不匹配的评论块发出诊断。
-
向编译器供应商提交错误报告。
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 检查输入是否不是整数或数字
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 此代码是否违反一个定义规则
- 是否需要删除包含对象的"pair"?
- 是否可以从int转换为enum类类型
- 无论条件是否为true,if总是在c++中执行
- 如何找到大小'x'数组是否完全填充,在C++?
- 检查值是否在集合p1和p2中,但不在p3中
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 检查 std::shared_ptr<> 的当前底层类型是否为 T
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- GL_SHADERSTORAGE_BUFFER位置是否与其他着色器位置冲突
- 子目录是否继承属性,例如add_definitions,include_directories和父Cmakelist.t
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- C/C++预处理器是否可以检测一些编译器选项
- MSVC 的 C4138 警告 ( "'*/' found outside of comment" ) 是否应该被禁用?