关于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部分。
XMReport-最懂你的Java报表工具
XMReport-The Best Java Report Engine