我正在开发一个带有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;
}
如果您需要某些代码或任何内容,请直接询问!
非常感谢。
答案 0 :(得分:1)
最后我得到了答案。这不是因为设备,而是由于Android OS版本。
4.0.3早期版本的AbstarctCursor方法fillWindow()以单向方式实现,并非强制要求将第一项的光标位置设置为0。在4.0.3(as seen here)之后,此方法被修改,导致未将光标位置设置为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)
其中显示(经过深入研究后),fillWindow()
未设置游标索引。
<强>解强>
要解决此“碎片”问题,只需在自定义光标的moveToFirst()
或move()
(带有一些应用逻辑)等方法中添加moveToPosition(0)即可。这将使光标索引设置为0,避免“-1”索引请求异常。
希望它可以帮助任何人=)
答案 1 :(得分:0)
我有点需要这个水晶球,但是......你可以尝试两件事:
将光标移动到第一个条目,建议为SteveR。
其次,我在使用Dell Streak 7“平板电脑时遇到了类似的问题。它应该是设备列表的一部分,在访问其内部存储方面有一个特殊例外。很难找到,但是用if语句排序。它可能类似,但我对此表示怀疑,特别是因为Nexus应该是开发人员的设备。
也许您应该尝试运行最简单的ContentProvider测试应用程序,看看它在这些设备上的行为。