man*_*ard 11 android android-contentprovider google-nexus
我正在开发一个带有ContentProvider的应用程序来提供一些内部文件(二进制文件).当我将它部署在三星Galaxy S,SII或其他任何产品上时,它可以完美地工作,当我在Galaxy Nexus或Nexus S上试用它时,它不起作用!
场景:
可以使用两个URI访问我的ContentProvider.根据此URI,提供程序将创建DataCursor(扩展CrossProcessCursor)或ModelCursor(也扩展CrossProcessCursos).事实是,在Nexus系列中,我访问第一个游标(DataCursor)来检索标识符,它工作正常,但是当访问第二个时,它总是在尝试时抛出"OutOfBoundsException"
getBlob()
方法.
提供商
@Override
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
Cursor cursor = null;
// If the third app requieres DATA (phrase id, phrase string and phrase name)
if(uri.toString().equalsIgnoreCase(ProviderConstants.DATA_URI.toString())) {
// Build the DataHelper and the customized cursor
DataHelper dataHelper = new DataHelper(getContext());
cursor = new DataCursor(dataHelper);
} else if(uri.toString().equalsIgnoreCase(ProviderConstants.MODEL_URI.toString())) {
// Let's take the model id from the selectionArgs...
if (selectionArgs != null && selectionArgs.length > 0) {
String modelId = selectionArgs[0];
// Get an instance to the persistent storage service...
File file = FileManager.getDirectory(getContext(), modelId);
FileSystemPersistentStorageService clientPersistentStorageService = new FileSystemPersistentStorageService(file);
cursor = new ModelCursor(clientPersistentStorageService);
} else {
Log.e("ContentProvider", "Query without model id on selectionArgs");
}
}
return cursor;
}
Run Code Online (Sandbox Code Playgroud)
如果您需要一些代码或任何东西,请索取它!
非常感谢.
终于我得到了答案。这不是由于设备,而是由于 Android 操作系统版本。
从 4.0.3 开始的早期版本,AbstarctCursor 的fillWindow()方法以一种方式实现,不强制将第一项的光标位置设置为 0。在4.0.3之后(如此处所示),此方法被修改,导致不将光标位置设置为0。
抛出的异常是:
07-31 11:35:09.938: W/System.err(2760): android.database.CursorIndexOutOfBoundsException: Index -1 requested, with a size of 1
07-31 11:35:09.985: W/System.err(2760): at android.database.AbstractCursor.checkPosition(AbstractCursor.java:418)
07-31 11:35:09.989: W/System.err(2760): at android.database.AbstractWindowedCursor.checkPosition(AbstractWindowedCursor.java:136)
07-31 11:35:09.989: W/System.err(2760): at android.database.AbstractWindowedCursor.getBlob(AbstractWindowedCursor.java:44)
07-31 11:35:09.993: W/System.err(2760): at android.database.CursorWrapper.getBlob(CursorWrapper.java:122)
07-31 11:35:09.993: W/System.err(2760): at es.agnitio.kivox.mobile.internal.ModelImporterAndroidImpl.importModelPackage(ModelImporterAndroidImpl.java:44)
07-31 11:35:09.993: W/System.err(2760): at es.agnitio.kivox.mobile.internal.KivoxMobileBasicCode.importModel(KivoxMobileBasicCode.java:159)
07-31 11:35:09.997: W/System.err(2760): at es.agnitio.kivox.mobile.internal.KivoxMobileBasicImpl.importModel(KivoxMobileBasicImpl.java:47)
07-31 11:35:09.997: W/System.err(2760): at es.agnitio.kivoxmobile.testing.KivoxMobileBasicTrial.onCreate(KivoxMobileBasicTrial.java:63)
07-31 11:35:09.997: W/System.err(2760): at android.app.Activity.performCreate(Activity.java:5008)
07-31 11:35:10.001: W/System.err(2760): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
07-31 11:35:10.001: W/System.err(2760): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2023)
07-31 11:35:10.001: W/System.err(2760): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084)
07-31 11:35:10.004: W/System.err(2760): at android.app.ActivityThread.access$600(ActivityThread.java:130)
07-31 11:35:10.004: W/System.err(2760): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195)
07-31 11:35:10.004: W/System.err(2760): at android.os.Handler.dispatchMessage(Handler.java:99)
07-31 11:35:10.008: W/System.err(2760): at android.os.Looper.loop(Looper.java:137)
07-31 11:35:10.008: W/System.err(2760): at android.app.ActivityThread.main(ActivityThread.java:4745)
07-31 11:35:10.008: W/System.err(2760): at java.lang.reflect.Method.invokeNative(Native Method)
07-31 11:35:10.012: W/System.err(2760): at java.lang.reflect.Method.invoke(Method.java:511)
07-31 11:35:10.012: W/System.err(2760): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
07-31 11:35:10.012: W/System.err(2760): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
07-31 11:35:10.016: W/System.err(2760): at dalvik.system.NativeStart.main(Native Method)
Run Code Online (Sandbox Code Playgroud)
这表明(经过深入研究),光标索引没有设置在 上fillWindow()。
解决方案
要解决此“碎片”问题,只需在自定义光标的or (使用某些应用程序逻辑)等方法中添加moveToPosition(0)即可。这将使游标索引被设置为0,避免“-1”索引请求异常。moveToFirst()move()
希望它对任何人有帮助=)
| 归档时间: |
|
| 查看次数: |
732 次 |
| 最近记录: |