Компьютерный форум OSzone.net  

Компьютерный форум OSzone.net (http://forum.oszone.net/index.php)
-   Программирование и базы данных (http://forum.oszone.net/forumdisplay.php?f=21)
-   -   [решено] Работа со строками. Буфер содержит нуль-терминатор (http://forum.oszone.net/showthread.php?t=184082)

Dr.Dark 28-08-2010 16:07 1483525

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

ganselo 28-08-2010 18:03 1483584

Первое, что пришло в голову:
Код:

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 1483903

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 1483929

ММММ Всем спасибо.... уже сделал так
Код:

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 1483992

Цитата:

Цитата Dr.Dark
ganselo твой метод не подходит тем что если буфер не полный то результирующий массив будет забиваться хламом в виде нолей или ещё чего.... можешь проверить... напиши
Код:
char buf[] = "aaaa\0bbbb\0cccc\0\0\0\0\0\0";
и увидишь что лишние нули будут в result... »

можно сделать проверку if(strlen(result) != 0) { }

Dr.Dark 29-08-2010 16:13 1484232

ganselo, точно... ток в цикле
Код:

while(*lptr!=NULL)


Время: 04:32.

Время: 04:32.
© OSzone.net 2001-