C++利用socket傳輸大文件的實(shí)現(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); //文件指針返回文件起點(diǎn)
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é),速度特快,因?yàn)閟ocket每次傳輸有字節(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ù)組最好用動(dòng)態(tài)分配內(nèi)存。如malloc,calloc, 還有c中socket一次傳輸?shù)淖止?jié)數(shù)也是有限制的。最好選1024 2048 ,不要太大。
到此這篇關(guān)于C++利用socket傳輸大文件的實(shí)現(xiàn)代碼的文章就介紹到這了,更多相關(guān)C++ socket傳輸大文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解如何將Spire.Doc for C++集成到C++程序中
Spire.Doc for C++是一個(gè)專業(yè)的Word庫,供開發(fā)人員在任何類型的C++應(yīng)用程序中閱讀、創(chuàng)建、編輯、比較和轉(zhuǎn)換 Word 文檔,本文演示了如何以兩種不同的方式將 Spire.Doc for C++ 集成到您的 C++ 應(yīng)用程序中,希望對(duì)大家有所幫助2023-05-05
C++中運(yùn)算符重載的規(guī)則語法實(shí)例
今天小編就為大家分享一篇關(guān)于C++中運(yùn)算符重載的規(guī)則語法實(shí)例,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-12-12
OpenCV實(shí)現(xiàn)低對(duì)比度圖像臟污區(qū)域檢測
本文主要介紹了OpenCV實(shí)現(xiàn)低對(duì)比度圖像臟污區(qū)域檢測,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
基于C++詳解數(shù)據(jù)結(jié)構(gòu)(附帶例題)
數(shù)據(jù)結(jié)構(gòu)作為每一個(gè)IT人不可回避的問題,本文基于C++編寫,下面這篇文章主要給大家介紹了關(guān)于數(shù)據(jù)結(jié)構(gòu)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
C語言實(shí)現(xiàn)猜數(shù)字小游戲的示例代碼
猜數(shù)字小游戲是我們小時(shí)候喜歡我們一個(gè)經(jīng)典小游戲。本文將用C語言實(shí)現(xiàn)這一經(jīng)典游戲,文中的示例代碼講解詳細(xì),感興趣的可以了解一下2022-08-08

