gpt4 book ai didi

java - 安卓3.2 : Receive UDP packets does not work?

转载 作者:行者123 更新时间:2023-12-01 19:11:47 25 4
gpt4 key购买 nike

我正在编写一个 Android 平板电脑应用程序。它通过 UDP 消息(每个 13 字节数据)进行通信。发送这些数据包工作正常。但是,当我尝试在端口 15731(以及其他端口)上接收单播 UDP 数据包时,它总是返回 IOException。这就是我的代码的样子(receiveUDP 循环运行)。

public void receiveUDP() {
byte[] buffer = new byte[13];
try {
DatagramPacket dataIn = new DatagramPacket(buffer, buffer.length);
DatagramSocket recSocket = new DatagramSocket(15731);
recSocket.setSoTimeout(1000);
recSocket.receive(dataIn);
Log.i("receiveUDP", "UDP Message received: " + buffer.toString());
recSocket.close();
} catch (IOException e) {
Log.i("receiveUDP", "IOException");
}
;
}

在 Android list 中,我授予了以下权限:

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.CHANGE_WIFI_MULTICAST_STATE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

e.printfStackTrace() 命令结果如下:

11-17 14:34:05.130: WARN/System.err(25961): java.net.BindException: Address already in use
11-17 14:34:05.140: WARN/System.err(25961): at org.apache.harmony.luni.platform.OSNetworkSystem.bind(Native Method)
11-17 14:34:05.140: WARN/System.err(25961): at dalvik.system.BlockGuard$WrappedNetworkSystem.bind(BlockGuard.java:275)
11-17 14:34:05.140: WARN/System.err(25961): at org.apache.harmony.luni.net.PlainDatagramSocketImpl.bind(PlainDatagramSocketImpl.java:77)
11-17 14:34:05.140: WARN/System.err(25961): at java.net.DatagramSocket.createSocket(DatagramSocket.java:190)
11-17 14:34:05.140: WARN/System.err(25961): at java.net.DatagramSocket.<init>(DatagramSocket.java:74)
11-17 14:34:05.140: WARN/System.err(25961): at com.example.MyService.onCreate(MyService.java:78)
11-17 14:34:05.140: WARN/System.err(25961): at android.app.ActivityThread.handleCreateService(ActivityThread.java:2103)
11-17 14:34:05.140: WARN/System.err(25961): at android.app.ActivityThread.access$1500(ActivityThread.java:122)
11-17 14:34:05.140: WARN/System.err(25961): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1078)
11-17 14:34:05.140: WARN/System.err(25961): at android.os.Handler.dispatchMessage(Handler.java:99)
11-17 14:34:05.140: WARN/System.err(25961): at android.os.Looper.loop(Looper.java:132)
11-17 14:34:05.140: WARN/System.err(25961): at android.app.ActivityThread.main(ActivityThread.java:4123)
11-17 14:34:05.140: WARN/System.err(25961): at java.lang.reflect.Method.invokeNative(Native Method)
11-17 14:34:05.140: WARN/System.err(25961): at java.lang.reflect.Method.invoke(Method.java:491)
11-17 14:34:05.140: WARN/System.err(25961): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
11-17 14:34:05.140: WARN/System.err(25961): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
11-17 14:34:05.140: WARN/System.err(25961): at dalvik.system.NativeStart.main(Native Method)

这是什么意思?

现在,如果我不再创建 DatagramSocket 和 DatagramPacket 循环,我会得到不同的堆栈跟踪。它是:

11-17 15:06:42.590: WARN/System.err(26812): android.os.NetworkOnMainThreadException
11-17 15:06:42.590: WARN/System.err(26812): at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1077)
11-17 15:06:42.590: WARN/System.err(26812): at dalvik.system.BlockGuard$WrappedNetworkSystem.recv(BlockGuard.java:332)
11-17 15:06:42.590: WARN/System.err(26812): at org.apache.harmony.luni.net.PlainDatagramSocketImpl.doRecv(PlainDatagramSocketImpl.java:165)
11-17 15:06:42.590: WARN/System.err(26812): at org.apache.harmony.luni.net.PlainDatagramSocketImpl.receive(PlainDatagramSocketImpl.java:174)
11-17 15:06:42.590: WARN/System.err(26812): at java.net.DatagramSocket.receive(DatagramSocket.java:391)
11-17 15:06:42.590: WARN/System.err(26812): at com.example.MyService.onCreate(MyService.java:114)
11-17 15:06:42.610: WARN/System.err(26812): at android.app.ActivityThread.handleCreateService(ActivityThread.java:2103)
11-17 15:06:42.610: WARN/System.err(26812): at android.app.ActivityThread.access$1500(ActivityThread.java:122)
11-17 15:06:42.610: WARN/System.err(26812): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1078)
11-17 15:06:42.610: WARN/System.err(26812): at android.os.Handler.dispatchMessage(Handler.java:99)
11-17 15:06:42.610: WARN/System.err(26812): at android.os.Looper.loop(Looper.java:132)
11-17 15:06:42.610: WARN/System.err(26812): at android.app.ActivityThread.main(ActivityThread.java:4123)
11-17 15:06:42.610: WARN/System.err(26812): at java.lang.reflect.Method.invokeNative(Native Method)

有人知道为什么我无法接收 UDP 数据包吗?

最佳答案

有几件事:

由于您重复使用相同的端口,您可能需要创建一个套接字,调用 setReuseAddress(true) ,然后将套接字绑定(bind)到端口。

InterruptedIOException是IOException的子类,setSOTimeout(1000);在抛出此异常之前只会等待(阻塞)1 秒

更新:异常显示了问题:

java.net.BindException: Address already in use

我相信使用 setReuseAddress(上面)可以解决这个问题?

android.os.NetworkOnMainThreadException

这意味着您在主 UI 线程上运行此代码,这将阻止 UI 的响应性并可能导致 ANR(如果您保留 setSOTimeout(1000) 则可能不会,但无论如何......)。 3.0及更高版本不允许UI线程上的网络请求,因此您需要将其放入 AsyncTask (或线程)。

关于java - 安卓3.2 : Receive UDP packets does not work?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8167113/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com