首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >运行在android局域网中的UDP服务器

运行在android局域网中的UDP服务器
EN

Stack Overflow用户
提问于 2013-08-26 07:43:19
回答 1查看 1K关注 0票数 0

我使用的是UDP服务器,但我的服务器类给了我错误,我使用Service类为我的服务器和创建线程,但最终它不是运行和给我错误,它被停止运行了几秒钟。

代码语言:javascript
复制
public class MainActivity extends Service {


static String UDP_BROADCAST = "UDPBroadcast";
DatagramSocket socket;


private void listenAndWaitAndThrowIntent(InetAddress broadcastIP, Integer port) throws Exception {
    byte[] recvBuf = new byte[15000];
    if (socket == null || socket.isClosed())
    {
        socket = new DatagramSocket(port, broadcastIP);
        socket.setBroadcast(true);
    }
    DatagramPacket packet = new DatagramPacket(recvBuf, recvBuf.length);
    Log.e("UDP", "Waiting for UDP broadcast");
    socket.receive(packet);

    String senderIP = packet.getAddress().getHostAddress();
    String message = new String(packet.getData()).trim();
    Log.e("UDP", "Got UDB broadcast from " + senderIP + ", message: " + message);

//  broadcastIntent(senderIP, message);
    socket.close();
}
private void broadcastIntent(String senderIP, String message) {
    Intent intent = new Intent(MainActivity.UDP_BROADCAST);
    intent.putExtra("sender", senderIP);
    intent.putExtra("message", message);
    sendBroadcast(intent);
}
     Thread UDPBroadcastThread;

void startListenForUDPBroadcast() {
    UDPBroadcastThread = new Thread(new Runnable() {
        public void run() {
            try {
                InetAddress broadcastIP =     InetAddress.getByName("192.168.1.101"); //172.16.238.42 //192.168.1.255
                Integer port = 11111;
                while (shouldRestartSocketListen) {
                    listenAndWaitAndThrowIntent(broadcastIP, port);
                }
                //if (!shouldListenForUDPBroadcast) throw new ThreadDeath();
            } catch (Exception e) {
                Log.i("UDP", "no longer listening for UDP broadcasts cause of error " + e.getMessage());
            }
        }
    });
    UDPBroadcastThread.start();
}
           private Boolean shouldRestartSocketListen=true;

void stopListen() {
    shouldRestartSocketListen = false;
    socket.close();
}

@Override
public void onCreate() {

};

@Override
public void onDestroy() {
    stopListen();
}


@Override
public int onStartCommand(Intent intent, int flags, int startId) {
    shouldRestartSocketListen = true;
    startListenForUDPBroadcast();
    Log.i("UDP", "Service started");
    return START_STICKY;
}

@Override
public IBinder onBind(Intent intent) {
    return null;
}
 }

我的日志猫是:

代码语言:javascript
复制
    08-26 19:28:44.232: D/AndroidRuntime(618): Shutting down VM
    08-26 19:28:44.252: W/dalvikvm(618): threadid=1: thread exiting with uncaught exception (group=0x409961f8)
    08-26 19:28:44.352: E/AndroidRuntime(618): FATAL EXCEPTION: main
    08-26 19:28:44.352: E/AndroidRuntime(618): java.lang.RuntimeException: Unable to   instantiate activity ComponentInfo{com.example.receiver/com.example.receiver.MainActivity}:   java.lang.ClassCastException: com.example.receiver.MainActivity cannot be cast to   android.app.Activity
    08-26 19:28:44.352: E/AndroidRuntime(618):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1879)
    08-26 19:28:44.352: E/AndroidRuntime(618):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1980)
    08-26 19:28:44.352: E/AndroidRuntime(618):  at android.app.ActivityThread.access$600(ActivityThread.java:122)
    08-26 19:28:44.352: E/AndroidRuntime(618):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1146)
    08-26 19:28:44.352: E/AndroidRuntime(618):  at android.os.Handler.dispatchMessage(Handler.java:99)
    08-26 19:28:44.352: E/AndroidRuntime(618):  at android.os.Looper.loop(Looper.java:137)
    08-26 19:28:44.352: E/AndroidRuntime(618):  at android.app.ActivityThread.main(ActivityThread.java:4340)
    08-26 19:28:44.352: E/AndroidRuntime(618):  at java.lang.reflect.Method.invokeNative(Native Method)
    08-26 19:28:44.352: E/AndroidRuntime(618):  at java.lang.reflect.Method.invoke(Method.java:511)
    08-26 19:28:44.352: E/AndroidRuntime(618):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
    08-26 19:28:44.352: E/AndroidRuntime(618):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
    08-26 19:28:44.352: E/AndroidRuntime(618):  at dalvik.system.NativeStart.main(Native Method)
    08-26 19:28:44.352: E/AndroidRuntime(618): Caused by: java.lang.ClassCastException: com.example.receiver.MainActivity cannot be cast to android.app.Activity
    08-26 19:28:44.352: E/AndroidRuntime(618):  at android.app.Instrumentation.newActivity(Instrumentation.java:1023)
    08-26 19:28:44.352: E/AndroidRuntime(618):  at   android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1870)
    08-26 19:28:44.352: E/AndroidRuntime(618):  ... 11 more
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-08-26 07:49:57

你把你想要做的不同任务混合在一起。为了让安卓能够在屏幕上显示它,您的活动必须扩展Activity。另一方面,Service基本上是一种告诉安卓你有一些背景或按需任务需要处理的方式。

您需要将UI (需要是Activity)从Service中分离出来。基于您的代码,您的类中似乎没有任何名为MainActivity的UI代码,因此您需要编写一个UI代码(它扩展了Activity),或者将您的意图指向现有的Activity。您还应该重命名MainActivity,因为它实际上不是Activity

Service有一些可能有用的示例。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18439077

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档