5.请指出下面代码的错误 int handle_message(int message_id) { int result = 0; switch (message_id) { case MSG_ID_NOTIFY: route_to_notify_thread (message_id); break; case MSG_ID_SHUTDOWN: case MSG_ID_REBOOT: LOGI("System Message %d =====\n", message_id) send_msg_to_sys_thread(message_id); break; default: LOGE ("===== Kaka Wrone Message %d =======\n", message_id) break; } return result;
时间: 2023-12-03 07:45:34 浏览: 13
下面代码的错误是缺少了一些分号,正确的代码如下:
```
int handle_message(int message_id) {
int result = 0;
switch (message_id) {
case MSG_ID_NOTIFY:
route_to_notify_thread (message_id);
break;
case MSG_ID_SHUTDOWN:
case MSG_ID_REBOOT:
LOGI("System Message %d =====\n", message_id); // 需要加分号
send_msg_to_sys_thread(message_id);
break;
default:
LOGE ("===== Kaka Wrone Message %d =======\n", message_id); // 需要加分号
break;
}
return result;
}
```
相关问题
7.请指出下面代码中的错误 #define LOGD(...) printk(KERN_DEBUG __VA_ARGS__); log_to_storage (__VA_ARGS__); int handle_message(int message_id) { int result = 0; static int message_count; switch (message_id) { case MSG_ID_STORE_COUNT: LOGD("message_count: %d\n", message_count++); break; case MSG_ID_CHECK_STATUS: result = handle_check_status(); message_count++; break; default: break; } return result; }
在这段代码中有以下错误:
1. 在handle_message函数中第12行,message_count++;应该改为message_count++,因为分号是多余的。
2. 在LOGD宏定义中,__VA_ARGS__应该放在括号内,即printk(KERN_DEBUG, __VA_ARGS__);。
3. 未定义log_to_storage函数,这可能会导致编译错误。
正确的代码如下:
```
#define LOGD(fmt, ...) \
printk(KERN_DEBUG fmt, ##__VA_ARGS__); \
log_to_storage(fmt, ##__VA_ARGS__)
int handle_message(int message_id) {
int result = 0;
static int message_count;
switch (message_id) {
case MSG_ID_STORE_COUNT:
LOGD("message_count: %d\n", message_count++);
break;
case MSG_ID_CHECK_STATUS:
result = handle_check_status();
message_count++;
break;
default:
break;
}
return result;
}
```
7.请指出下面代码中的错误 #define LOGD(...) printk(KERN_DEBUG _VA_ARGS_); log_to_storage (_VA_ARGS_): int handle_message(int message_id) { int result = 0; static int message_count; switch (message_id) { case MSG_ID_STORE_COUNT: LOGD("message_count: %d\n", message_count++); break; case MSG_ID_CHECK_STATUS: result = handle_check_status(); message_count++; break; default: break; } return result; }
下面是代码中的错误:
1. 在宏定义`LOGD`中,`_VA_ARGS_`应该是`__VA_ARGS__`,即两个下划线。
2. 在`MSG_ID_CHECK_STATUS`分支中,`message_count++`后面多了一个分号。
修改后的代码如下:
```
#define LOGD(...) printk(KERN_DEBUG __VA_ARGS__); log_to_storage (__VA_ARGS__)
int handle_message(int message_id) {
int result = 0;
static int message_count;
switch (message_id) {
case MSG_ID_STORE_COUNT:
LOGD("message_count: %d\n", message_count++);
break;
case MSG_ID_CHECK_STATUS:
result = handle_check_status();
message_count++;
break;
default:
break;
}
return result;
}
```