12

我在 Kotlin 中使用数据类来显着减少我必须编写的 Java 代码量。

但是,在我的一个 Java 类中,我不确定如何在 Kotlin 中实现相同的结果。

我的 Java 类看起来有点像这样:

public class DataObject {

    private int mId;
    private String mName;

    public DataObject(int id, String name) {
        mId = id;
        mName = name;
    }

    public DataObject(Context context, int id) {
        mId = id;
        Cursor cursor = ...
        cursor.moveToFirst();
        mName = cursor.getString(...);
        cursor.close();
    }

    public int getId() {
        return mId;
    }

    public String getName() {
        return mName;
    }

}

我试图用 Kotlin 重写它,到目前为止我有这个:

data class DataObject(val id: Int, val name: String) {

    constructor(context: Context, id: Int) : this(id, fetchName(context))

    private fun fetchName(context: Context): String {
        val cursor = ...
        cursor.moveToFirst()
        val name = cursor.getString(...)
        cursor.close()
        return name
    }

}

fetchName(context)但是我的 IDE(Android Studio)强调了我constructor用红色调用的部分。它显示以下消息:

fetchName在调用超类构造函数之前无法访问

我应该如何解决这个问题?

4

2 回答 2

19

您只能在完全构造的对象上使用成员函数。解决此问题的一种方法是使用私有扩展函数或仅使用函数来获取名称:

private fun Context.fetchName(): String {
    ///...
    return cursor.getString(1)
}

data class DataObject(val id: Int, val name: String) {
    constructor(context: Context, id: Int) : this(id, context.fetchName())
}

虽然我确实认为使用Cursor对于constructor. 我会Factory像这样单独使用:

data class DataObject(val id: Int, val name: String) {
    object FromCursorFactory {
        fun create(id: Int, context: Context): DataObject {
            val name = context.fetchName()
            return DataObject(id, name)
        }
    }
}

进一步阅读:

于 2016-07-20T12:32:24.927 回答
1

另一种方法是使用伴随对象。这也将允许您在数据类之外调用该函数(在您的特定情况下可能没有用)

data class DataObject(val id: Int, val name: String) {

  constructor(context: Context, id: Int) : this(id, fetchName(context))

  companion object {

    fun fetchName(context: Context): String {
      val cursor = ...
      ...
      return name
    }
  }
}
于 2020-01-15T15:11:10.763 回答