Android NDK中使用socket

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

第一部分: 创建socket并绑定IP和端口
  1. #include <sys/select.h>   
  2. #include <sys/socket.h>   
  3. #include <arpa/inet.h>   
  4.   
  5. #define MAX_DATA_BUF_LEN 10240   
  6.   
  7. int sd = INVALID_SOCKET;  
  8. sockaddr_in addr_org; // 发送端地址   
  9.   
  10. sd = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP); // 创建socket   
  11.   
  12. addr_org.sin_family = AF_INET;  
  13. addr_org.sin_addr.s_addr = inet_addr("192.128.0.1"); // 发送端IP   
  14. addr_org.sin_port = htons(8080); // 发送端端口   
  15.   
  16. bind(sd, (struct sockaddr *)&(addr_org), sizeof(struct sockaddr_in)); // 绑定IP和端口  
    #include <sys/select.h>
    #include <sys/socket.h>
    #include <arpa/inet.h>

    #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和端口

第二部分: 发送数据

  1. sockaddr_in addr_dst; // 接收端地址   
  2.   
  3. addr_dst.sin_family = AF_INET;  
  4. addr_dst.sin_addr.s_addr = inet_addr("192.128.0.2"); // 接收端IP   
  5. addr_dst.sin_port = htons(8080); // 接收端端口   
  6.   
  7. ... // 生成要发送的数据到SendDataBuff, 长度为ulLen   
  8. sendto(sd, SendDataBuff, ulLen, 0, (struct sockaddr *)&(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中的数据

第三部分: 在线程中接收数据(非阻塞式)
  1. void *SocketReceiveThread(void *pParam)  
  2. {  
  3.     fd_set fdset;  
  4.     struct timeval delayval;  
  5.     unsigned long lRetVal;  
  6.   
  7.     delayval.tv_sec = 0;  
  8.     delayval.tv_usec = 5000; /*5ms延时*/  
  9.   
  10.     while (!end_flag)  
  11.     {  
  12.         FD_ZERO(&fdset);  
  13.         FD_SET(sd, &fdset);  
  14.   
  15.         lRetVal = select(sd+1, &fdset, NULL, NULL, &delayval); // 尤其要注意第一个参数   
  16.         if (0 == lRetVal)  
  17.         {  
  18.             continue;  
  19.         }  
  20.         else if (SOCKET_ERROR == lRetVal)  
  21.         {  
  22.             break;  
  23.         }  
  24.         else if (FD_ISSET(sd, &fdset) != 0)  
  25.         {  
  26.             char RecvDataBuff[MAX_DATA_BUF_LEN]; // 接收数据buffer   
  27.             unsigned long ulLen = recvfrom(sd, RecvDataBuff, MAX_DATA_BUF_LEN, 0, NULL, NULL);  
  28.             ... // 处理接收到的数据   
  29.         }  
  30.     }  
  31. }  
    void *SocketReceiveThread(void *pParam)
    {
        fd_set fdset;
        struct timeval delayval;
        unsigned long lRetVal;

        delayval.tv_sec = 0;
        delayval.tv_usec = 5000; /*5ms延时*/

        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
  1. close(sd);  
close(sd);


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值