c++ error:crosses initialization of 问题解决

最近在写代码的时候,碰到了 crosses initialization of ... 的问题,只因我在 switch 的某个 case 分支下定义了一个变量,于是乎便将这个问题整理一下。

情形1 在 switch case 的某个分支定义了变量

1.1 问题代码示例


#include <iostream>

void switchTest(int code);

int main() {
    switchTest(1);
}

void switchTest(int code) {
	switch (code) {
	case 1:
		int myNum = 0;
		break;
	case 2:
		break;
	default:
		break;
	}
}

上述代码,我在第一个 case 分支下定义了 myNum 变量,尝试编译,出现如下错误。主要看 C2360 这一行,myNum 的初始化操作由 case标签跳过,也就是说当 code !=1 的时候,不会进行 myNum 的初始化。第一反应是“我这个 myNum 只在 case 1 下用啊,不初始化就不初始化嘛,反正其他地方又不用”。
在这里插入图片描述
呃,这就牵扯到变量的作用范围了。myNum 这个局部变量的作用范围是从定义处开始直到 switch 语句结束。通俗说,就算我们跳过了 case 1 处的初始化,myNum 在后面的分支中,也是可以被访问到的,被访问到就有可能被使用(虽然我们自己没打算在后面使用,但编译器认为这是有风险的),但是我们又没有对其进行初始化,那这就会出问题。那这个问题怎么处理呢?

1.2 问题的解决

1.2.1 限定 myNum 的作用域

void switchTest(int code) {
	switch (code)
	{
	case 1:
	{
		int myNum = 0;
		break;
	}
	case 2:
		break;
	default:
		break;
	}
}

我们给 case 1 加上大括号,明确告诉编译器,我们在后面不使用这个 myNum 了,它只在 case 1 里有效,这种方式应该是最符合我们本意的。

1.2.2 确保 myNun 被初始化

void switchTest(int code) {
	int myNum = 0;
	switch (code)
	{
	case 1:
		break;
	case 2:
		break;
	default:
		break;
	}
}

既然 myNum 不被初始化的原因的是 case 分支,那么我们将 myNum 的初始化提到 switch 外面吧,这样一来,在它的作用域内,myNum 就肯定会被初始化了。

1.2.3 不算方案的方案

void switchTest(int code) {
	switch (code)
	{
	case 2:
		break;
	case 1:
		int myNum = 0;
		break;
	}
}

上面这种写法是能编译过的,而且满足我的意图。我把 case 1 放到了最后一个分支,这样一来,myNum 的作用域就只是在最后一个分支了,在 myNum 的作用域内,它都是被初始化了的,因此是不会出问题的。当然,这样写只是为了说明,出现这个错误的根因是:变量在其作用范围内,可能不会被初始化。(项目中请勿这样弄哦)

情形2 goto 跳过了变量的初始化

2.1 goto 中的错误示例

#include <iostream>

void gotoTest();

int main()
{
	gotoTest();
}

void gotoTest() {
	goto label;
	int myNum = 1;
	label: std::cout << "goto the label" << std::endl;
}

上面的代码里,我们使用 goto 跳过了 myNum 的初始化,不出意外的出了意外,编译时出现如下错误,原因和我们上面 switch 的例子是一样的,那解决方法自热也是类似的
在这里插入图片描述

2.2 问题的解决

2.2.1 限定 myNum 的作用域

void gotoTest() {
	goto label;
	{
		int myNum = 1;
	}
	label: std::cout << "goto the label" << std::endl;
}

限制 myNum 的作用域,告诉编译器我们在后面不使用了。

2.2.2 确保 myNun 被初始化

void gotoTest() {
	int myNum = 1;
	goto label;
	label: std::cout << "goto the label" << std::endl;
}

将 myNum 的初始化提前,确保不会因为 goto 导致跳过了初始化。

结论

crosses initialization of 翻译过来就是 跳过了初始化,根本原因是变量在其作用范围内,存在不被初始化的风险,解决思路有两个:一是明确限定变量的作用域;而是将初始化提前,避免不被初始化的发生。

  • 12
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在给定的代码中,发生了变量的初始化跳过导致的错误。根据引用的内容,使用了goto语句跳过了变量myNum的初始化,这与之前switch语句的例子类似。这种情况下,解决方法也是相似的。为了解决这个问题,可以限定myNum变量作用域,稍作修改如下所示: ``` void gotoTest() { { int myNum = 1; goto label; } label: std::cout << "goto the label" << std::endl; } ``` 这样做的目的是在变量使用的同时限定其作用域,确保在跳转时不会跳过变量的初始化。根据引用的内容,这种限定作用域的做法可以避免跳过变量声明导致的错误。 另外,根据引用的内容,当只打开第一种情况时,即执行了"goto _Lab1"语句跳转到标签_Lab1处,导致变量t2没有初始化,从而导致编译错误。为了解决这个问题,可以在_Lab1前先定义并初始化变量t2,如下所示: ``` void testFunction() { int t2 = 0; // 初始化变量t2 if (condition1) { goto _Lab1; } // ... _Lab1: // ... } ``` 这样做的目的是在跳转到_Lab1之前确保t2变量已经被正确初始化,避免编译错误。这是引用中给出的解决方法之一。 综上所述,为了解决编译错误"crosses initialization of 'char day [10]'",需要注意在使用goto语句跳转时,避免跳过变量的初始化,并且在跳转前确保变量已经被正确初始化。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [c++ error:crosses initialization of 问题解决](https://blog.csdn.net/hejnhong/article/details/129676548)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [两次碰到编译错误: crosses initialization of...](https://blog.csdn.net/u012294613/article/details/127207761)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值