抱歉,如果这个问题是试图采取简单的方法,但我真的认为我只是需要一些澄清。我正在尝试使用malloc和free。我以为我理解了它们,但是我要做的作业本身有点令人困惑。
tklist数组中的每个元素应该指向一个单独的标记(在引号之间或用空格分隔的一组字符)。所以,我需要分配空间,然后释放它。
我不明白的是当内存应该被释放。我试着在各种地方释放它,但都不起作用。我想我只是不完全理解一些东西,我在过去的几天里广泛地查阅了malloc和free,试图弄清楚它。(也许我应该释放我的主?也许我的强度是错的?)任何帮助都将非常感激!
下面是函数,它接受一个字符数组和一个char指针数组作为参数,并返回在第一个参数中找到的令牌数作为答案。该函数应该解析令牌并依次将每个令牌添加到tklist数组中。
int parseCommandLine(char cline[], char *tklist[]){
int i;
int length;
int count = 0; //counts number of tokens
int toklength = 0; //counts the length of each token
length = strlen(cline);
for (i=0; i < length; i++) { //go to first character of each token
if (((cline[i] != ' ' && cline[i-1]==' ') || i == 0)&& cline[i]!= '"') {
while ((cline[i]!=' ')&& (cline[i] != ' ') && (cline[i] != 'r')){
toklength++;
i++;
}
count ++;
//---------------
//tklist[count] = (char *) malloc( toklength +1);
//strncpy(tklist[count], &cline[i], toklength);
// free( (void *)tklist[count] );
//--------------
toklength = 0;
}
//--------------
//free( (void *)tklist[count] );
//--------------
if (cline[i] == '"') {
do {
toklength++;
i++;
if (cline[i] == ' ') {
toklength--;
}
} while (cline[i]!='"');
count++;
//--------------
//tklist[count] = (char *) malloc( toklength +1);
//strncpy(tklist[count], &cline[i], toklength);
//free( (void *)tklist[count] );
//--------------
toklength = 0;
}
//--------------
//free( (void *)tklist[count] );
//--------------
}
cout << count;
return count;
}
在使用完tklist后,需要在调用方释放它