PDA

Показать полную графическую версию : [решено] Работа со строками. Буфер содержит нуль-терминатор


Dr.Dark
28-08-2010, 16:07
Есть буфер (char[512]), в котором текст разделённый \0. Нужно разбить на строки буффер и записать в массив. Как это правилнее в C++ сделать?! Пока придумал вариант в цикле посимвольно просматривать буфер и писать символы в массив при встрече с '\0' создавать новый элемент в массиве. Но чот мне кажется что решение из арсенала индийских прогеров.... Есть еще strchr... Но она возвращает указатель на элемент... а без индекса не знаю как извлечь из строки подстроку... В общем помогите плз найти оптимальное решение...

ganselo
28-08-2010, 18:03
Первое, что пришло в голову:

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;

Admiral
29-08-2010, 02:18
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, можно обойтись от указания конкретного числа в цикле, однако на момент компиляции строка уже должна быть сформирована (прописана в коде).

Dr.Dark
29-08-2010, 03:43
ММММ Всем спасибо.... уже сделал так

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
29-08-2010, 10:53
ganselo твой метод не подходит тем что если буфер не полный то результирующий массив будет забиваться хламом в виде нолей или ещё чего.... можешь проверить... напиши
Код:
char buf[] = "aaaa\0bbbb\0cccc\0\0\0\0\0\0";
и увидишь что лишние нули будут в result... »
можно сделать проверку if(strlen(result) != 0) { }

Dr.Dark
29-08-2010, 16:13
ganselo, точно... ток в цикле

while(*lptr!=NULL)




© OSzone.net 2001-2012