Johannes schrieb:
> Ich habe festgestellt, dass man normal lesen kann, solange 256 Byte
> verfügbar sind. Sind jedoch weniger als 256 Byte verfügbar, so blockiert
> fread(). Eigentlich sollte die Funktion doch zurückkehren mit n<256 oder
> habe ich da was falsch verstanden?
Sollte sie, wenn weniger als 256 Zeichen vorhanden sind, ja.
In deinem Fall sind aber mehr als 256 Zeichen vorhanden, der Server hat
sie nur noch nicht gesendet.
=> fread prüft auf EOF, stellt fest: "Kein EOF, also müssen noch mehr
Daten da sein", startet einen neuen read und wartet darauf, dass der
Server den Buffer wieder befüllt.
Fazit: fread & co sind für TCP nicht wirklich geeignet, wenn man
blockieren vermeiden möchte.