关于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部分。

原文地址:https://www.cnblogs.com/mosmith/p/4472245.html