Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/183.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/webpack/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 在数据库中使用Dagger2_Android_Database_Nullpointerexception_Dagger - Fatal编程技术网

Android 在数据库中使用Dagger2

Android 在数据库中使用Dagger2,android,database,nullpointerexception,dagger,Android,Database,Nullpointerexception,Dagger,我正在尝试在我的android应用程序中使用dagger2和数据库。我无法使用inject操作访问数据库类。我创建的数据库数据库对象返回null。我是匕首2的新手。谢谢你的帮助 这是我的数据库类 public class Database extends SQLiteOpenHelper { @Inject public Database(@ApplicationContext Context context) { super(context, Constants.DATABASE

我正在尝试在我的android应用程序中使用dagger2和数据库。我无法使用inject操作访问数据库类。我创建的数据库数据库对象返回null。我是匕首2的新手。谢谢你的帮助

这是我的数据库类

public  class Database extends SQLiteOpenHelper {


@Inject
public Database(@ApplicationContext Context context) {
    super(context, Constants.DATABASE_NAME, null, Constants.DATABASE_VERSION);
}

public void createTables(){..}

public void clearAllTables() {...}

public void dropTable(SQLiteDatabase db, String tableName){
    db.execSQL("DROP TABLE IF EXISTS " + tableName);
}

@Override
public void onCreate(SQLiteDatabase db) {.. }  .. }
这是我的模块

@Module abstract public class DatabaseModule {

private Application application;
public DatabaseModule(Application application) {
    this.application = application;
}
@Provides
@ApplicationContext
Context provideContext() {
    return application;
}}
和组件

@ActivityScope @Subcomponent public interface DatabaseSubcomponent {

@ApplicationContext
Context getContext();

Database getDb(); }
Db对象返回空值,如下所示:

   @Inject
Database db;

如果你能告诉我哪里出了错,我将不胜感激。提前感谢。

为自己定义一个范围注释器@DatabaseScope.java

@Scope
@Retention(RetentionPolicy.RUNTIME)
public @interface DatabaseScope {
}
public  class Database extends Object {

    public Database(Context context) {
        Log.e("database creted"," ");
    }

    String getmessage(){
        return "jenison";
    }

}
然后,DatabaseModule.java应该提供作为您的模块的上下文和数据库对象(在注入数据库对象期间,dagger会自动从对象图中为您注入上下文)

然后是DatabaseComponent.java。您不需要将其注释为子组件

@ActivityScope @Subcomponent public interface DatabaseSubcomponent {

@ApplicationContext
Context getContext();

Database getDb(); }
@DatabaseScope
@Component(modules = {DatabaseModule.class})
public interface DatabaseComponent {
    void inject(MainActivity mainActivity);
}
然后是您的数据库.java

@Scope
@Retention(RetentionPolicy.RUNTIME)
public @interface DatabaseScope {
}
public  class Database extends Object {

    public Database(Context context) {
        Log.e("database creted"," ");
    }

    String getmessage(){
        return "jenison";
    }

}
最后将其注入到您的活动中

public class MainActivity extends AppCompatActivity {

    @Inject
    Database db;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        DatabaseComponent component=DaggerDatabaseComponent.builder().databaseModule(new DatabaseModule(getApplication())).build();
        component.inject(this);
        Log.e("test"," "+db.getmessage());
    }
}