The OpenNET Project / Index page

[ новости /+++ | форум | wiki | теги | ]

форумы  помощь  поиск  регистрация  майллист  вход/выход  слежка  RSS
"Странная ситуация - из за чего такое может быть?"
Вариант для распечатки  
Пред. тема | След. тема 
Форумы Программирование под UNIX (Public)
Изначальное сообщение [ Отслеживать ]

"Странная ситуация - из за чего такое может быть?"  
Сообщение от Towellie (ok) on 24-Янв-09, 11:00 
Это по сути та же проблема - которую я описывал на этом форуме не так давно собственно большая ее часть была результатом моего невежества(Прошу меня простить) - и я решил создать новую тему, чтобы не пудрить людям мозги, которые читают темы с самого начала(Дай господь здоровья этим людям).
Краткая аннотация - создается BIO соединение с шифрованием. Если отослать привет с одной стороны то привет - поймается с другой, и наоборот.(То есть с только запись с одной стороны и только чтение с другой и соответственно наоборот) - это я к тому что в этот дескриптор можно писать, и с него читать - проверено.


//_________________________Server__________________________________________
strcpy(tmpbuf,"Hello client");
len=BIO_write(sbio,tmpbuf,sizeof(tmpbuf));
printf("[%d] bytes was writed\n", len); // Write прорабатывает
/*<----------Когда этот код не заремарен - на другом конце дело не доходит до printf
for(;;)
{
    len=BIO_read(sbio,tmpbuf,sizeof(tmpbuf));
    printf("Cycle is rock! --- [%d]", len);
    if(len > 0)break;
}
printf("[%s]----[%d]\n",tmpbuf,strlen(tmpbuf));

if(strcmp(tmpbuf,"Hello server")==0)
{
    printf("Hello server is recived - let's rock!!!!! \n");
}
*/ <----------Когда этот код не заремарен - на другом конце дело не доходит до printf


//___________________________________________________________________

//________________________Client___________________________________________

for(;;)
{
    len=BIO_read(sbio,tmpbuf,sizeof(tmpbuf));
    printf("Cycle is rock! --- [%d]", len);
    if(len > 0)break;
}
printf("[%s]----[%d]\n",tmpbuf,strlen(tmpbuf)); <---- Этот printf
fflush(stdout);
sleep(5); <-- Когда код заремарен строка появляется до sleep
if(strcmp(tmpbuf,"Hello client")==0)
{
    printf("Hello client is recived - sending hello server\n");
    strcpy(tmpbuf,"Hello server");
    len=BIO_write(sbio,tmpbuf,sizeof(tmpbuf));
    printf("[%d] bytes was writed\n", len);
}

//___________________________________________________________________
Подробно --- >
Если код чтения заремарен результат работы программ
$ ./recv
[1024] bytes was writed
$
$ ./send
Cycle is rock! --- [1024][Hello client]----[12]
Hello client is recived - sending hello server
// Прорабатывает sleep
[1024] bytes was writed
$
// - Если не заремарен
$ ./recv
[1024] bytes was writed
$
$ ./send
<--- Ждет BIO_read чего она ждет?  В дескриптор записывается уже к этому времени именно столько сколько она должна считать.

Высказать мнение | Ответить | Правка | Cообщить модератору

 Оглавление

Сообщения по теме [Сортировка по времени | RSS]


1. "Странная ситуация - из за чего такое может быть?"  
Сообщение от Michelnok (ok) on 24-Янв-09, 13:33 
>и я решил создать новую тему, чтобы не пудрить людям мозги

А не мог бы ты еще и упростить свой код, поубирав все ненужное, и разделив по вариантам? Очень трудно анализировать такое сумбурное изложение. То закомментировано, то нет, то один printf, то какой-то другой, и все это в одной куче.

Высказать мнение | Ответить | Правка | Наверх | Cообщить модератору

2. "Странная ситуация - из за чего такое может быть?"  
Сообщение от Towellie (ok) on 24-Янв-09, 14:14 
В общем если так
//_________________________Server__________________________________________
strcpy(tmpbuf,"Hello");
len=BIO_write(sbio,tmpbuf,sizeof(tmpbuf));
//_________________________Server__________________________________________
А на клиенте
//__________________________Client_________________________________________
for(;;)
{
    len=BIO_read(sbio,tmpbuf,sizeof(tmpbuf));
}
printf("[%s]----[%d]\n",tmpbuf,strlen(tmpbuf));
fflush(stdout);
sleep(5);
len=BIO_write(sbio,tmpbuf,sizeof(tmpbuf));
//___________________________________________________________________
Слип для того, чтобы увидеть не затупляет ли read и не отсылает данные по окончанию соединения(Сразу все отправляется)
а так
//_________________________Server__________________________________________
strcpy(tmpbuf,"Hello");
len=BIO_write(sbio,tmpbuf,sizeof(tmpbuf));
for(;;)
{
    len=BIO_read(sbio,tmpbuf,sizeof(tmpbuf));
}
//_________________________Server__________________________________________
А на клиенте
//__________________________Client_________________________________________
for(;;)
{
    len=BIO_read(sbio,tmpbuf,sizeof(tmpbuf));
}
printf("[%s]----[%d]\n",tmpbuf,strlen(tmpbuf));
fflush(stdout);
sleep(5);
len=BIO_write(sbio,tmpbuf,sizeof(tmpbuf));
//___________________________________________________________________
Затупляет read который в первом случае работал.
fflush чтобы printf полюбому показался
Высказать мнение | Ответить | Правка | Наверх | Cообщить модератору

3. "Странная ситуация - из за чего такое может быть?"  
Сообщение от Towellie (ok) on 24-Янв-09, 16:22 
Все - оказалось на стороне сервера подрубался в цепочку sbio буферный bbio который там не нужен

Все))) Делаю дальше - бодрячком пацанчики)))

Высказать мнение | Ответить | Правка | Наверх | Cообщить модератору

Архив | Удалить

Индекс форумов | Темы | Пред. тема | След. тема
Оцените тред (1=ужас, 5=супер)? [ 1 | 2 | 3 | 4 | 5 ] [Рекомендовать для помещения в FAQ]




Спонсоры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2022 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру