草庐IT

static_switch

全部标签

c++ - 使用 switch 的自动函数返回值

我正在尝试创建一个返回类型应取决于switch语句的函数,例如:autofunction_name(intvalue){switch(value){case1:{return2.3;}case2:{return1;}case3:{return"string";}}}但是我不能因为一个错误:error:inconsistentdeductionforautoreturntype:'double'andthen'int'我可以做些什么来创建功能与上述示例类似的东西? 最佳答案 C++中的函数只能返回一个类型。如果您使用auto作为返回类

c++ - 如何消除在 switch case 中使用 goto

基本上我想接受来自用户的特定字符,然后使用switchcase将与该字符大小写相关的字符串传递给另一个函数。例如。casei:strcpy(str,"ice-cream");other_function(str);break;如果用户打印了任何默认字符,那么它应该打印默认语句并再次从用户那里获取字符并检查其大小写。我使用goto完成了此操作,但是是否有任何其他选项可用于避免或替换此代码中的goto。p:{cout>c;switch(c){chart[20];case's':strcpy(t,"saving");a[i].setype(t);break;case'c':strcpy(t,

c++ - switch 语句和递增运算符

我写了下面的代码:inti=0;switch(i++){case0:cout代码的输出是这样的:011谁能解释一下输出的第一行?为什么0和1都被打印出来了? 最佳答案 首先,表达式i++(后递增运算符)的计算结果为0(即使它将i的值设置为1)。所以里面switch,case0:分支被选中。那么,因为没有break在你的case0:之后,程序继续执行case1:中的代码标签。总而言之,您有:第一个switch中的0个分支,1来自第二个分支,另外1因为那是i的最终值. 关于c++-switc

c++ - 高效的switch语句

在下面两个版本的switchcase中,我想知道哪个版本是高效的。1:string*convertToString(inti){switch(i){case1:returnnewstring("one");case2:returnnewstring("two");case3:returnnewstring("three");..default:returnnewstring("error");}}2:string*convertToString(inti){string*intAsString;switch(i){case1:intAsString=newstring("one");b

c++ - 模板类 : static members not inherited

这个问题在这里已经有了答案:Whydoesn'taderivedtemplateclasshaveaccesstoabasetemplateclass'identifiers?(4个答案)关闭7年前。下面的代码templatestructBase{staticconstinta=c+5;};templatestructDerived:Base{staticconstintb=a+5;};...编译失败因为awasnotdeclaredinthisscope.明确指定Base::a有效,但从逻辑上讲这不是必需的,因为我们是从Base派生的.这是预期的行为(以及为什么)还是我遗漏了什么?

c++ - 如果 switch case 失败,我如何让 MSVC 发出警告或失败?

如果我的一个switch语句有一个不中断的情况,我想得到一个警告/错误。这可能吗?switch(i){case1:cout在goingnative2012session上讨论了类似的Clang功能,但我需要它用于MSVC2013http://channel9.msdn.com/Events/GoingNative/GoingNative-2012/Clang-Defending-C-from-Murphy-s-Million-Monkeys理想情况下,当两个连续的主体没有被中断分开时,我会想要一个警告,这样上面的例子就会失败,但这不会:switch(i){case1:cout

c++ - C++ switch 仅适用于整数类型的基本原理是什么?

这个问题在这里已经有了答案:Whycan'ttheswitchstatementbeappliedtostrings?(22个答案)关闭7年前。我觉得C++应该允许switch()处理任何可以比较的类型,而不仅仅是整数类型。这似乎很奇怪:switch(myEnum){casemyEnumValue1:...break;casemyEnumValue1:...break;}在语义上等同于:if(myEnum==myEnumValue1)...elseif(myEnum==myEnumValue2)...但这只适用于整数类型。为什么?这样限制的目的是什么?我知道编译器为switch生成的代

c++ - 是否存在 static_warning?

我知道thisquestion其中提到了Boost的“STATICWARNING”,但我想再问一次,具体来说,我如何实现一个static_warning,它的操作类似于static_assert但只发出一个在编译时发出警告,而不是中止编译错误。我想要类似于Alexandrescu在C++11之前提出的静态断言提案,它以某种方式设法打印一些有用的上下文信息作为错误的一部分。要求用户启用某些标准编译器警告以使此构造工作(可能是“无效指针转换”或“违反严格的别名规则”)是可以接受的——任何应该属于正常编译器的警告编译反正可以用。简而言之,我希望static_warning(false,"He

c++ - constexpr if 和 static_assert

P0292R1constexprif一直included,在C++17的轨道上。它似乎很有用(并且可以替代SFINAE的使用),但是关于static_assert的评论是错误的,不需要诊断在false分支中吓到我了:Disarmingstatic_assertdeclarationsinthenon-takenbranchofaconstexprifisnotproposed.voidf(){ifconstexpr(false)static_assert(false);//ill-formed}templatevoidg(){ifconstexpr(false)static_asser

c++ - 优化 switch 语句时出现 Visual Studio 2005 C 编译器问题

其他人可能感兴趣的一般问题:据我所知,我遇到了一个带有switch语句的C++编译器优化(VisualStudio2005)问题。我想知道的是,是否有任何方法可以满足我的好奇心并找出编译器正在尝试但未能做到的事情。有没有我可以花一些时间(可能太多时间)破译的日志?我的具体问题对于那些足够好奇并继续阅读的人-我想听听您对我在这个具体案例中遇到问题的原因的看法。我有一个包含switch语句的大约500行代码的小程序。它的一些情况包含一些指针赋值。double*ptx,*pty,*ptz;double**ppt=newdouble*[3];//somecodeinitializingetcp