要在Android的app billing v3中测试我实现了一个对话框,它添加了一个选项项适配器。我添加了测试Skus,“android.test.purchased”,“android.test.canceled”,“android.test.refunded”,“android.test.item_unavailable”。
当我使用对话框启动购买流程时,一切都很好,我可以购买该商品,并且该商品绝对是购买的。但是,当我的应用程序尝试刷新UI时,我得到nullpointerexception。我知道刷新工作。
这是我的logcat:
12-16 01:06:06.706: I/Running inventory query with(20846): android.test.purchased
12-16 01:06:06.706: I/Running details query with(20846): SkuDetails:{"title":"Sample Title","price":"£0.61","type":"inapp","description":"Sample description for product: android.test.purchased.","productId":"android.test.purchased"}
12-16 01:06:06.706: I/Running details query with(20846): SkuDetails:{"title":"Sample Title","price":"£0.61","type":"inapp","description":"Sample description for product: android.test.purchased.","productId":"android.test.purchased"}
12-16 01:06:06.706: I/Running inventory query with(20846): android.test.canceled
12-16 01:06:06.706: I/Running details query with(20846): null
12-16 01:06:06.706: I/Running details query with(20846): null
12-16 01:06:06.706: D/AndroidRuntime(20846): Shutting down VM
12-16 01:06:06.706: W/dalvikvm(20846): threadid=1: thread exiting with uncaught exception (group=0x40d12930)
12-16 01:06:06.706: E/AndroidRuntime(20846): FATAL EXCEPTION: main
12-16 01:06:06.706: E/AndroidRuntime(20846): java.lang.NullPointerException
12-16 01:06:06.706: E/AndroidRuntime(20846): at com.example.test.MainActivity$1.onQueryInventoryFinished(MainActivity.java:201)
12-16 01:06:06.706: E/AndroidRuntime(20846): at com.example.test.util.IabHelper$2$1.run(IabHelper.java:536)
12-16 01:06:06.706: E/AndroidRuntime(20846): at android.os.Handler.handleCallback(Handler.java:725)
12-16 01:06:06.706: E/AndroidRuntime(20846): at android.os.Handler.dispatchMessage(Handler.java:92)
12-16 01:06:06.706: E/AndroidRuntime(20846): at android.os.Looper.loop(Looper.java:137)
12-16 01:06:06.706: E/AndroidRuntime(20846): at android.app.ActivityThread.main(ActivityThread.java:5039)
12-16 01:06:06.706: E/AndroidRuntime(20846): at java.lang.reflect.Method.invokeNative(Native Method)
12-16 01:06:06.706: E/AndroidRuntime(20846): at java.lang.reflect.Method.invoke(Method.java:511)
12-16 01:06:06.706: E/AndroidRuntime(20846): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
12-16 01:06:06.706: E/AndroidRuntime(20846): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
12-16 01:06:06.706: E/AndroidRuntime(20846): at dalvik.system.NativeStart.main(Native Method)
for (String s : allSkus) {
Log.i("Running inventory query with", "" + s);
SkuDetails c = inv.getSkuDetails(s);
Log.i("Running details query with", "" + c);
if (inv.hasPurchase(s)) {
purchaseArray.add(c.getTitle());
} else {
**LINE 201** objects.add(c.getPrice() + " T:" + c.getSku());
}
allSkus是一个ArrayList,它保存上面的4个skus。
nullpointer是 SkuDetails c = inv.getSkuDetails(s);
在UI刷新时返回null。但问题是它似乎适用于第一个sku(android.test.purchased)但是对于第二个sku(android.test.canceled)是空的,并且当它在购买另一个项目之后运行时它也是null(退款或购买)。但是,如果我随后再次打开它,它就没问题了,也没有抛出nullpointerexception。
如果我在添加到ArrayList对象之前添加空检查,则在购买的项目在inv.getSkuDetails(s)上返回null之前或之后,不会添加任何项目作为每个项目
答案 0 :(得分:5)
这让我很难过,而且接受的答案中没有相关细节。
在调用startSetup之后,您需要做的是传递一个包含您要查询的SKU(无论是否购买)。所以它看起来像下面的代码,而不是(不适当的)样板TrivialDrive示例中提供的代码。
mHelper.queryInventoryAsync(true, skuList, mGotInventoryListener);
此外,它看起来有一些幻影方法(在评论中仍然没有清理,这也是不准确的)... ...这个错误的更多细节:
答案 1 :(得分:4)
想出来,把它留给与我有同样问题的人。在UI刷新中,我调用IabHelper查询而不查询skus的详细信息。因此,预先缓存的skus有细节,但那些没有的,失败了。