在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语句中声明变量编译出错的解决方案的更多相关文章

  1. 在switch中的case语句中声明变量会被提前

    原文链接:http://my.oschina.net/u/2000201/blog/514384 本人今天在编写工具类时,无意之间发现,在Java的Swith语句的case语句中声明局部变量时出现了一 ...

  2. switch case语句中能否作用在String,long上

    在之前的eclipse中使用switch的case语句时是只能为(byte,short,char)int类型或枚举类型.但在jdk1.7以后 在case语句中是可以使用String 以及long 等类 ...

  3. Shell编程-07-Shell中的case语句

    目录 基本语法 case示例 case语句总结     case语句相当于多分支的if/elif/else语句,而在使用case会让脚本看起来更简单工整.在case语句中,程序会将获取到的值与case ...

  4. Mybatis中动态SQL语句中的parameterType不同数据类型的用法

    Mybatis中动态SQL语句中的parameterType不同数据类型的用法1. 简单数据类型,    此时#{id,jdbcType=INTEGER}中id可以取任意名字如#{a,jdbcType ...

  5. MyBatis 中实现SQL语句中in的操作 (11)

    MyBatis 中实现SQL语句中in的操作 概括:应用myBatis实现SQL查询中IN的操作 1.数据库结构及其数据 2.mapper.xml文件 <?xml version="1 ...

  6. switch...case... 语句中的类型转换

    switch语句对case表达式的结果类型有如下要求: 要求case表达式的结果能转换为switch表示式结果的类型 并且如果switch或case表达式的是无类型的常量时,会被自动转换为此种常量的默 ...

  7. swtich和case语句中,定义变量要加花括号

    转自: http://blog.chinaunix.net/uid-27103408-id-3340702.html http://www.xuebuyuan.com/2070170.html swi ...

  8. 在 case 语句中使用字符串-转

    http://www.cnblogs.com/del/archive/2008/07/08/1237856.html 非常遗憾 Delphi 的 case 语句不支持字符串, 但我觉得这也可能是基于效 ...

  9. MySQL中的case when 中对于NULL值判断的坑

    sql中的case when 有点类似于Java中的switch语句,比较灵活,但是在Mysql中对于Null的处理有点特殊 Mysql中case when语法: 语法1: CASE case_val ...

随机推荐

  1. 这是关于FastJson的一个使用Demo,在Java环境下验证的

    public class User { private int id; private String name; public int getId() { return id; } public vo ...

  2. MySQL的模糊搜索

    1.模糊搜索 第一时间我马上想到了关键字 like 1.1.所要查询的字段中包含特定 字符,但不确定其位置,使用两个%包起来 select * from phone where provider li ...

  3. Map集合遍历的4种方法

    完全复制https://www.cnblogs.com/blest-future/p/4628871.html import java.util.HashMap; import java.util.I ...

  4. 《Maven实战》关联实际工作的核心知识

    通读了<Maven实战>这本书,由于在实际的工作中,对其有一定的操作上的经验.因此,再回头去通读这本书,就能够更加精准的把握里面的核心知识了. 以下我主要从两点去介绍之—— 1> m ...

  5. 在WPF中自定义控件

    一, 不一定需要自定义控件在使用WPF以前,动辄使用自定义控件几乎成了惯性思维,比如需要一个带图片的按钮,但在WPF中此类任务却不需要如此大费周章,因为控件可以嵌套使用以及可以为控件外观打造一套新的样 ...

  6. [Erlang]各种系统限制总结

    Erlang本身对进程数,原子长度等没有限制,但为了提高性能和节省内存,总会在实际实现中和运行环境中作出一些限制. 1.进程数量 缺省情况下同时存在的最大Erlang进程数量不超过2^18=26214 ...

  7. POI 2000 ------Stripes

    Stripes Time Limit:1000MS Memory Limit:30000KBTotal Submit:94 Accepted:43 Description Stripes is a t ...

  8. git 永久性设置密码

    git 设置不需要输入密码 https方式每次都要输入密码,按照如下设置即可输入一次就不用再手输入密码的困扰而且又享受https带来的极速 设置记住密码(默认15分钟): git config --g ...

  9. python----openpyxl模块

    openpyxl 模块 1.openpyxl的写 from openpyxl import Workbook wb = Workbook() # 方式一: 默认创建sheet在最后 wb1 = wb. ...

  10. mysql load data infile auto increment id

    1. 问题描述 当使用load data infile 向表中插入数据 而主键id是 auto_increment 时 ,执行 load data 不会报错 但插入也不成功 2. 问题解决 2.1 方 ...