Компилятор уже сообщил, что эта функция
//Read-in string
char *readIn(void)
{
char param[101];
fgets(param, 101, stdin);
return param;
}
имеет неопределенное поведение, поскольку возвращает указатель на локальный массив param
, который не будет активен после выхода из функции.
In в этой функции
char *parseString(char* cmd)
{
char* temp = strtok(cmd, " ");
if (cmd == NULL)
{
return temp;
}
else
{
int i = 0;
char *tokens[3];
while (temp != NULL)
{
tokens[i++] = temp;
temp = strtok(NULL, " ");
}
for (i = 0; i < 3; i++)
{
printf("%s\n", tokens[i]);
}
return tokens;
}
}
существует та же проблема (если не учитывать неправильную реализацию) и, кроме того, тип возвращаемого выражения
return tokens;
не соответствует типу возвращаемого значения функции, потому что выражение в операторе возврата имеет тип char **
, а тип возвращаемого значения функции - char *
.
Я уверен, что наиболее трудным для вас является написание функции, которая разбивает строка в токены.
Это может выглядеть следующим образом, как показано в демонстрационной программе ниже. Функция динамически распределяет память для массива указателей на токены. Если распределение завершается неудачно, функция возвращает NULL. В противном случае функция возвращает указатель на первый элемент динамически размещенного массива указателей. Последний элемент массива содержит NULL. Этот элемент можно использовать для определения количества фактических указателей на токены в массиве.
Вот и вы.
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
char ** parseString( char *cmd )
{
char **tokens = malloc( sizeof( char * ) );
*tokens = NULL;
size_t n = 1;
const char *delim = " \t";
char *p = strtok( cmd, delim );
int success = p != NULL;
while ( success )
{
char **tmp = realloc( tokens, ( n + 1 ) * sizeof( char * ) );
if ( tmp == NULL )
{
free( tokens );
tokens = NULL;
success = 0;
}
else
{
tokens = tmp;
tokens[n - 1] = p;
tokens[n] = NULL;
++n;
p = strtok( NULL, delim );
success = p != NULL;
}
}
return tokens;
}
int main(void)
{
char cmd[] = "Many various and unique commands";
char **tokens = parseString( cmd );
if ( tokens != NULL )
{
for ( char **p = tokens; *p != NULL; ++p )
{
puts( *p );
}
}
free( tokens );
return 0;
}
Вывод программы:
Many
various
and
unique
commands