我不了解/不知道如何将我的if else语句更改为case的switch语句。请帮忙!我只需要将if else语句更改为一个开关即可完成我的分配!它完全运行并正常运行!
此C程序提供了一个主要功能,支持类似bash的历史记录 能力;循环缓冲区的主要目标是重复 向用户显示提示,并且每个提示都分配一个输入号码开头 在1。输入到循环缓冲区的每一行都被存储,直到被覆盖为止, 缓冲区最多只允许存储5行输入FIFO(先进先出)。
为用户提供4个命令选项: !x:x表示选定的行号,感叹号(“!”)表示 重复编号为x的(绝对)输入行。仅当此行是 保存的命令。此命令将显示原始输入行以及 存储副本。如果参数x无效,将显示错误消息。
退出(区分大小写):终止程序。
历史记录(区分大小写):打印保存的命令
parse(区分大小写):对输入行号x进行标记,此输入行不应为 存储在缓冲区中,而是在单独的一行上显示每个单词。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define CIRCULAR_HISTORY_BUFFER 5
#define CHARACTER_LENGTH 128
void CircularHistoryBuffer()
{
char memory[CIRCULAR_HISTORY_BUFFER][CHARACTER_LENGTH];
char command_line[CHARACTER_LENGTH];
int data, n, i;
int number = 0;
while(1)
{
printf("%d>", number + 1);
fgets(command_line, CHARACTER_LENGTH - 1, stdin);
for(i = 0; i < CHARACTER_LENGTH; i++)
{
if(command_line[i] == '\n')
{
command_line[i] = '\0';
break;
}
}
if(command_line[0] == '!')
{
n = atoi(command_line + 1);
if(n < number - CIRCULAR_HISTORY_BUFFER + 1 || n > number || n <= 0)
{
printf( "%d: Not found\n", n);
}
else
{
data = (n - 1) % CIRCULAR_HISTORY_BUFFER;
printf("%s\n", memory[data]);
strcpy(memory[number % CIRCULAR_HISTORY_BUFFER], memory[data]);
number++;
}
}
else if(strcmp(command_line, "exit") == 0)
{
exit(0);
}
else if(strcmp(command_line, "history") == 0)
{
if(number <= CIRCULAR_HISTORY_BUFFER)
{
for(i = 0; i < number; i++)
{
printf("%d\t%s\n", i + 1, memory[i]);
}
}
else
{
n = number - CIRCULAR_HISTORY_BUFFER + 1;
data = number % CIRCULAR_HISTORY_BUFFER;
for(i = data; i < CIRCULAR_HISTORY_BUFFER; i++)
{
printf("%d\t%s\n", n++, memory[i]);
}
for(i = 0; i < data; i++)
{
printf("%d\t%s\n", n++, memory[i]);
}
}
}
else if(strncmp(command_line, "parse", 5) == 0)
{
n = atoi(command_line + 5);
if(n < number - CIRCULAR_HISTORY_BUFFER + 1 || n > number || n <= 0)
{
printf("%d: event not found\n", n);
}
else
{
data = (n - 1) % CIRCULAR_HISTORY_BUFFER;
for(i = 0; i < strlen(memory[data]); i++)
{
if(memory[data][i] == ' ')
{
printf("\n");
}
else
{
printf("%c", memory[data][i]);
}
}
printf("\n");
}
}
else
{
strcpy(memory[number % CIRCULAR_HISTORY_BUFFER], command_line);
number++;
}
}
}
int main()
{
CircularHistoryBuffer();
return 0;
}
答案 0 :(得分:0)
在这种情况下,使用switch语句没有多大意义,因为您正在考虑进行多个字符串比较。
您可以执行的是基于字母顺序排序的表的表查找:
const char* STR_TABLE[] = // must be sorted in alphabetic order
{
"exit",
"history",
"parse",
...
};
const size_t STR_TABLE_SIZE = sizeof(STR_TABLE) / sizeof(STR_TABLE[0]);
然后可以在表格中搜索正确的字符串。天真的实现是for循环:
for(size_t i=0; i<STR_TABLE_SIZE; i++)
{
if(strcmp(STR_TABLE[i], user_input)==0)
{
// found, do something
break;
}
}
当表中的字符串数受到限制时,这是最佳选择。对于较大的表,应改为使用二进制搜索。像这样:
int strcmp_wrapper (const void* obj1, const void* obj2)
{
return strcmp(obj1, *(const char**)obj2);
}
const char** result = bsearch(user_input,
STR_TABLE,
STR_TABLE_SIZE,
sizeof(const char*),
strcmp_wrapper);
if(result != NULL)
{
printf("User picked option %s at index %d.", *result, (int)(result - STR_TABLE));
}
答案 1 :(得分:0)
switch
语句仅适用于整数值。
有switch
条语句用法:
switch(a)
{
case '1': doSomething(); break; // if you forget break operator, than second
案例also will invoke and so one
case '2': doSomethingElse(); break;
default: doSomethingElse2();
}
如果需要使用特定范围内的整数值/常量,则可以使用switch
语句。
答案 2 :(得分:0)
当前您的代码如下:
if(command_line[0] == '!') { <recall> } else if(strcmp(command_line, "exit") == 0) { <exit> } else if(strcmp(command_line, "history") == 0) { <historic> } else if(strncmp(command_line, "parse", 5) == 0) { <parse> } else { <other> }
使用开关会给出类似的信息:
switch (command_line[0]) {
case '!':
<recall>
break;
case 'e':
if(strcmp(command_line + 1, "xit") == 0)
{
<exit>
}
else
{
<other>
}
break
case 'h':
if(strcmp(command_line + 1, "istory") == 0)
{
<historic>
}
else
{
<other>
}
break
case 'p':
if(strncmp(command_line + 1, "arse", 4) == 0)
{
<parse>
break;
}
// no fallthrough
default:
{
<other>
}
}
这不太容易理解,如果需要修改,则有助于引入错误;如果达到您的期望,则不会对速度产生有益的影响
对我来说不要那样做 ... ...但是请问自己有关 strcmp 的问题,但请问一下 strncmp 的情况