日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

三、在应用中升级----网络编程部分

發布時間:2024/9/3 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 三、在应用中升级----网络编程部分 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">本次記錄網絡編程。</span>

使用的通信協議為TCP,方式為epoll方式。對于socket的基本知識不再記錄,這里直接給出說明代碼。

在進行網絡編程時遇到一個問題,還不知道原因,函數代碼如下:

int read_pack(int sockfd,void * buf,int len) {if(buf==NULL||len<=0)return 0;int nleft;int nread, nwrite;char *ptr;long int offset = 0;ptr=(char *)buf;nleft = len;printf("nleft is :%d\n", nleft);while(nleft > 0){printf("nleft is :%d\n", nleft);if((nread = recv(sockfd, &ptr[offset], nleft, 0)) < 0)//read返回錯誤{printf("Read ERROR\n");if(errno == EINTR)//是由于信號中斷造成的讀失敗,則繼續讀nread = 0;else//否則是真正的讀錯誤,返回失敗的標志return -1;}else if(nread == 0)//數據讀取完畢了,到達了文件的末尾break; nleft -= nread;//剩余要讀取的offset += nread;//偏移緩沖區位置printf("nread is :%d\n", nread);/*if((nwrite = send(sockfd, "Next", 4, 0)) < 0){printf("ERROR\n");break; }*/ }printf("nleft is :%d\n", nleft);printf("Read over\n");return (len-nleft); }問題就是上面的recv讀函數,假如數據已經讀完了,但是還未判斷nread的值所以還不能跳出循環,于是又讀了一次,因為已經讀完數據,所以這次讀數據返回的nread值應該是0,可是實際上是,讀的時候死在那里了。

多方面思考我想是不是recv函數在等待服務端發送的數據,阻塞在那里了。不太明白,還需要跟蹤一下源碼。


但是如果在服務端指定了文件的大小,而且客戶端也已經知道要接收的文件大小的話,就沒有問題了。

因此我想服務端在發送具體文件數據前,先通知客戶端,下面將要發送文件的大小信息,于是定義一個下面的結構體:

typedef struct{char file_name;//文件名字long int file_size;//文件的大小long int complete_block;//記錄file_name該文件已經傳送完成的數據 }file_info;用上面這個結構體來標示文件的相關信息。

測試調試一下。








總結

以上是生活随笔為你收集整理的三、在应用中升级----网络编程部分的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。