正确使用Malloc和c++指针



抱歉,如果这个问题是试图采取简单的方法,但我真的认为我只是需要一些澄清。我正在尝试使用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后,需要在调用方释放它

相关内容

  • 没有找到相关文章

最新更新