在switch中的case语句中声明变量编译出错的解决方案
在switch中的case语句中声明变量编译的问题
先来看段代码,别管什么意思:
case 10:
int i = 0, j = 0;
for (i = 0; i < 11; i++)
recive_phone[i] = msgbuf.text[i];
recive_phone[i] = '\0';
printf("%s文件%s函数%d行:接收端号码:%s\n", __FILE__
, __FUNCTION__, __LINE__, recive_phone);
for (j = 0; msgbuf.text[i] != '\0' && j < 12; i++,j++)
center_phone[j] = msgbuf.text[i];
center_phone[j] = '\0';
printf("%s文件%s函数%d行:发送端号码:%s\n", __FILE__
, __FUNCTION__, __LINE__, center_phone);
break;
我在case:break中声明了变量,结果gcc编译时就提示:
error: a label can only be part of a statement and a declaration is not a statement
有下面三种方法处理:
1、将变量定义放到case:break外面;
2、将case:break中间的语句用{}包含;
case 10: {
int i = 0, j = 0;
for (i = 0; i < 11; i++)
recive_phone[i] = msgbuf.text[i];
recive_phone[i] = '\0';
printf("%s文件%s函数%d行:接收端号码:%s\n", __FILE__
, __FUNCTION__, __LINE__, recive_phone);
for (j = 0; msgbuf.text[i] != '\0' && j < 12; i++,j++)
center_phone[j] = msgbuf.text[i];
center_phone[j] = '\0';
printf("%s文件%s函数%d行:发送端号码:%s\n", __FILE__
, __FUNCTION__, __LINE__, center_phone);
}
break;
注意case后{}括号
3、在“case:”后面加“;”处理。
case 10: ;
int i = 0, j = 0;
for (i = 0; i < 11; i++)
recive_phone[i] = msgbuf.text[i];
recive_phone[i] = '\0';
printf("%s文件%s函数%d行:接收端号码:%s\n", __FILE__
, __FUNCTION__, __LINE__, recive_phone);
for (j = 0; msgbuf.text[i] != '\0' && j < 12; i++,j++)
center_phone[j] = msgbuf.text[i];
center_phone[j] = '\0';
printf("%s文件%s函数%d行:发送端号码:%s\n", __FILE__
, __FUNCTION__, __LINE__, center_phone);
break;
在switch中的case语句中声明变量编译出错的解决方案的更多相关文章
- 在switch中的case语句中声明变量会被提前
原文链接:http://my.oschina.net/u/2000201/blog/514384 本人今天在编写工具类时,无意之间发现,在Java的Swith语句的case语句中声明局部变量时出现了一 ...
- switch case语句中能否作用在String,long上
在之前的eclipse中使用switch的case语句时是只能为(byte,short,char)int类型或枚举类型.但在jdk1.7以后 在case语句中是可以使用String 以及long 等类 ...
- Shell编程-07-Shell中的case语句
目录 基本语法 case示例 case语句总结 case语句相当于多分支的if/elif/else语句,而在使用case会让脚本看起来更简单工整.在case语句中,程序会将获取到的值与case ...
- Mybatis中动态SQL语句中的parameterType不同数据类型的用法
Mybatis中动态SQL语句中的parameterType不同数据类型的用法1. 简单数据类型, 此时#{id,jdbcType=INTEGER}中id可以取任意名字如#{a,jdbcType ...
- MyBatis 中实现SQL语句中in的操作 (11)
MyBatis 中实现SQL语句中in的操作 概括:应用myBatis实现SQL查询中IN的操作 1.数据库结构及其数据 2.mapper.xml文件 <?xml version="1 ...
- switch...case... 语句中的类型转换
switch语句对case表达式的结果类型有如下要求: 要求case表达式的结果能转换为switch表示式结果的类型 并且如果switch或case表达式的是无类型的常量时,会被自动转换为此种常量的默 ...
- swtich和case语句中,定义变量要加花括号
转自: http://blog.chinaunix.net/uid-27103408-id-3340702.html http://www.xuebuyuan.com/2070170.html swi ...
- 在 case 语句中使用字符串-转
http://www.cnblogs.com/del/archive/2008/07/08/1237856.html 非常遗憾 Delphi 的 case 语句不支持字符串, 但我觉得这也可能是基于效 ...
- MySQL中的case when 中对于NULL值判断的坑
sql中的case when 有点类似于Java中的switch语句,比较灵活,但是在Mysql中对于Null的处理有点特殊 Mysql中case when语法: 语法1: CASE case_val ...
随机推荐
- JavaScript技巧45招(转)
原文:45 Useful JavaScript Tips, Tricks and Best Practices作者:Saad Mousliki 在这篇文章里,我将分享一些JavaScript的技巧.秘 ...
- Sed - An Introduction and Tutorial by Bruce Barnett
http://www.grymoire.com/unix/sed.html Quick Links - NEW Sed Commands : label # comment {....} Block ...
- linux-pm2用法
devo.ps团队对JavaScript的迷恋已经不是什么秘密了;node.js作为服务器端,AngularJS作为客户端,某种程度上说,我们的堆栈是用它建成的.我们构建静态客户端和RESTful J ...
- Flask & Vue 构建前后端分离的应用
Flask & Vue 构建前后端分离的应用 最近在使用 Flask 制作基于 HTML5 的桌面应用,前面写过<用 Python 构建 web 应用>,借助于完善的 Flask ...
- Mybatis JdbcType与Oracle、MySql数据类型对应列表
1. Mybatis JdbcType与Oracle.MySql数据类型对应列表 Mybatis JdbcType Oracle MySql JdbcType ARRAY JdbcType B ...
- Firebird Fluentdata
Fluentdata 支持很多种数据库驱动,但对Firebird不友好,不过可以使用DB2Provider来操作大部分功能, 例如: new DbContext().ConnectionString( ...
- dozer 简单用法
maven添加必要的库: <!-- https://mvnrepository.com/artifact/net.sf.dozer/dozer --> <dependency> ...
- Shell脚本之awk详解
一.基本介绍 1.awk: awk是一个强大的文本分析工具,在对文本文件的处理以及生成报表,awk是无可替代的.awk认为文本文件都是结构化的,它将每一个输入行定义为一个记录,行中的每个字符串定义为一 ...
- 清除SQL Server内存
数据库进行查询时,会缓存结果集,当查询结果过大时会出现内存爆满的情况,如果手动清除SQL所占用的内存呢,在网上搜索一下,把结果贴下面: --强制释放内存 Create procedure [dbo]. ...
- Java如何实现form表单提交的数据自动对应实体类(源码)
原文出自:https://blog.csdn.net/seesun2012 原生Java+JQuery form表单serializeArray提交自动对应java实体,这是一个实际的例子: html ...