单播只能发送给一个接收方,但是当给多个接收者发送时,不仅仅耗费流量,而且耗费时间,总流量=每个接收者的流量*接受者。

广播方式是发送给所有的主机,广播的坏处是会造成信息污染,大量的信息会占用网络带宽。

多播(组播):只有加入某个多播组的主机才能接收到数据。多播既可以发给多个主机,又能避免像广播那样带来的过多的负荷。

组播的地址为D类地址:224.0.1.1-239.255.255.255

那么代码实现如下:

组播发送

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#define MCAST_PORT 50001
#define MCAST_ADDR "239.0.0.1"
#define error_exit(_errmsg_) error(EXIT_FAILURE, errno, _errmsg_)
#define BUFF_SIZE 1024
int main()
{
int sockfd;
struct sockaddr_in mcastaddr;
char *buff = NULL;
int nbytes;
time_t time_sec;
/**创建用户数据包套接字**/
== (sockfd = socket(AF_INET, SOCK_DGRAM, )))
error_exit("socket");
/**指定接收方地址为组播地址**/
mcastaddr.sin_family = AF_INET;
mcastaddr.sin_port = htons(MCAST_PORT);
mcastaddr.sin_addr.s_addr = inet_addr(MCAST_ADDR);
/**连接到组播地址**/
== connect(sockfd, (struct sockaddr *)&mcastaddr, sizeof(mcastaddr)))
error_exit("bind");
time(&time_sec);
) {
sleep();
time_sec ++;
buff = ctime(&time_sec);
printf("%s", buff);
/**数据发送**/
== send(sockfd, buff, strlen(buff), ))
error_exit("send");
}
close(sockfd);
;
}
组播接收,有多个接收者
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#define N 128
typedef struct sockaddr SA;
int main(int argc, const char *argv[])
{
int sockfd;
/**创建用户数据包套接字**/
)) == -)
{
perror("socket");
exit(-);
}
struct sockaddr_in myaddr;
myaddr.sin_family = AF_INET;
myaddr.sin_addr.s_addr = inet_addr("239.0.0.1");
myaddr.sin_port = htons();
/**绑定多播IP**/
)
{
perror("bind");
exit(-);
}
/*
** struct ip_mreq {
** struct in_addr imr_multiaddr; IP multicast address of group 设置多播组地址
** struct in_addr imr_interface; local IP address of interface 本机IP
** };
*/
/**加入多播组**/
struct ip_mreq mreq;
bzero(&mreq, sizeof(mreq));
mreq.imr_multiaddr.s_addr = inet_addr("239.0.0.1");
mreq.imr_interface.s_addr = inet_addr(/*"0.0.0.0"*/"192.168.1.24");
)
{
perror("setsockopt");
exit(-);
}
};
)
{
/**等待接收数据**/
recvfrom(sockfd, buf, N, , NULL, NULL);
printf("recv : %s\n", buf);
}
close(sockfd);
;
}
android multicast 多播(组播)问题

有谁遇到过同样问题的可以探讨下,或者已经解决问题的,能够指导下我    获取组播锁 private  InetAddress   group; WifiManager  wm=(WifiManager ...

IP多播(组播)

IP多播是实现数据一对多通信的模式.从一个源点传送到多个目的地,数据仅仅拷贝一份.这里说的数据仅仅拷贝一份,是指在每一条须要它的两个点之间,数据仅仅有一份.例如以下图为(谢希 ...

Java单播、广播、多播(组播)---转

一.通信方式分类 在当前的网络通信中有三种通信模式:单播.广播和多播(组播),其中多播出现时间最晚,同时具备单播和广播的优点. 单播:单台主机与单台主机之间的通信 广播:当台主机与网络中的所有主机通信 ...

Java单播、广播、多播(组播)

一.通信方式分类 在当前的网络通信中有三种通信模式:单播.广播和多播(组播),其中多播出现时间最晚,同时具备单播和广播的优点. 单播:单台主机与单台主机之间的通信 广播:当台主机与网络中的所有主机通信 ...

多网卡情况下接收udp组播

多网卡下接收udp组播 往往会接收失败 因为用错了网卡 例如我想要接收2网段 其他电脑出的udp组播  我电脑有有线网和wifi在window下可以这样 route add 230.0.0.1 mas ...

Linux IPC socket 广播,组播

getsockopt()/setsockopt() //获得sockfd指向的socket的属性 int getsockopt(int sockfd, int level, int optname, ...

Linux下用户和组管理

用户与组之间的关系是,组下面有若干个用户,每个用户必须从属于唯一一个组.组可以理解为权限的集合.用户管理的命令有:useradd, userdel, usermod, passwd, chsh, ch ...

2017.7.18 linux下用户、组和文件的操作


为什么要使用多播:        网卡从网络上接收到目标物理地址对应的所有bit位都为1的数据报时,会收到这条消息并将其上传给驱动程序,网卡的这种工作模式称为广播模式,网卡的缺省工作模式包含直接模式和 ...

随机推荐

给input的按钮控件添加onserverclick事件

前台:

yii2.0使用之缓存

1.片段缓存(针对于视图中的某部分进行缓存): <?php 设置有效时间 $time=15; 缓存依赖,存入文件.当文件内容发生改变是才会刷新新内容 $dependecy=[ 'class'=& ...

PCA原理解释(二)

PCA在做数据处理,一般会有一个数据预处理,其中一个目标就是将取数据特征向相关性. 为什么要去特征的相关性? 因为数据如果有相关性,在学习的时候是冗余的,徒增学习成本:所以对于数据处理(也称之为白化, ...

重学

C语言---03数据和C
1.数据的必要性.数据使我们生活中不可缺少的东西,程序也是如次,离不开数据.将文字.图片和单词等输入到算计,将其展现出来或者做一系列操作等. 2.实例程序. /*rhodium.c--用金属铑衡量体重 ...
Jenkins使用Git Parameter插件打包
一. 下载Git Parameter插件: 二. 项目配置: Shell脚本: #!/bin/bash -l echo $deploy_envcase $deploy_env in deploy) e ...
Java Web系列:JAAS认证和授权基础
1.认证和授权概述 (1)认证:对用户的身份进行验证. .NET基于的RBS(参考1)的认证和授权相关的核心是2个接口System.Security.Principal.IPrincipal和Syst ...
JDBC处理可滚动的处理集
Statement createStatement(int resultSetType,                           int resultSetConcurrency,     ...
网卡优化RPS/RFS
网卡优化 RSS receive side scaling,网卡多队列,需要硬件支持.网卡接收到网络数据包后,要发送一个硬件中断,通知CPU取数据包.默认配置,都是由CPU0去做. RPS recei ...
php int 与 datetime 转换

数据库日期类型是int类型的,该查询结果是datetime类型的 select from_unixtime( `dateline` ) from cdb_posts 如果原来类型是datetime类型 ...

爬虫任务一:使用httpclient去爬取百度新闻首页的新闻标题和url,编码是utf-8

第一个入手的爬虫小任务: maven工程