13
public class BobDatabase extends SQLiteOpenHelper{
private static final String DATABASE_NAME = "bob.db";
private static final int DATABASE_VERSION = 1;
public static final String DEFAULT_PROFILE = "default_profile";

public BobDatabase(Context context) 
{
    super(context, DATABASE_NAME, null, DATABASE_VERSION);
}

@Override
public void onCreate(SQLiteDatabase database) 
{
    createProfileTable(database);
    createTimeTable(database);
    createEventTable(database);
    createLocationTable(database);
}

/**
 * Creates a table for Profile objects, executes the string create_profile_table_sql
 * contained within strings.xml
 * @param database
 */
public void createProfileTable(SQLiteDatabase database)
{
    database.execSQL(Resources.getSystem().getString(R.string.create_profile_table_sql));
}}

我收到这个错误

01-14 12:20:57.591: E/AndroidRuntime(1825): 由: android.content.res.Resources$NotFoundException: 字符串资源 ID #0x7f040003

导致错误的代码是 createProfileTable 中的单行,特别是Resources.getSystem().getString(R.string.create_profile_table_sql)如果我使用类变量来保存 Context 并执行context.getString(R.string.create_profile_table_sql)我没有收到任何错误,但我不想这样做,因为我想避免内存泄漏,并且根据我知道这应该可以工作。知道发生了什么吗?

4

3 回答 3

30

根据 Android 文档,Resources.getSystem()仅提供系统级资源,而不是应用程序级资源(如您的 strings.xml 文件中的资源)。

http://developer.android.com/reference/android/content/res/Resources.html#getSystem()

如果您真的想以这种方式检索字符串,请尝试使用应用程序的上下文,或者在您的问题的评论中采纳我的建议。

于 2012-01-14T17:50:24.363 回答
7

使用 Resources.getSystem().getWhatEver() 您只能访问系统范围的资源(您会收到错误,因为您的 ID 没有系统范围的资源)。由于资源 ID 在应用程序中不是唯一的,因此您需要在访问资源时提供应用程序。在 Android 中,这是使用 Context 完成的。因此,如果您想访问某些资源,则需要像这样使用它

context.getResources().getString(myID);

除此之外,布兰登的评论是正确的。

于 2012-01-14T17:52:39.897 回答
1

您可以通过参数、静态变量或getApplicationContext()函数获取函数中的上下文参数。

于 2012-01-14T20:48:10.980 回答