组播

组播原理这里就不介绍了, 我博客里有介绍组播原理的详细的文章。

 

这里只是实现一个小例子, 一个 send.cpp 一个recv.cpp文件。

 

编译后生成2个进程, 一个接收一个发送。

 

Sender.cpp 文件内容如下:

 

  1. #include <stdlib.h>   
  2. #include <sys/types.h>   
  3. #include <sys/socket.h>   
  4. #include <netinet/in.h>   
  5. #include <arpa/inet.h>   
  6. #include <time.h>   
  7. #include <string.h>   
  8. #include <stdio.h>   
  9. #include <unistd.h>   
  10.   
  11. #define HELLO_PORT 12345   
  12. #define HELLO_GROUP "225.0.0.37"   
  13.   
  14. int main(int argc, char *argv[])  
  15. {  
  16.     struct sockaddr_in addr;  
  17.     int fd, cnt;  
  18.     struct ip_mreq mreq;  
  19.     char *message="Hello, World!";  
  20.   
  21.     /* create what looks like an ordinary UDP socket */  
  22.     if ((fd=socket(AF_INET,SOCK_DGRAM,0)) < 0)   
  23.     {  
  24.         perror("socket");  
  25.         exit(1);  
  26.     }  
  27.   
  28.     /* set up destination address */  
  29.     memset(&addr,0,sizeof(addr));  
  30.     addr.sin_family=AF_INET;  
  31.     addr.sin_addr.s_addr=inet_addr(HELLO_GROUP);  
  32.     addr.sin_port=htons(HELLO_PORT);  
  33.   
  34.     /* now just sendto() our destination! */  
  35.     while (1)  
  36.     {  
  37.         if (sendto(fd,message, strlen(message), 0, (struct sockaddr *) &addr, sizeof(addr)) < 0)   
  38.         {  
  39.             perror("sendto");  
  40.             exit(1);  
  41.         }  
  42.         sleep(1);  
  43.     }  
  44. }  

 

Recver.cpp 文件内容如下:

 

  1. #include <stdlib.h>   
  2. #include <sys/types.h>   
  3. #include <sys/socket.h>   
  4. #include <netinet/in.h>   
  5. #include <arpa/inet.h>   
  6. #include <time.h>   
  7. #include <string.h>   
  8. #include <stdio.h>   
  9. #include <unistd.h>   
  10.   
  11. #define HELLO_PORT  12345   
  12. #define HELLO_GROUP "225.0.0.37"   
  13. #define MSGBUFSIZE 256   
  14.   
  15. int main(int argc, char *argv[])  
  16. {  
  17.     struct sockaddr_in addr;  
  18.     int fd, nbytes,addrlen;  
  19.     struct ip_mreq mreq;  
  20.     char msgbuf[MSGBUFSIZE];  
  21.   
  22.     u_int yes=1; /*** MODIFICATION TO ORIGINAL */  
  23.   
  24.     /* create what looks like an ordinary UDP socket */  
  25.     if ((fd=socket(AF_INET,SOCK_DGRAM,0)) < 0)   
  26.     {  
  27.         perror("socket");  
  28.         exit(1);  
  29.     }  
  30.   
  31.   
  32.     /**** MODIFICATION TO ORIGINAL */  
  33.     /* allow multiple sockets to use the same PORT number */  
  34.     if (setsockopt(fd,SOL_SOCKET,SO_REUSEADDR,&yes,sizeof(yes)) < 0)   
  35.     {  
  36.         perror("Reusing ADDR failed");  
  37.         exit(1);  
  38.     }  
  39.     /*** END OF MODIFICATION TO ORIGINAL */  
  40.   
  41.     /* set up destination address */  
  42.     memset(&addr,0,sizeof(addr));  
  43.     addr.sin_family=AF_INET;  
  44.     addr.sin_addr.s_addr=htonl(INADDR_ANY); /* N.B.: differs from sender */  
  45.     addr.sin_port=htons(HELLO_PORT);  
  46.   
  47.     /* bind to receive address */  
  48.     if (bind(fd,(struct sockaddr *) &addr,sizeof(addr)) < 0)  
  49.     {  
  50.         perror("bind");  
  51.         exit(1);  
  52.     }  
  53.   
  54.     /* use setsockopt() to request that the kernel join a multicast group */  
  55.     mreq.imr_multiaddr.s_addr=inet_addr(HELLO_GROUP);  
  56.     mreq.imr_interface.s_addr=htonl(INADDR_ANY);  
  57.     if (setsockopt(fd,IPPROTO_IP,IP_ADD_MEMBERSHIP,&mreq,sizeof(mreq)) < 0)   
  58.     {  
  59.         perror("setsockopt");  
  60.         exit(1);  
  61.     }  
  62.   
  63.     /* now just enter a read-print loop */  
  64.     while (1)   
  65.     {  
  66.         addrlen=sizeof(addr);  
  67.         if ((nbytes=recvfrom(fd,msgbuf,MSGBUFSIZE,0, (struct sockaddr *) &addr,(socklen_t*)&addrlen)) < 0)   
  68.         {  
  69.             perror("recvfrom");  
  70.             exit(1);  
  71.         }  
  72.         puts(msgbuf);  
  73.     }  
  74.   
  75.     return 0;  
  76. }  

 

Makefie 文件如下 :

 

  1. CC = gcc  
  2. CXX = g++  
  3. CFLAGS = -Wall -D_DEBUG -DDEBUG -g -O0  
  4. LDFLAGS =   
  5.   
  6. MODULE_INC = -I/usr/include  
  7. MODULE_LIB = -L/usr/lib  
  8.   
  9. CFLAGS  += $(MODULE_INC)  
  10. LDFLAGS += $(MODULE_LIB)  
  11.   
  12.   
  13. SENDOBJS = Sender.o  
  14. RECVOBJS = Recver.o  
  15.   
  16.   
  17. TARGET = Sender Recver  
  18.   
  19. all: $(TARGET)  
  20.   
  21. Sender: $(SENDOBJS)  
  22.     $(CXX) -o $@ $^ $(LDFLAGS)  
  23.   
  24. Recver: $(RECVOBJS)  
  25.     $(CXX) -o $@ $^ $(LDFLAGS)  
  26.   
  27. clean:   
  28.     rm -f *.o  
  29.     rm -f $(TARGET)  
  30.     rm -f http/*.o  
  31. # make rule  
  32. %.o : %.c  
  33.     $(CC) $(CFLAGS) -c $^ -o $@   
  34.   
  35. %.o : %.cpp  
  36.     $(CC) $(CFLAGS) -c $^ -o $@   

 

 

编译方法直接

 

make

 

下来执行

 

./Sender 

 

./Recver

 

即可看到输出的结果。。。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值