C++利用socket傳輸大文件的實現(xiàn)代碼
server:
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <arpa/inet.h> #include <sys/socket.h> int fasong(void); int main(void){ FILE *f=fopen("/home/wzpc/c/1.mp4","r"); if(f==NULL){ puts("file error\n"); } long int n=0; while(!feof(f)){ //讀寫文件長度 fgetc(f); n++; } //------------------------------------------------- rewind(f); //文件指針返回文件起點 printf("%ld\n",n); int sp=fasong(); write(sp,&n,8); //傳送總字節(jié)數(shù) /* char c; fread(&c,1,1,f); for(int t=0;t<n;t++){ write(sp,&c,1); fread(&c,1,1,f); } //----------------------1.采用讀文件一字節(jié)傳送一字節(jié),速度非常慢 */ char *pt=calloc(n,sizeof(char)); fread(pt,n,1,f); int ee=0; for(int k=0;(k*1024)<n;k++){ if(k*1024+1024>n){ //判斷最后一次剩余字節(jié)數(shù) ee=n-k*1024; }else{ ee=1024; } send(sp,&pt[k*1024],ee,0); } //-----------------------2. 采用塊讀取,每次1024字節(jié),速度特快,因為socket每次傳輸有字節(jié)數(shù)限制,所有這理限定每次傳輸1024字節(jié) fclose(f); close(sp); free(pt); return 0; } int fasong(void){ //socket 連接 struct sockaddr_in serv,*p; memset(&serv,0,sizeof(serv)); p=&serv; p->sin_family=AF_INET; p->sin_addr.s_addr=htonl(INADDR_ANY); p->sin_port=htons(3000); int sk=socket(PF_INET,SOCK_STREAM,0); if(sk==-1){ puts("socket error\n"); } if(bind(sk,(struct sockaddr*)&serv,sizeof(serv))==-1){ puts("bind error\n"); } if(listen(sk,10)==-1){ puts("listen error\n"); } puts("listening port\n"); int ck=accept(sk,NULL,NULL); if(ck==-1){ puts("accept error\n"); } //------------------------------------------------------- return ck; }
client
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <arpa/inet.h> #include <sys/socket.h> int jisou(void); int main(void){ FILE *f1=fopen("/home/wzpc/c/2.mp4","w+"); if(f1==NULL){ puts("file error\n"); } long int len; int ss=jisou(); read(ss,&len,8); printf("%ld\n",len); /* char c; recv(ss,&c,1,0); for(int t=0;t<len;t++){ fwrite(&c,1,1,f1); recv(ss,&c,1,0); }*/ char *pt=calloc(len,sizeof(char)); int ee=0; for(int k=0;(k*1024)<len;k++){ if(k*1024+1024>len){ ee=len-k*1024; }else{ ee=1024; } recv(ss,&pt[1024*k],ee,0); } fwrite(pt,len,1,f1); close(ss); fclose(f1); free(pt); return 0; } int jisou(void){ int sock=socket(PF_INET,SOCK_STREAM,0); if(sock==-1) puts("socket() error"); struct sockaddr_in addr,*p; memset(&addr,0,sizeof(addr)); p=&addr; p->sin_family=AF_INET; p->sin_addr.s_addr=inet_addr("127.0.0.1"); p->sin_port=htons(3000); if(connect(sock,(struct sockaddr*)&addr,sizeof(addr))==-1) puts("connect() error"); return sock; }
c比java的socket傳輸快多了,肉眼可見的快。
特別注意,c中的數(shù)組長度是有限制的,如是大數(shù)組最好用動態(tài)分配內(nèi)存。如malloc,calloc, 還有c中socket一次傳輸?shù)淖止?jié)數(shù)也是有限制的。最好選1024 2048 ,不要太大。
到此這篇關(guān)于C++利用socket傳輸大文件的實現(xiàn)代碼的文章就介紹到這了,更多相關(guān)C++ socket傳輸大文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解如何將Spire.Doc for C++集成到C++程序中
Spire.Doc for C++是一個專業(yè)的Word庫,供開發(fā)人員在任何類型的C++應(yīng)用程序中閱讀、創(chuàng)建、編輯、比較和轉(zhuǎn)換 Word 文檔,本文演示了如何以兩種不同的方式將 Spire.Doc for C++ 集成到您的 C++ 應(yīng)用程序中,希望對大家有所幫助2023-05-05OpenCV實現(xiàn)低對比度圖像臟污區(qū)域檢測
本文主要介紹了OpenCV實現(xiàn)低對比度圖像臟污區(qū)域檢測,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09基于C++詳解數(shù)據(jù)結(jié)構(gòu)(附帶例題)
數(shù)據(jù)結(jié)構(gòu)作為每一個IT人不可回避的問題,本文基于C++編寫,下面這篇文章主要給大家介紹了關(guān)于數(shù)據(jù)結(jié)構(gòu)的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-06-06