首先我是在学习的时候遇到这样一段代码
char cmd[MAX_CMD_PART][MAX_LEN_PART]; //当前解析出来的命令
void cmd_paser(char *str)
{
int i;
//step1:把用户输入的命令字符串分割放入cmd中
cmdsplit(cmd, str);
//step2:把cmd中的次命令的第一个字符串与cmdset里面比较
cmd_index = -1;
for(i=0;i<CMD_NUM;i++)
{
//次命令中的第一个字符串就是主命令
if(!strcmp(cmd[0],g_cmdset[i]))
{
//command has been found, and then run the command
//puts("the command ");
//puts(str);
//puts(" is legal\n");
cmd_index = i;
break;
}
}
}
当时遇到的问题:
明明cmd是一个二维数组,为什么可以直接cmd[0]与一个数组进行比较呢?
后面经过自己测试过,看文章,得到原因我对二维数组认识不够,或者可以说是理解错误。
链接: https://blog.csdn.net/u013684730/article/details/46565577.
我是从这篇文章得到启发的。
其实二维数组不是像我们所想那样一个横坐标纵坐标那样排布的,它实际也像一维数组那样连续的。
这图就是从上述链接里面拉过来的。
二维数组就是数组里再分组了,等于大组里面有小组,而在内存上他们是连续的分布的,不是说cmd[0][1]就在第一行,cmd[1][1]就在第二行,不是的,其实是连起来的。
内存地址是连续的,一个内存地址里面就存一个值,这就是本质。
想明白了这些的话就好理解那段代码了。