zoukankan      html  css  js  c++  java
  • 关于java MulticastSocket中的joinGroup(SocketAddress mcastAddr,NetworkInterface netif)

    今天复习了一下java网络编程这方面(其实是之前没有学好),之前在linux下用c来做过一些例子,不过不好久没有用也就忘得一干二净了。不知道c/c++的东西不太好记,还是当初没好好学。

    关于组播这方面,其实别的问题没有,《JAVA网络编程》这本书说得很明白了,但遇到其中一个很令人费解的api,如下:

    java MulticastSocket中的joinGroup(SocketAddress mcastAddr,NetworkInterface netif)

    第一个参数为什么是SocketAddress而不是InetAddress啊,SocketAddress中的端口号有毛用啊?很可惜,API上并没有说明为什么是SocketAddress,于是乎只好自动动手做实验了。

    import java.util.*;
    import java.io.*;
    import java.net.*;
    
    public class Server {
    	public static void main(String[] args) throws Exception{
    		InetAddress group=InetAddress.getByName("224.2.2.2");
    		MulticastSocket ms=new MulticastSocket(8989);
    		ms.joinGroup(new InetSocketAddress(group,1000),NetworkInterface.getByName("172.31.164.11"));
    		
    		byte[] buffer=new byte[8192];
    		DatagramPacket dp=new DatagramPacket(buffer,buffer.length);
    		
    		while(true){
    			ms.receive(dp);
    			byte[] data=dp.getData();
    			String line=new String(data,dp.getOffset(),dp.getLength());
    			System.out.println(line);
    			dp.setLength(buffer.length);
    		}
    	}
    }
    

    客户端的代码没有给出(太简单了)。如果按上面运行的话,Server只能接收到8989端口上的组播数据,而不能接收发送到1000端口上的组播数据。

    用netstat -ano | findstr也没有发现有1000号的端口在监听。

    SO.....joinGroup(SocketAddress mcastAddr,NetworkInterface netif)中的SocketAddress只是用到了InetAddress部分。

  • 相关阅读:
    和大家一起了解Windows Server 2016 License许可证授权方式
    centos的cockpit安装使用
    Nscan-20150223
    JexBoss-20170328
    InsightScan-20150320
    Clusterd-20151119
    BBScan-20200419
    Astra-20190405
    为什么计算机计算时间要从1970年开始
    Appium环境搭建
  • 原文地址:https://www.cnblogs.com/mosmith/p/4472245.html
Copyright © 2011-2022 走看看