android 什么时候使用socket,Android NDK中使用socket

本文详细介绍了在Android NDK环境下使用UDP socket进行通信的三个关键步骤:创建并绑定socket、发送数据以及非阻塞式接收数据。通过示例代码展示了如何设置发送端和接收端的IP及端口,以及如何利用`sendto`和`recvfrom`函数进行数据传输,并在接收端使用`select`函数实现非阻塞接收。
摘要由CSDN通过智能技术生成

Android

NDK中使用socket的整个过程分为以下几部分:

第一部分: 创建socket并绑定IP和端口

#include

#include

#include

#define MAX_DATA_BUF_LEN 10240

intsd = INVALID_SOCKET;

sockaddr_in addr_org; // 发送端地址

sd = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP); // 创建socket

addr_org.sin_family = AF_INET;

addr_org.sin_addr.s_addr = inet_addr("192.128.0.1");// 发送端IP

addr_org.sin_port = htons(8080); // 发送端端口

bind(sd, (structsockaddr *)&(addr_org),sizeof(structsockaddr_in));// 绑定IP和端口

#include

#include

#include

#define MAX_DATA_BUF_LEN 10240

int sd = INVALID_SOCKET;

sockaddr_in addr_org; // 发送端地址

sd = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP); // 创建socket

addr_org.sin_family = AF_INET;

addr_org.sin_addr.s_addr = inet_addr("192.128.0.1"); // 发送端IP

addr_org.sin_port = htons(8080); // 发送端端口

bind(sd, (struct sockaddr *)&(addr_org), sizeof(struct sockaddr_in)); // 绑定IP和端口

第二部分:

发送数据

sockaddr_in addr_dst;// 接收端地址

addr_dst.sin_family = AF_INET;

addr_dst.sin_addr.s_addr = inet_addr("192.128.0.2");// 接收端IP

addr_dst.sin_port = htons(8080); // 接收端端口

... // 生成要发送的数据到SendDataBuff, 长度为ulLen

sendto(sd, SendDataBuff, ulLen, 0, (structsockaddr *)&(addr_dst),sizeof(sockaddr_in));// 发送SendDataBuff中的数据

sockaddr_in addr_dst; // 接收端地址

addr_dst.sin_family = AF_INET;

addr_dst.sin_addr.s_addr = inet_addr("192.128.0.2"); // 接收端IP

addr_dst.sin_port = htons(8080); // 接收端端口

... // 生成要发送的数据到SendDataBuff, 长度为ulLen

sendto(sd, SendDataBuff, ulLen, 0, (struct sockaddr *)&(addr_dst), sizeof(sockaddr_in)); // 发送SendDataBuff中的数据

第三部分:

在线程中接收数据(非阻塞式)

void*SocketReceiveThread(void*pParam)

{

fd_set fdset;

structtimeval delayval;

unsigned longlRetVal;

delayval.tv_sec = 0;

delayval.tv_usec = 5000;

while(!end_flag)

{

FD_ZERO(&fdset);

FD_SET(sd, &fdset);

lRetVal = select(sd+1, &fdset, NULL, NULL, &delayval); // 尤其要注意第一个参数

if(0 == lRetVal)

{

continue;

}

elseif(SOCKET_ERROR == lRetVal)

{

break;

}

elseif(FD_ISSET(sd, &fdset) != 0)

{

charRecvDataBuff[MAX_DATA_BUF_LEN];// 接收数据buffer

unsigned longulLen = recvfrom(sd, RecvDataBuff, MAX_DATA_BUF_LEN, 0, NULL, NULL);

... // 处理接收到的数据

}

}

}

void *SocketReceiveThread(void *pParam)

{

fd_set fdset;

struct timeval delayval;

unsigned long lRetVal;

delayval.tv_sec = 0;

delayval.tv_usec = 5000;

while (!end_flag)

{

FD_ZERO(&fdset);

FD_SET(sd, &fdset);

lRetVal = select(sd+1, &fdset, NULL, NULL, &delayval); // 尤其要注意第一个参数

if (0 == lRetVal)

{

continue;

}

else if (SOCKET_ERROR == lRetVal)

{

break;

}

else if (FD_ISSET(sd, &fdset) != 0)

{

char RecvDataBuff[MAX_DATA_BUF_LEN]; // 接收数据buffer

unsigned long ulLen = recvfrom(sd, RecvDataBuff, MAX_DATA_BUF_LEN, 0, NULL, NULL);

... // 处理接收到的数据

}

}

}

第四部分:

关闭socket

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值