为什么我会在我的SQLiteOpenHelper构造函数中获得"不兼容的类型:Bla无法转换为Context"?

B. *_*non 2 java sqlite android sqliteopenhelper android-sqlite

我正在使用本教程在我的Android项目中实现SQLite功能.

我有这个SQLiteOpenHelper代码:

public class HHSSQLiteHandler extends SQLiteOpenHelper {

    private static final int DATABASE_VERSION = 1;
    private static final String DATABASE_NAME = "HHS.db";
    private static final String TABLE_VENDORS = "vendors";

    public static final String COLUMN_ID = "_id";
    public static final String COLUMN_VENDORID = "vendorId";
    public static final String COLUMN_COMPANYNAME = "companyName";

    public HHSSQLiteHandler(Context context, String vendor,
                       SQLiteDatabase.CursorFactory factory, int company) {
        super(context, DATABASE_NAME, factory, DATABASE_VERSION);
    }
    . . .
Run Code Online (Sandbox Code Playgroud)

...但尝试以这种方式实例化该类:

protected void onPostExecute(String result) {
    try {
        JSONArray jsonArr = new JSONArray(result);
        for (int i = 0; i < jsonArr.length(); i++) {
            JSONObject jsonObj = jsonArr.getJSONObject(i);
            String vendorId = jsonObj.getString("vendorId");
            String companyName = jsonObj.getString("companyName");
            // Prepare for writing to db
            Vendor vend = new Vendor();
            vend.setVendorId(vendorId);
            vend.setCompanyName(companyName);
            HHSSQLiteHandler sqliteHandler = new HHSSQLiteHandler(this, null, null, 1);
            sqliteHandler.addVendor(vend);
        }
    } catch (JSONException j) {
        System.out.println(j.getMessage());
        Log.i("jsonEx", j.getMessage());
    }
}
Run Code Online (Sandbox Code Playgroud)

...给我,"错误:不兼容的类型:MainActivity.GetVendorsTask无法转换为上下文"在"HHSSQLiteHandler sqliteHandler = new HHSSQLiteHandler(this,null,null,1);" 线.

究竟是什么期待?我该通过什么来安抚它呢?

laa*_*lto 8

this在嵌套类中引用嵌套类instance(GetVendorsTask),而不是外部类instance(MainActivity).通过例如MainActivity.this引用外部类实例来限定它,并且如果它是Context(例如Activity),它将起作用.