Токенизация ввода от getline
Я пытаюсь использовать getline(), чтобы взять ввод с клавиатуры, сохранить его в строку, токенизировать, а затем распечатать токены. Когда я запускаю это, я получаю ошибку Segmentation Fault на последней итерации (итерация, которая обрабатывает последний токен из входных данных).
#define _POSIX_C_SOURCE 200809L
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
////////////////////////
// Main Method //
////////////////////////
void main() {
system("clear");
int ShInUse = 1; // Represents if shell is in use
char curpath[1024]; // holds current path to print with prompt
char *UserCommand = NULL;
size_t combytes = 100;
UserCommand = (char *) malloc(combytes);
char *tok;
// Main loop that shell uses //
while (ShInUse == 1) {
getcwd(curpath, sizeof(curpath)); // Store initial working dir
printf("gash:%s>", curpath); // print prompt
getline(&UserCommand, &combytes, stdin);
tok = strtok(UserCommand, " \n"); // Tokenize input
if (tok == NULL ) {
printf("Enter a command.\n");
} else {
// Exit command //
if (strcmp(tok, "exit") == 0) {
ShInUse = 0;
} else {
while (tok != NULL ) {
printf("You entered a command.\n");
printf("tok: %s\n", tok);
tok = strtok(NULL, " \n");
}
}
}
}
free(UserCommand);
}
Любые идеи относительно того, что может быть причиной этого? Отладка не вариант для меня на данный момент.
2 ответа
Я проверил ваш код с этим:
#define _POSIX_C_SOURCE 200809L
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
char *UserCommand = NULL;
size_t combytes = 100;
UserCommand = (char *) malloc(combytes);
char *tok;
while(getline(&UserCommand, &combytes, stdin) != EOF)
{
tok = strtok(UserCommand, " \n"); // Tokenize input
if (tok != NULL) {
while(tok != NULL) {
printf("%s\n", tok);
tok = strtok(NULL, " \n");
}
}
}
return 0;
}
и он отлично работает для всех тестов, которые я провел, включая передачу исходного файла в качестве входных данных, написание довольно длинных строк и т. д. и т. д.
Поэтому я пришел к выводу, что у вас, вероятно, есть что-то еще, что в вашем коде вызывает ошибки.
Тоже не ответ, просто еще один вариант стиля программирования:
Всякий раз, когда у меня есть токенизирующий цикл, подобный вашему, я предпочитаю создавать их так
for( tok = strtok( UserCommand, " \n" );
tok != NULL;
tok = strtok( NULL, " \n" ) )
{
printf( "%s\n", tok );
}
Это держит оба strtok()
звонки близко друг к другу и требует написания NULL
проверить только один раз. Твой путь в порядке, это просто еще один вариант. Удачи!