72

我正在尝试使用新的 Google Cloud Messaging 系统,但我遇到了一些问题。

我阅读了入门文档并查看了演示应用程序;之后,我将要求应用于我的应用程序,然后我使用 API 16 创建了一个新的虚拟设备。

但是当我尝试将我的设备注册到 GCM 时,它会因为这条线而失败:

GCMRegistrar.checkDevice(getApplicationContext()); 

在 logcat 我看到这些错误:

07-05 07:06:31.925: E/AndroidRuntime(691): FATAL EXCEPTION: main
07-05 07:06:31.925: E/AndroidRuntime(691): java.lang.UnsupportedOperationException: Device does not have package com.google.android.gsf
07-05 07:06:31.925: E/AndroidRuntime(691):  at com.google.android.gcm.GCMRegistrar.checkDevice(GCMRegistrar.java:83)
07-05 07:06:31.925: E/AndroidRuntime(691):  at aero.tav.mobile.genel$4.onClick(genel.java:201)
07-05 07:06:31.925: E/AndroidRuntime(691):  at com.android.internal.app.AlertController$ButtonHandler.handleMessage(AlertController.java:166)
07-05 07:06:31.925: E/AndroidRuntime(691):  at android.os.Handler.dispatchMessage(Handler.java:99)
07-05 07:06:31.925: E/AndroidRuntime(691):  at android.os.Looper.loop(Looper.java:137)
07-05 07:06:31.925: E/AndroidRuntime(691):  at android.app.ActivityThread.main(ActivityThread.java:4745)
07-05 07:06:31.925: E/AndroidRuntime(691):  at java.lang.reflect.Method.invokeNative(Native Method)
07-05 07:06:31.925: E/AndroidRuntime(691):  at java.lang.reflect.Method.invoke(Method.java:511)
07-05 07:06:31.925: E/AndroidRuntime(691):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
07-05 07:06:31.925: E/AndroidRuntime(691):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
07-05 07:06:31.925: E/AndroidRuntime(691):  at dalvik.system.NativeStart.main(Native Method)

我已将 gcm.jar 添加到我的课程路径中;我不知道出了什么问题。

4

2 回答 2

140

在我看来,您使用的是错误的模拟器。

默认模拟器使用没有任何 Google 软件包的常规 Android 模拟器,并且无法运行各种东西,如地图、c2dm 和各种类似的东西。

您要做的是创建一个可以支持 Google API 的新模拟器。

然后,当您运行项目时,选择运行目标名称的模拟器Google APIs (Google Inc).

祝你好运。

于 2012-07-05T07:35:22.273 回答
11

它可能在不支持 GCM 的设备上运行,因此您调用 GCMRegistrar.checkDevice(this); 正在引发异常。检查你的 logcat 以确保。

如果您在模拟器上对其进行测试,请确保您已将模拟器设置为使用 Google API。创建模拟器时,创建新的 AVD 窗口有一个“目标”框。在该框中选择“Google API”。

在此处输入图像描述

于 2014-03-18T06:41:26.557 回答