Socket客戶端的建立與連接

#import <arpa/inet.h>

#import <netdb.h>

#include <sys/ioctl.h>

@interfaceXCClient() {

intsock_fd;

structhostent*host;

structsockaddr_inserver_addr;

intloopcount;

}

staticintPortNum_Car;//端口號(hào)

constchar*IP_Car;//IP地址

設(shè)置端口號(hào)和服務(wù)器地址

PortNum_Car=16868;

NSString*ipString =@"192.168.43.1";//這個(gè)ip地址要從服務(wù)端要

IP_Car= ipString.UTF8String;

//下面創(chuàng)建并連接端口

if((host=gethostbyname(IP_Car)) ==NULL) {

NSLog(@"host Error");

}

if((sock_fd=socket(AF_INET,SOCK_STREAM,0)) == -1) {

NSLog(@"create Socket Error");

}

//設(shè)置調(diào)用closesocket()后,仍可繼續(xù)重用該socket。調(diào)用closesocket()一般不會(huì)立即關(guān)閉socket,而經(jīng)歷TIME_WAIT的過(guò)程

BOOLnREUSEADDR =true;

setsockopt(sock_fd,SOL_SOCKET,SO_REUSEADDR, (constchar*)&nREUSEADDR,sizeof(int));

server_addr.sin_family=AF_INET;

server_addr.sin_port=htons(PortNum_Car);

server_addr.sin_addr= *((structin_addr*)host->h_addr);

bzero(&(server_addr.sin_zero),8);

//異常

sigset_tset;

sigemptyset(&set);

sigaddset(&set,SIGPIPE);

sigprocmask(SIG_BLOCK, &set,NULL);

if(connect(sock_fd, (structsockaddr*)&server_addr,sizeof(structsockaddr)) == -1) {

//失敗處理

}else {

//連接成功,開(kāi)始通訊

}

//warning 當(dāng)然了在connect的時(shí)候如果遇到服務(wù)器沒(méi)開(kāi)端口,由于socket是阻塞模式,它就會(huì)connect到超時(shí),才知道失敗,所以在connect的時(shí)候,我們把它設(shè)為非阻塞的。系統(tǒng)就會(huì)很快就告訴我們了。上代碼;

在connect之前,先把socket設(shè)為非阻塞的

//設(shè)置為非阻塞,能改connect超時(shí)時(shí)間

structtimevaltimeout;

unsignedlongul =1;//1是非阻塞

fd_setwriteset;

intret;

ioctl(sock_fd,FIONBIO, &ul);

//嘗試連接

if(connect(sock_fd, (structsockaddr*)&server_addr,sizeof(structsockaddr)) == -1) {

timeout.tv_sec=5;

timeout.tv_usec=0;

FD_ZERO(&writeset);

FD_SET(sock_fd, &writeset);

ret =select(sock_fd+1,NULL, &writeset,NULL, &timeout);

if(ret ==0)//返回0,代表在描述詞狀態(tài)改變已超過(guò)timeout時(shí)間

{

超時(shí)處理

return;

}elseif(ret==-1){

錯(cuò)誤處理

}else{

perror("connect error");close(sock_fd);

return;

}

}else{

interror;

socklen_tlen =sizeof(unsignedint);

getsockopt(sock_fd,SOL_SOCKET,SO_ERROR, &error, &len);//檢查一下是否真的連成功

if(error ==0)

{

//true

}

else

{

perror("connect error");close(sock_fd);

return;

}

成功就再把socket設(shè)成阻塞的,開(kāi)始后面的邏輯

ul =0;

ioctl(sock_fd,FIONBIO, &ul);//重新將socket設(shè)置成阻塞模式

[self connectSuccess_AndOpenthread];

}

}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容