over the socket? Is there a way to have a dynamic buffer? What does one do when one does not know how much information is coming?
Answer Posted / chaitanya
When the size of the incoming data is unknown, you can either make the size of the buffer as big as the largest possible (or likely) buffer, or you can re-size the buffer on the fly during your read. When you malloc() a large buffer, most (if not all) varients of unix will only allocate address space, but not physical pages of ram. As more and more of the buffer is used, the kernel allocates physical memory. This means that malloc'ing a large buffer will not waste resources unless that memory is used, and so it is perfectly acceptable to ask for a meg of ram when you expect only a few K.
On the other hand, a more elegant solution that does not depend on the inner workings of the kernel is to use realloc() to expand the buffer as required in say 4K chunks (since 4K is the size of a page of ram on most systems). I may add something like this to sockhelp.c in the example code one day.
| Is This Answer Correct ? | 0 Yes | 0 No |
Post New Answer View All Answers
How can I write a multi-homed server?
What is a sae socket?
What is a socket address?
What are the pros/cons of select(), non-blocking I/O and SIGIO?
How do I convert a string into an internet address?
What is difference between socket () and serversocket () class?
Whats the difference between select() and poll()?
What's better 6pt or 12pt sockets?
What is active unix domain sockets?
What is a socket set used for?
What is difference between socket and websocket?
system choose one for me on the connect() call? Should I bind() a port number in my client program, or let the?
Why do I get EPROTO from read()?
How can I set the timeout for the connect() system call?
Is socket a hardware or software?