gpt4 book ai didi

c - 我如何操作这个表?

转载 作者:行者123 更新时间:2023-11-30 17:36:50 25 4
gpt4 key购买 nike

我一直在尝试寻找优化代码的方法,但有一个问题,我能想到的唯一方法就是使用我们老师给出的表格。我尝试进行操作,但无法让它按预期工作。

关于这个项目,我和我的团队必须制作一个编译器,将 .s 文件转换为将用于 corewar 的 .cor 文件。我负责检测命令并处理错误的语法。我的程序会检测您可以执行的所有不同命令。这就是我现在得到的。

int     reading_file(char *pepper)
{
char *bffr;
int k;

k = 0;
while ((bffr = get_next_line(0)))
{
while (bffr[k] == '\t')
k++;
my_putstr(bffr);
my_putchar('\n');
if ((strncmp((bffr + k), "ld", my_strlen("ld"))) == 0)
my_putstr("it works! \n");
else if (strncmp((bffr + k), "zjmp", my_strlen("zjmp")) == 0)
my_putstr("it works!\n");
else if (strncmp((bffr + k), "sti", my_strlen("sti")) == 0)
my_putstr("it works! \n");
else if (strncmp((bffr + k), "live", my_strlen("live")) == 0)
my_putstr("it works! \n");
else if (strncmp((bffr + k), "st", my_strlen("st")) == 0)
my_putstr("it works!");
/* all of the other commands go after this */
k = 0;
}
}

现在,这没有问题,但它看起来并不是非常优化,正如我之前所说,我尝试使用我们老师给出的表格,它包含每个命令所需的所有信息。我理解表格的每个部分的含义,但我完全不知道如何操作它。

这是该表以及与其相关的结构:

结构:

struct  op_s
{
char *mnemonique;
char nbr_args;
args_type_t type[MAX_ARGS_NUMBER];
char code;
int nbr_cycles;
char *comment;
};

typedef struct op_s op_t;

表:

#include "op.h"

op_t op_tab[] =
{
{"live", 1, {T_DIR}, 1, 10, "alive"},
{"ld", 2, {T_DIR | T_IND, T_REG}, 2, 5, "load"},
{"st", 2, {T_REG, T_IND | T_REG}, 3, 5, "store"},
{"add", 3, {T_REG, T_REG, T_REG}, 4, 10, "addition"},
{"sub", 3, {T_REG, T_REG, T_REG}, 5, 10, "soustraction"},
{"and", 3, {T_REG | T_DIR | T_IND, T_REG | T_IND | T_DIR, T_REG}, 6, 6,
"et (and r1, r2, r3 r1&r2 -> r3"},
{"or", 3, {T_REG | T_IND | T_DIR, T_REG | T_IND | T_DIR, T_REG}, 7, 6,
"ou (or r1, r2, r3 r1 | r2 -> r3"},
{"xor", 3, {T_REG | T_IND | T_DIR, T_REG | T_IND | T_DIR, T_REG}, 8, 6,
"ou (xor r1, r2, r3 r1^r2 -> r3"},
{"zjmp", 1, {T_DIR}, 9, 20, "jump if zero"},
{"ldi", 3, {T_REG | T_DIR | T_IND, T_DIR | T_REG, T_REG}, 10, 25,
"load index"},
{"sti", 3, {T_REG, T_REG | T_DIR | T_IND, T_DIR | T_REG}, 11, 25,
"store index"},
{"fork", 1, {T_DIR}, 12, 800, "fork"},
{"lld", 2, {T_DIR | T_IND, T_REG}, 13, 10, "long load"},
{"lldi", 3, {T_REG | T_DIR | T_IND, T_DIR | T_REG, T_REG}, 14, 50,
"long load index"},
{"lfork", 1, {T_DIR}, 15, 1000, "long fork"},
{"aff", 1, {T_REG}, 16, 2, "aff"},
{0, 0, {0}, 0, 0, 0}
};

现在,我刚才尝试做一些事情,但它没有按预期工作:

int     reading_file(char *pepper)
{
char *bffr;
int k;
op_t woop;

k = 0;
while ((bffr = get_next_line(0)))
{
while (bffr[k] == '\t')
k++;
my_putstr(bffr);
my_putchar('\n');
if ((strncmp((bffr + k), woop.mnemonique, my_strlen(woop.mnemonique))) == 0)
my_putstr("it works!\n");

k = 0;
}
}

此代码将显示“it Works!”到处都是。这不是我要找的。

简而言之,除了使用 if 和 else if 条件墙之外,还有其他方法可以做到这一点吗?是否可以通过操作给我的表格来做到这一点?

最佳答案

恕我直言,棘手的是 C 并不将字符串视为“真实”类型,这就是为什么你最终会得到瀑布 else ifstrcmp .

我不确定它是否已优化,但我想到了一个技巧:您可以(仔细)将字符串转换为整数(仔细检查重复项和副作用,例如特殊字符 \n , \t, \0, ...):通过这样做,您将能够将倍数 if/else 替换为漂亮的开关盒。看这个post

关于c - 我如何操作这个表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22559139/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com