From: "Nick S. Grechukh" <ngrechukh@ua.fm> To: community@altlinux.ru Subject: Re: [Comm] read from socket Date: Fri, 11 Feb 2005 12:43:00 +0200 Message-ID: <200502111243.06160.ngrechukh@ua.fm> (raw) In-Reply-To: <420C8A56.1050400@unisoft.com.ua> [-- Attachment #1: Type: text/plain, Size: 1079 bytes --] On Friday 11 February 2005 12:35, Eugene Ostapets wrote: > Nick S. Grechukh wrote: > | задача читать из сокета (PF_INET SOCK_STREAM) данные в количестве > 'несколько' > | байт (команды вида 'stop','pause','skip','getinfo', возможно направляя > ответ > | до 100 байт. > | есть ли вероятность что команда будет прочитана не полностью (не успел > | ;-) т.е., клиент делает write("getinfo\n"), а я при однократном чтении > | ловлю 'geti' (при повторном чтении - остальное) > | я так понимаю, это зависит от размера посылаемого пакета, и при > десятках байт > | (которые влезают в один физический пакет) такое исключено? > Нет, не исключено! Протокол tcp гарантирует что пакет будет доставлено, ага. но 100 байт - по любому один пакет. меня пугает только не-атомарность, которая имхо может быть только в момент перемещения пакета с сетевого уровня в сам сокет. > если это возможно. udp гарантирует только отправку пакета. Больше никто > и ничего не гарантирует. а recv с MSG_WAITALL не поможет? правда, тогда придется от текстовых команд уйти на бинарные ради фиксированной длины. [-- Attachment #2: Type: application/pgp-signature, Size: 190 bytes --]
next prev parent reply other threads:[~2005-02-11 10:43 UTC|newest] Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top 2005-02-11 9:59 Nick S. Grechukh 2005-02-11 10:35 ` Eugene Ostapets 2005-02-11 10:43 ` Nick S. Grechukh [this message] 2005-02-11 12:41 ` Nick S. Grechukh 2005-02-11 10:48 ` Nick S. Grechukh
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=200502111243.06160.ngrechukh@ua.fm \ --to=ngrechukh@ua.fm \ --cc=community@altlinux.ru \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
ALT Linux Community general discussions This inbox may be cloned and mirrored by anyone: git clone --mirror http://lore.altlinux.org/community/0 community/git/0.git # If you have public-inbox 1.1+ installed, you may # initialize and index your mirror using the following commands: public-inbox-init -V2 community community/ http://lore.altlinux.org/community \ mandrake-russian@linuxteam.iplabs.ru community@lists.altlinux.org community@lists.altlinux.ru community@lists.altlinux.com public-inbox-index community Example config snippet for mirrors. Newsgroup available over NNTP: nntp://lore.altlinux.org/org.altlinux.lists.community AGPL code for this site: git clone https://public-inbox.org/public-inbox.git