Чтение и запись java.util.Date из класса Parcelable

Я работаю с классом Parcelable. Как я могу читать и писать java.util.Date возражать против этого класса?

5 ответов

Решение

Используйте writeSerializable, где Date является Сериализуемым. (Но не очень хорошая идея. Смотрите ниже для другого лучшего способа)

@Override
public void writeToParcel(Parcel out, int flags) {
   // Write object
   out.writeSerializable(date_object);

}

private void readFromParcel(Parcel in) {
   // Read object
    date_object = (java.util.Date) in.readSerializable();

}

Но операции сериализации требуют большой производительности. Как можно это преодолеть?

Поэтому лучше использовать для преобразования даты в Long во время записи, чтения Long и передачи в конструктор Date, чтобы получить Date. Смотрите ниже код

   @Override
    public void writeToParcel(Parcel out, int flags) {
       // Write long value of Date
       out.writeLong(date_object.getTime());

    }

    private void readFromParcel(Parcel in) {
       // Read Long value and convert to date
        date_object = new Date(in.readLong());

    }

В Kotlin мы можем создать расширение для Parcel - самое простое решение.

fun Parcel.writeDate(date: Date?) {
    writeLong(date?.time ?: -1)
}

fun Parcel.readDate(): Date? {
    val long = readLong()
    return if (long != -1L) Date(long) else null
}

И использовать это

parcel.writeDate(date)
parcel.readDate()

Используйте date.getTime() для получения длинного формата:

public class MiClass implements Parcelable {
    Date date;

    public MiClass(Date date) {
        this.date = date;
    }

    @Override
    public int describeContents() {
        return 0;
    }

    @Override
    public void writeToParcel(Parcel dest, int flags) {
        dest.writeLong(date != null ? date.getTime() : -1);
    }

    protected MiClass(Parcel in) {
        long tmpDate = in.readLong();
        this.date = tmpDate == -1 ? null : new Date(tmpDate);
    }

    public static final Parcelable.Creator<MiClass> CREATOR = new Parcelable.Creator<MiClass>() {
        public MiClass createFromParcel(Parcel source) {
            return new MiClass(source);
        }

        public MiClass[] newArray(int size) {
            return new MiClass[size];
        }
    };
}

Попробуйте это (Котлин):

data class DateParcel(val date: Date?):Parcelable {
constructor(parcel: Parcel) : this(parcel.readValue(Date::class.java.classLoader) as? Date
)

override fun writeToParcel(parcel: Parcel, flags: Int) {
    parcel.writeValue(date)
}

override fun describeContents(): Int {
    return 0
}

companion object CREATOR : Parcelable.Creator<DateParcel> {
    override fun createFromParcel(parcel: Parcel): DateParcel {
        return DateParcel(parcel)
    }

    override fun newArray(size: Int): Array<DateParcel?> {
        return arrayOfNulls(size)
    }
}}

Date реализует класс Serializable...

так что вы можете написать

parcel.writeSerializable(java.util.Date)

и вы можете читать как

java.util.Date date = (java.util.Date)parcel.readSerializable();

Попробуйте это следующим образом:

для записи::

yourParse.writeSerializable(YourGivenDate)

для чтения::

Date myDate = yourParse.readSerializable();
Другие вопросы по тегам