草庐IT

return-code

全部标签

c++ - 为什么要在这个 return 语句中使用这个逗号?

这个问题在这里已经有了答案:Whatdoesthecommaoperator,do?(8个答案)C++--returnx,y;Whatisthepoint?(18个答案)关闭6年前。我明白这个C++函数是做什么的,但是我不明白为什么return语句是这样写的:intintDivide(intnum,intdenom){returnassert(denom!=0),num/denom;}这里只有一个语句,因为只有一个;但逗号让我很困惑。为什么不写:intintDivide(intnum,intdenom){assert(denom!=0);returnnum/denom;}除了“优雅”之

c++ - 视觉 C++ 错误 : function must return a value

我正在做一个多平台项目,有些平台禁用了功能,在这些功能的界面中,我经常做的事情是这样的:boolFoo::bar()const{//disabledabort();}GCC/LLVM不要求非void函数返回值(它们只是给出警告),在这种情况下,我调用abort()时,它们足够聪明,甚至不会发出警告(因为该函数永远不会返回)。有没有办法(编译标志?)让VisualC++2010以相同的方式运行,这样我就不会继续破坏Windows构建?我知道我总是可以在中止后返回值,但在其他平台上工作时我通常会忘记这一点,不给出错误的行为似乎更合适。 最佳答案

c++ - 如果函数调用是 return 语句,编译器能否自动 move 函数参数?

在以下情况下,编译器可以自动move函数参数v还是必须手动声明?std::vectorFilter(std::vectorv);voidDoSomeStuffAndCallFilter(std::vectorv){//dosomestufftov//canthecompilerautomaticallystd::movevinthiscall?//ie.returnFilter(std::move(v));//returnFilter(v);} 最佳答案 在您的情况下,编译器可以在as-if规则下作为允许的优化来执行此操作,因为它非

c++ - Visual Studio Code : C++ include path

我目前正在使用https://marketplace.visualstudio.com/items?itemName=mitaki28.vscode-clang这是一个很棒的访问成员函数的小工具。但是,我在导入的项目中遇到了一个问题。虽然上面的clang功能有效,但我在使用包含目录时遇到了特殊问题。我的项目结构如下:|-src/|-main.cpp|-include/|-MyHelper.h|-CMakeLists.txt有没有办法在VisualStudioCode中配置我的包含目录,以便在main.cpp中我可以这样做:#include"MyHelper.h"而不是#include"

c++ - 如何测试 std::error_code 不是错误?

我有一个返回std::error_code的方法。我对错误消息不是特别感兴趣,只对方法是否成功感兴趣。测试std::error_code是否代表成功操作的最佳方法是什么? 最佳答案 我在使用ASIO库时遇到过类似的情况。作为什么oneoftheirblogposts建议,std::error_code应按如下方式进行测试:std::error_codeec;//...if(!ec){//Success.}else{//Failure.}深入挖掘后,我发现了this(最近)C++标准Google组中的讨论证实了上述说法,但也提出了关于

c++ - Visual Studio Code 智能感知模式

c_cpp_properties.json标签“intelliSenseMode”的有效值是多少?它默认为clang-x64,但我正在使用g++进行编译,所以我可以在那里使用其他值吗?我找不到任何关于它的文档。 最佳答案 因为ArtemyVysotsky没有将他的答案作为答案发布:文档指出"msvc-x64"和"clang-x64"是唯一可能的值。 关于c++-VisualStudioCode智能感知模式,我们在StackOverflow上找到一个类似的问题:

c++ - 是否允许在 requires 表达式中为 return-type-requirement 指定类型?

看看这个简单的概念示例:templaterequiresrequires(Tt){{t+t}->bool;}voidfn(){}intmain(){fn();}这里,我使用bool作为return-type-requirement的type-constraint。当前稿says:type-constraint:nested-name-specifieroptconcept-namenested-name-specifieroptconcept-name所以type-constraint必须是一个concept-name。bool(或任何类型)是否允许作为概念名称?如果是,那是什么意思,

c++ - 首选哪个,return const double& OR return double

给定以下场景,以下哪一项是首选。m_state是一个成员评价者,而不是局部变量。classC{private:doublem_state;public:doublestate()const{returnm_state;}//returnsdoubledouble&state(){returnm_state;}}===========================================classC{private:doublem_state;public:constdouble&state()const{returnm_state;}//returnsconstdouble&

C++11 原子 : why does this code work?

让我们采用这个结构:structentry{atomicvalid;atomic_flagwriting;charpayload[128];}两个线程A和B以这种方式同时访问这个结构(让e成为entry的一个实例):if(e.valid){//dosomethingwithe.payload...}else{while(e.writing.test_and_set(std::memory_order_acquire));if(!e.valid){//writee.payloadonebyteatatime//(thepayloadwrittenbyAmaybedifferentfrom

c++ - 嵌套类中的 "Invalid covariant return type"错误,其方法返回基于模板的对象

下面的C++代码在编译时给我这些错误:covariant.cpp:32:22:error:invalidcovariantreturntypefor‘virtualQC::test()’covariant.cpp:22:22:error:overriding‘virtualQB::test()’我不想更改行virtualQtest(){}至virtualQtest(){}尽管它消除了编译错误。有没有其他方法可以解决这个问题?templateclassQ{public:Q(){}virtual~Q(){}};classA{public:A(){}virtual~A(){}};classB