Показать полную графическую версию : [решено] Работа со строками. Буфер содержит нуль-терминатор
Есть буфер (char[512]), в котором текст разделённый \0. Нужно разбить на строки буффер и записать в массив. Как это правилнее в C++ сделать?! Пока придумал вариант в цикле посимвольно просматривать буфер и писать символы в массив при встрече с '\0' создавать новый элемент в массиве. Но чот мне кажется что решение из арсенала индийских прогеров.... Есть еще strchr... Но она возвращает указатель на элемент... а без индекса не знаю как извлечь из строки подстроку... В общем помогите плз найти оптимальное решение...
Первое, что пришло в голову:
char buf[] = "aaaa\0bbbb\0cccc\0";
char result[1024];
char *ptr;
int offset, len;
offset = 0;
len = sizeof(buf);
while(len != offset)
{
ptr = strchr(buf + offset, 0);
strncpy(result, buf + offset, (int)(ptr - buf) + 1);
offset += (int)(ptr - (buf + offset)) + 1;
cout << result << endl;
}
getch();
return 0;
Dr.Dark, если наперёд известно количество подстрок (в примере ниже 23) то можно поступить следующим образом:
char Label [512] = "Раз\0Два\0Три\0....";
int SubStrLen = 0;
for (int i = 0; i < 23/*36*/; i++)
{
//Доступ к подстроке будет как &Label[SubStrLen]
SubStrLen += strlen(&Label[SubStrLen]) + 1;
}
Воспользовавшись предложением от ganselo, в части sizeof, можно обойтись от указания конкретного числа в цикле, однако на момент компиляции строка уже должна быть сформирована (прописана в коде).
ММММ Всем спасибо.... уже сделал так
char *sArr, INI[512], *ptr, *lptr;
//запись в буфер INI[512]
lptr=INI;
while(*lptr!=*(lptr-1))
{
ptr=strchr(lptr,'\0');
sArr=(char*) malloc(ptr-lptr+1);
strncpy(sArr, lptr, ptr-lptr+1);
lptr=ptr+1;
cout <<"sArr :" << sArr <<"\n\r";
cout <<"sArr :" << ptr-INI <<"\n\r";
system("pause");
}
ganselo твой метод не подходит тем что если буфер не полный то результирующий массив будет забиваться хламом в виде нолей или ещё чего.... можешь проверить... напиши
char buf[] = "aaaa\0bbbb\0cccc\0\0\0\0\0\0";
и увидишь что лишние нули будут в result...
Admiral Увы количество подстрок не известно...
Относительно функциональности правильно. А вот относительно идеологии C++? Подскажите всё ли правильно?!
И ещё подкиньте что нибудь толковое о динамических многомерных массивах в C++... Гугл уже юзаю....
ganselo твой метод не подходит тем что если буфер не полный то результирующий массив будет забиваться хламом в виде нолей или ещё чего.... можешь проверить... напиши
Код:
char buf[] = "aaaa\0bbbb\0cccc\0\0\0\0\0\0";
и увидишь что лишние нули будут в result... »
можно сделать проверку if(strlen(result) != 0) { }
ganselo, точно... ток в цикле
while(*lptr!=NULL)
© OSzone.net 2001-2012
vBulletin v3.6.4, Copyright ©2000-2025, Jelsoft Enterprises Ltd.