UDP广播之socket bad address 错误被解决,舒服

在编写UDP广播程序编写完后,一编译,提示socket bad address.后面查资料得知在读取socket缓冲的时候,发送端sendto返回值正常,接收端recvfrom却读不到信息,是因为指针指向了无法访问的空间
发送端代码:client.c

#include <sys/types.h>
#include <sys/socket.h>
#include <stdio.h>
#include <unistd.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <string.h>

int main(void){
    int ret;
    int serverfd;

    serverfd = socket(AF_INET, SOCK_DGRAM, 0);
    if(serverfd == -1){
        perror("socket fail\n");
        close(serverfd);
        return -1;
    }

    struct sockaddr_in serveraddr, clientaddr;

    memset(&serveraddr, 0, sizeof(serveraddr));
    memset(&clientaddr, 0, sizeof(clientaddr));
    serveraddr.sin_family = AF_INET;
    serveraddr.sin_port = htons(8000);
    serveraddr.sin_addr.s_addr = INADDR_ANY;


    ret = bind(serverfd, (struct sockaddr *)&serveraddr, sizeof(serveraddr));
    if(ret == -1){
        perror("bind error\n");
        close(serverfd);
        return -1;
    }

    char buf[128];
    int sin_size = sizeof(clientaddr);
    while(1){
        memset(buf, 128, 0);
        recvfrom(serverfd, buf, 128, 0, (struct sockaddr *)&clientaddr, &sin_size);
        printf("Recv msg from client: %s\n", buf);
    }

    return 0;
}

接收端代码:server.c

#include <sys/types.h>
#include <sys/socket.h>
#include <stdio.h>
#include <unistd.h>
#include <string.h>
#include <netinet/in.h>
#include <arpa/inet.h>

int main(void){
    int ret;
    int clientfd;

    clientfd = socket(AF_INET, SOCK_DGRAM, 0);
    if(clientfd ==  -1){
        perror("socket fail\n");
        close(clientfd);
        return -1;
    }

    struct sockaddr_in serveraddr;

    memset(&serveraddr, 0, sizeof(serveraddr));
    serveraddr.sin_family = AF_INET;
    serveraddr.sin_port = htons(8000);
    serveraddr.sin_addr.s_addr = inet_addr("192.168.5.255");

    int on = 1;
    ret = setsockopt(clientfd, SOL_SOCKET, SO_BROADCAST, (void *)&on, sizeof(on));
    //ret = setsockopt(clientfd, SOL_SOCKET, SO_BROADCAST, (void *)on, sizeof(on));
    //注意on与上一条语句的&on,少了一个取址符,
    //on的值此时为1(及地址值为1),因此指向了无法访问的空间
    if(ret == -1){
        perror("setsockopt fail\n");
        close(clientfd);
        return -1;
    }

    char buf[128];
    while(1){
        memset(buf, 0, 128);
        printf("Client send msg: ");
        fgets(buf, 128, stdin);
        sendto(clientfd, buf, strlen(buf), 0, (struct sockaddr *)&serveraddr, sizeof(serveraddr));
    }

    close(clientfd);

    return 0;
}

为了突出重点(指针指向了无法访问的空间),就省略了其它注释了,见谅~

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值