2010-07-23 144 views
2

我的应用程序使用应用内搜索,动态建立每个请求的搜索建议,将它们放入MatrixCursor并返回要显示的建议。在这里搜索建议信息:
http://developer.android.com/guide/topics/search/adding-custom-suggestions.html搜索建议失败2.2

这个工作在2.1 UPDATE1完全正常,但是当我装好了一个2.2的手机上,我得到一个致命的错误,当我尝试搜索。下面是相关的日志:

07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028): error changing cursor and caching columns 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028): java.lang.NumberFormatException: My String Message 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at java.lang.Long.parse(Long.java:364) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at java.lang.Long.parseLong(Long.java:354) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at java.lang.Long.parseLong(Long.java:320) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.database.MatrixCursor.getLong(MatrixCursor.java:255) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.database.CursorWrapper.getLong(CursorWrapper.java:127) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.widget.CursorAdapter.getItemId(CursorAdapter.java:156) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.widget.AutoCompleteTextView.buildDropDown(AutoCompleteTextView.java:1248) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.widget.AutoCompleteTextView.showDropDown(AutoCompleteTextView.java:1137) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.widget.AutoCompleteTextView.updateDropDownForFilter(AutoCompleteTextView.java:1019) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.widget.AutoCompleteTextView.onFilterComplete(AutoCompleteTextView.java:1002) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.app.SearchDialog.onDataSetChanged(SearchDialog.java:612) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.app.SuggestionsAdapter.notifyDataSetChanged(SuggestionsAdapter.java:193) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.widget.CursorAdapter.changeCursor(CursorAdapter.java:260) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.app.SuggestionsAdapter.changeCursor(SuggestionsAdapter.java:238) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.widget.CursorFilter.publishResults(CursorFilter.java:67) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.widget.Filter$ResultsHandler.handleMessage(Filter.java:282) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.os.Handler.dispatchMessage(Handler.java:99) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.os.Looper.loop(Looper.java:123) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at android.app.ActivityThread.main(ActivityThread.java:4627) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at java.lang.reflect.Method.invokeNative(Native Method) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at java.lang.reflect.Method.invoke(Method.java:521) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
07-22 12:13:05.935: ERROR/SuggestionsAdapter(1028):  at dalvik.system.NativeStart.main(Native Method) 


07-22 12:13:05.935: DEBUG/AndroidRuntime(1028): Shutting down VM 
07-22 12:13:05.935: WARN/dalvikvm(1028): threadid=1: thread exiting with uncaught exception (group=0x4001d7f0) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028): FATAL EXCEPTION: main 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028): java.lang.NumberFormatException: My String Message 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at java.lang.Long.parse(Long.java:364) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at java.lang.Long.parseLong(Long.java:354) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at java.lang.Long.parseLong(Long.java:320) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at android.database.MatrixCursor.getLong(MatrixCursor.java:255) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at android.database.CursorWrapper.getLong(CursorWrapper.java:127) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at android.widget.CursorAdapter.getItemId(CursorAdapter.java:156) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at android.widget.AutoCompleteTextView.buildDropDown(AutoCompleteTextView.java:1248) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at android.widget.AutoCompleteTextView.showDropDown(AutoCompleteTextView.java:1137) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at android.widget.AutoCompleteTextView.updateDropDownForFilter(AutoCompleteTextView.java:1019) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at android.widget.AutoCompleteTextView.onFilterComplete(AutoCompleteTextView.java:1002) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at android.widget.Filter$ResultsHandler.handleMessage(Filter.java:285) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at android.os.Handler.dispatchMessage(Handler.java:99) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at android.os.Looper.loop(Looper.java:123) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at android.app.ActivityThread.main(ActivityThread.java:4627) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at java.lang.reflect.Method.invokeNative(Native Method) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at java.lang.reflect.Method.invoke(Method.java:521) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
07-22 12:13:05.945: ERROR/AndroidRuntime(1028):  at dalvik.system.NativeStart.main(Native Method) 

其中“我的字符串信息”是第一个(在这种情况下,仅)行的SUGGEST_COLUMN_TEXT_1字段的值将被返回作为光标的建议。堆栈跟踪根本不触碰我的代码,并且在调试器中跟踪它,显示在我的搜索建议内容提供程序中返回建议光标后的一段时间内发生错误。

为什么他们的适配器突然尝试将字符串解释为长整型?有人遇到过这种情况么?

谢谢!

回答

3

代码在尝试访问任何搜索建议游标所需的ID列(“_id”)时失败,并且必须是Long。

您是否可能不包括该列,或者,您是否正在创建该列,但无意中将其写入了该列?

http://developer.android.com/guide/topics/search/adding-custom-suggestions.html#SuggestionTable

+0

这是问题所在。当我得到的代码有一个字符串(与text1相同的字符串)进入ID,但它并不重要,并在2.1它工作,所以我刚刚离开它。显然在2.2上,它被强制执行为一个Long。 – 2010-07-23 21:01:23

+0

我也面临同样的问题在android 2.2,请提供一些更多的信息来解决这个问题。请 – 2010-10-22 15:30:38

0

只是一个参考别人谁卡住,列_id是区分大小写的。将列定义为"_ID"失败并命中异常。