// 向客户端回显历史记录 if (row == 0) { // 说明没有历史记录 // memset(content, 0, sizeof(content)); strcpy(content, "没有历史记录,开始查询单词吧!"); if ((send(event_fd, content, strlen(content), 0)) == -1) printf("send error"); // 发送查询后的结果 } else { int index = column; // 数组下标走到第一行第一个内容 for (int i = 0; i < row; i++) { memset(content, 0, sizeof(content)); sprintf(content, "历史记录:时间[%s] 单词[%s]\n", result[index], result[index + 1]); if ((send(event_fd, content, strlen(content), 0)) == -1) printf("send error"); // 发送查询后的结果 index += column; } } memset(content, 0, sizeof(content)); strcpy(content, "**OVER**\n"); send(event_fd, content, strlen(content), 0); 上面是服务端代码,// 接收服务端查询到的历史记录信息 while(1){ memset(content, 0, sizeof(content)); recv(listen_fd, content, sizeof(content)-1, 0); if(strcmp(content, "**OVER**") == 0){ break; } printf("%s\n", content); } 这两段代码结合有什么问题吗
时间: 2024-04-27 13:25:40 浏览: 55
这两段代码结合起来没有明显的问题。第一段代码在服务端发送历史记录信息给客户端。第二段代码在客户端接收服务端发送的历史记录信息。客户端通过一个 while 循环不断接收服务端发送的数据,直到接收到 "**OVER**" 结束标志为止。服务端在发送完所有历史记录信息后,也会发送一个 "**OVER**" 结束标志。因此,这两段代码结合起来可以实现服务端将历史记录信息发送给客户端并在客户端展示出来的功能。
相关问题
void do_check_history(user_t user, char name_copy[32], sqlite3* sqlite_p, int event_fd) { char content[128] = { 0 }; char* errmsg = NULL; // 接收错误信息指针 char** result = NULL; // 结果集指针 int row = 0; // 数据表行 int column = 0; // 数据表列 printf("开始查询[%s]的历史记录\n", name_copy); // 查找历史记录,获取结果集 char sql[1024] = { 0 }; sprintf(sql, "select * from %s ", name_copy); int ret = sqlite3_get_table(sqlite_p, sql, &result, &row, &column, &errmsg); if (ret != SQLITE_OK) { printf("历史记录数据表提取信息失败\n"); } printf("历史记录数据表提取信息成功\n"); // 向客户端回显历史记录 int index = column; // 数组下标走到第一行第一个内容 for (int i = 0; i < row; i++) { sprintf(content, "时间[%s] 单词[%s]", result[index], result[index + 1]); if ((send(event_fd, content, sizeof(content), 0)) == -1) printf("send error"); // 发送查询后的结果 // memset(content, 0, sizeof(content)); index += column; } strcpy(content, "OVER"); send(event_fd, content, sizeof(content), 0); // 释放错误指针空间 sqlite3_free(errmsg); // 释放结果集 sqlite3_free_table(result); }代码修正
修正后的代码如下:
```
void do_check_history(user_t user, char name_copy[32], sqlite3* sqlite_p, int event_fd) {
char content[128] = { 0 };
char* errmsg = NULL; // 接收错误信息指针
char** result = NULL; // 结果集指针
int row = 0; // 数据表行
int column = 0; // 数据表列
// 输入参数有效性校验
if (name_copy == NULL || sqlite_p == NULL) {
printf("输入参数无效\n");
return;
}
printf("开始查询[%s]的历史记录\n", name_copy);
// 查找历史记录,获取结果集
char sql[1024] = { 0 };
snprintf(sql, sizeof(sql), "SELECT * FROM %s ", name_copy);
int ret = sqlite3_get_table(sqlite_p, sql, &result, &row, &column, &errmsg);
if (ret != SQLITE_OK) {
printf("历史记录数据表提取信息失败\n");
sqlite3_free(errmsg);
return;
}
printf("历史记录数据表提取信息成功\n");
// 向客户端回显历史记录
int index = column; // 数组下标走到第一行第一个内容
for (int i = 0; i < row; i++) {
snprintf(content, sizeof(content), "时间[%s] 单词[%s]", result[index], result[index + 1]);
if ((send(event_fd, content, strlen(content), 0)) == -1) {
printf("send error\n");
break;
}
index += column;
}
// 发送查询结束标志
strcpy(content, "OVER");
send(event_fd, content, strlen(content), 0);
// 释放错误指针空间
sqlite3_free(errmsg);
// 释放结果集
sqlite3_free_table(result);
}
```
修正后的代码增加了输入参数有效性校验,使用了更安全的函数snprintf,增加了数据库操作的错误处理和发送操作的错误处理,以及格式化输出。
阅读全文