作者o07608 (無良記者)
看板C_and_CPP
標題[問題] read進陣列內數量遠小於實際讀到數量
時間Wed Dec 7 22:23:33 2016
開發平台(Platform): (Ex: Win10, Linux, ...)
Linux
編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出)
gcc
額外使用到的函數庫(Library Used): (Ex: OpenGL, ...)
無
問題(Question):
我的網路程式設計功課,需要寫一個UDP sender/reciever來傳資料
我想在sender open指定檔案後,一段段read進陣列裡傳到reciever,write進另一個檔案
但當我在read時,假設:
char buf[1024];
n = read(fd, buf, 1024); //fd指向已開啟檔案,大小5KB
把n和strlen(buf)印出來
n會是1024沒錯,但strlen(buf)卻遠小於1024
傳到receiver write進新開的檔案之後,新的檔案大小也會小很多
餵入的資料(Input):
用dd隨機產生的5kb檔案
預期的正確結果(Expected Output):
從sender端完美複製到reciever端
錯誤結果(Wrong Output):
read進陣列的每段資料都差很多
程式碼(Code):(請善用置底文網頁, 記得排版)
http://codepad.org/HGM1mFF7
如有需要完整的sender程式碼,我再另行附上
補充說明(Supplement):
網路程式設計作業老是會出現神奇的bug......
--
1F:→ gcobc12632 :一樓帥哥11/04 22:52
2F:推 maple0935 :二樓帥哥11/04 22:52
3F:推 howar31 :二樓帥哥11/04 22:52
4F:→ howar31 :..11/04 22:52
5F:→ maple0935 :五樓吃屎 11/04 22:53
6F:→ maple0935 :幹 可以不要當簽名檔嗎... 11/04 22:53
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 140.113.68.155
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1481120617.A.C9A.html
7F:→ stupid0319: 你一次傳送1024個字母嗎.............. 12/07 22:30
8F:→ o07608: 這樣是不好的習慣嗎O_O 12/07 22:31
9F:→ stupid0319: 用DD產生的5kb是什麼?全部都是DD DD DD DD這樣? 12/07 22:33
> dd if=/dev/urandom of=test5kb bs=5KB count=1
10F:→ o07608: 怎麼變藍色的o.0 12/07 22:37
※ 編輯: o07608 (140.113.68.155), 12/07/2016 22:45:21
11F:→ x000032001: 如果你的檔案有一個byte是0x00 就會視為字串結束 12/07 22:46
12F:→ x000032001: 所以你要用n判斷大小 而不是strlen 12/07 22:47
13F:→ x000032001: read/write直接拿來strxxx 就是無止盡的踩地雷遊戲 12/07 22:47
14F:→ o07608: 但實際上每段傳到receiver的東西大小也小於1024 12/07 22:51
15F:→ o07608: 還是說我不應該用char陣列傳東西?那應該要用什麼型態? 12/07 22:52
16F:推 LPH66: 不是不該用 char 陣列, 而是你要知道 char 陣列不等於字串 12/07 22:59
17F:→ LPH66: strxxx 系列函數只能用在是字串的 char 陣列上 12/07 23:00
18F:→ LPH66: 你的資料是從 /dev/urandom 裡複製來的所以是二進位資料 12/07 23:00
19F:→ LPH66: 二進位資料不是字串所以不能用 strxxx 系列函數 12/07 23:01
20F:→ LPH66: 所以只有 read 的回傳值 n 可信, 你要 write 也要用 n 12/07 23:01
21F:推 LPH66: 話說回來, 既然是在練習 udp 傳輸, 一次就是固定一個大小 12/07 23:04
22F:→ LPH66: 所以不管傳什麼資料都不是 strxxx 出場的時候 12/07 23:04
23F:→ LPH66: 這也就是為什麼 read 這種 general 讀取的程式會回傳讀多少 12/07 23:05
24F:→ o07608: 嗯我懂了,write最後參數我的確不是用n判斷 12/07 23:05
25F:→ o07608: 改一下試試看 12/07 23:05
26F:→ o07608: 問題找到了,果然是write參數用錯,感謝大家 12/07 23:12