三、在应用中升级----网络编程部分
生活随笔
收集整理的這篇文章主要介紹了
三、在应用中升级----网络编程部分
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">本次記錄網(wǎng)絡(luò)編程。</span>
使用的通信協(xié)議為TCP,方式為epoll方式。對于socket的基本知識不再記錄,這里直接給出說明代碼。
在進(jìn)行網(wǎng)絡(luò)編程時遇到一個問題,還不知道原因,函數(shù)代碼如下:
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)//是由于信號中斷造成的讀失敗,則繼續(xù)讀nread = 0;else//否則是真正的讀錯誤,返回失敗的標(biāo)志return -1;}else if(nread == 0)//數(shù)據(jù)讀取完畢了,到達(dá)了文件的末尾break; nleft -= nread;//剩余要讀取的offset += nread;//偏移緩沖區(qū)位置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讀函數(shù),假如數(shù)據(jù)已經(jīng)讀完了,但是還未判斷nread的值所以還不能跳出循環(huán),于是又讀了一次,因為已經(jīng)讀完數(shù)據(jù),所以這次讀數(shù)據(jù)返回的nread值應(yīng)該是0,可是實際上是,讀的時候死在那里了。多方面思考我想是不是recv函數(shù)在等待服務(wù)端發(fā)送的數(shù)據(jù),阻塞在那里了。不太明白,還需要跟蹤一下源碼。
但是如果在服務(wù)端指定了文件的大小,而且客戶端也已經(jīng)知道要接收的文件大小的話,就沒有問題了。
因此我想服務(wù)端在發(fā)送具體文件數(shù)據(jù)前,先通知客戶端,下面將要發(fā)送文件的大小信息,于是定義一個下面的結(jié)構(gòu)體:
typedef struct{char file_name;//文件名字long int file_size;//文件的大小long int complete_block;//記錄file_name該文件已經(jīng)傳送完成的數(shù)據(jù) }file_info;用上面這個結(jié)構(gòu)體來標(biāo)示文件的相關(guān)信息。測試調(diào)試一下。
總結(jié)
以上是生活随笔為你收集整理的三、在应用中升级----网络编程部分的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 二、在应用中升级----网络部分
- 下一篇: WordPress打开速度很慢的解决方法