3

我正在尝试使用代码将声音保存为 Android 中的铃声。它就像一个魅力,但如果我尝试保存已经插入的铃声,它会失败。

保存时发生“SQLiteConstraintException”,但我无法捕获异常,事实上,我无法捕获任何执行。

这是我的代码的一部分:

Uri uri = MediaStore.Audio.Media.getContentUriForPath(k.getAbsolutePath());

try {
  this.getContentResolver().insert(uri, values);
} catch (SQLiteConstraintException e) {
  Log.e("error", e.getMessage());
} catch (SQLiteException e) {
  Log.e("error", e.getMessage());
} catch (Exception e) {
  Log.e("error", e.getMessage());
}

所以我试图真正捕捉任何可能的异常,但没有一个被捕捉到。

这是 LogCat:

10-12 18:32:51.627: ERROR/Database(217): Error inserting album_id=-1 title=Applause is_notification=true title_key=%,%J%J%B%,%T%P%4% mime_type=audio/ogg date_added=1286908371 _display_name=Applause.ogg is_alarm=true is_ringtone=true artist_id=1 is_music=false _data=/mnt/sdcard/media/audio/ringtones/Applause.ogg
10-12 18:32:51.627: ERROR/Database(217): android.database.sqlite.SQLiteConstraintException: error code 19: constraint failed
10-12 18:32:51.627: ERROR/Database(217):     at android.database.sqlite.SQLiteStatement.native_execute(Native Method)
10-12 18:32:51.627: ERROR/Database(217):     at android.database.sqlite.SQLiteStatement.execute(SQLiteStatement.java:55)
10-12 18:32:51.627: ERROR/Database(217):     at android.database.sqlite.SQLiteDatabase.insertWithOnConflict(SQLiteDatabase.java:1549)
10-12 18:32:51.627: ERROR/Database(217):     at android.database.sqlite.SQLiteDatabase.insert(SQLiteDatabase.java:1410)
10-12 18:32:51.627: ERROR/Database(217):     at com.android.providers.media.MediaProvider.insertInternal(MediaProvider.java:1813)
10-12 18:32:51.627: ERROR/Database(217):     at com.android.providers.media.MediaProvider.insert(MediaProvider.java:1638)
10-12 18:32:51.627: ERROR/Database(217):     at android.content.ContentProvider$Transport.insert(ContentProvider.java:174)
10-12 18:32:51.627: ERROR/Database(217):     at android.content.ContentProviderNative.onTransact(ContentProviderNative.java:146)
10-12 18:32:51.627: ERROR/Database(217):     at android.os.Binder.execTransact(Binder.java:288)
10-12 18:32:51.627: ERROR/Database(217):     at dalvik.system.NativeStart.run(Native Method)

我找到了一种解决方法:我在调用 .insert-method 之前检查声音文件是否存在(如果文件已经存在,则不要调用它),但我真的很想了解为什么没有捕获到异常。希望有人可以帮助我。

亲切的问候, Select0r

4

2 回答 2

1

It is not caught because the exception is not in your code. It is not even in your process. It is in the process of the MediaStore content provider.

于 2010-10-12T20:08:52.633 回答
1

我遇到了同样的问题....这是因为您的清单中没有此权限

<uses-permission android:name="android.permission.WRITE_SETTINGS"/>

此外,如果您正在使用该教程,请确保您的清单中也有此内容......

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

我花了半个小时左右的时间试图找出代码不起作用的原因。我实际上删除了 try/catch 只是为了看看它会在 logcat 中抛出什么类型的错误,它告诉我我缺少这些权限。

于 2011-11-19T07:13:43.870 回答