按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭11年前。我正在阅读一篇有趣的文章here它提出了一个关于vb.net中的“case”语句与C#中的“switch”语句的有趣观点,我已将其粘贴在下面:以下VisualBasicSelectCase语句无法在C#中用单个switch语句表示:DimConditionAsInteger=55SelectCaseConditionCase1,3To5,10,12,14
我的资源(.resx)文件中有一堆字符串。我试图直接将它们用作switch语句的一部分(请参阅下面的示例代码)。classTest{staticvoidmain(string[]args){stringcase=args[1];switch(case){caseStringResources.CFG_PARAM1://DoSomething1break;caseStringResources.CFG_PARAM2://DoSomething2break;caseStringResources.CFG_PARAM3://DoSomething3break;default:break;}}
在switch中,如果我们写任何单词或单个字母而不是default,它不会抛出错误。例如switch(10){case1:break;hello:break;}它运行时没有抛出错误。谁能解释一下这是如何工作的? 最佳答案 它正在编译,因为hello:是一个标签,因此可以作为goto的目的地。当我编译这个时,我收到了关于未引用标签的警告(因为我没有转到)这是您可以放入LINQPad的示例-您会注意到它同时打印“1”和“hello”:switch(1){case1:"1".Dump();gotohello;break;hello:"he
这个问题在这里已经有了答案:Multiplecasesinswitchstatement(24个答案)Switchcase:canIusearangeinsteadofaonenumber[duplicate](16个答案)关闭1年前。有谁知道是否可以在switch语句中包含范围(如果可以,如何)?例如:switch(x){case1://dosomethingbreak;case2..8://dosomethingelsebreak;default:break;}编译器似乎不喜欢这种语法——它也不喜欢:case
谁能告诉我为什么我需要从我的枚举中转换为Intswitch(Convert.ToInt32(uxView.SelectedValue)){case(int)ViewBy.Client:如果我删除强制转换(int),它会失败并提示我必须使用强制转换。这是我的枚举,枚举是整数....有人知道吗?publicenumViewBy{Client,Customer} 最佳答案 在C#中,enum不仅仅是数字。相反,它们是与类型相关联的数字或在上下文中具有名称的数字。要避免在case语句中进行强制转换,您可以在switch中进行强制转换:swi
再次受到-5问题的启发!IsemptycaseofswitchinC#combinedwiththenextnon-emptyone?我阅读了[thiscomment]的@Quartermeister并感到惊讶!那么为什么这个可以编译switch(1){case2:}但这不是。inti;switch(i=1){case2://Controlcannotfallthroughfromonecaselabel('case2:')toanother}这都不是switch(2){case2://Controlcannotfallthroughfromonecaselabel('case2:')
我以不同的方式找到了一个关于实现枚举的漂亮示例。我认为这就是所谓的类型安全枚举模式。我开始使用它,但我意识到我不能在switch语句中使用它。我的实现如下所示:publicsealedclassMyState{privatereadonlystringm_Name;privatereadonlyintm_Value;publicstaticreadonlyMyStatePASSED=newMyState(1,"OK");publicstaticreadonlyMyStateFAILED=newMyState(2,"ERROR");privateMyState(intvalue,stri
我有一个基于Javascript的机器人,用于Xat聊天室,它也充当AI。我最近决定重做它的AI部分,因为它变成了绝对庞大的elseif语句链,几乎无法使用。我做了一些研究并想出了一个关于如何处理响应的新想法。我先给你代码段:functionmsgSwitch(id,msgRes){varbotResponse=[];switch(msgRes){case(msgRes.indexOf("hi")!=-1):botResponse.push("HELLO.");case(msgRes.indexOf("howareyou")!=-1):botResponse.push("IAMFINE
为了某种类型安全,我想在我的Controller逻辑中引入一些枚举,所以例如我创建了这样的东西:varapp=angular.module('myApp',[]);varStateEnum=Object.freeze({"login":1,"logout":2})functionLoginCheckCtrl($scope){$scope.stateEnum=StateEnum$scope.loginData=StateEnum.login$scope.login=function(){console.log($scope.loginData?'loggedin':'notloggedi
我继承了一个项目,该项目有一些巨大的switch语句block,其中一些包含多达20个案例。重写这些的好方法是什么? 最佳答案 为什么要用不同的结构重写它们?如果你真的有20个案例需要单独处理,那么switch/case是可行的方法。一大串if/then逻辑很难维护。如果您使用面向对象的语言,多态性是另一种选择。每个子类都将在方法中实现它自己的功能。 关于c#-失控的switch语句的最佳替代方法是什么?,我们在StackOverflow上找到一个类似的问题: