I have class mentioned below:
public class JsonHistoryList extends ArrayList<JsonHistory> implements Serializable{}
I wish to pass it through intent using
timerService.putExtra(TimerService.ACTIVITY_LIST_ARG, activities);
But after I receive it (way below)
JsonHistoryList temp = (JsonHistoryList) intent.getSerializableExtra(TimerService.ACTIVITY_LIST_ARG);
in my service it gives me exception:
Caused by: java.lang.ClassCastException: java.util.ArrayList cannot be cast to com.epstim.captime.jsonmodel.JsonHistoryList
I don't understand why java can't handle that operation.
I've changed my code in service to:
ArrayList<JsonHistory> temp = (ArrayList<JsonHistory>) intent.getSerializableExtra(TimerService.ACTIVITY_LIST_ARG);
activities.addAll(temp);
And it worked.
So if
JsonHistoryList extends ArrayList
, then aJsonHistoryList
is anArrayList
but anArrayList
is not necessarily aJsonHistoryList
. You expected your own subclass, but that's not what you got back.This happens if
intent.getSerializableExtra(TimerService.ACTIVITY_LIST_ARG);
returns an object of classArrayList<JsonHistory>
and not an object of typeJSONHistoryList
.We cannot forcefully downcast a parent object.
Consider your example,say
public class JsonHistoryList extends ArrayList implements Serializable{ public int someField ;// can by anything }
For simplicity, if your
getSerializableExtra();
returns,new ArrayList<JsonHistory>()
, when you try to downcast this toJsonHistoryList
, it cannot cast so becausesomeField
values cannot be determiniedIn the internals, android puts every extra in a special Map and doesn't record how exactly you want it parcelled.
At some point android will flattern your extras into parcel, and it will do so by checking each object type (since, as I said, it doesn't remember how you want it).
Parcel supports both writeList and writeSerializable and your JsonHistoryList is also both (list of serializables and a serialisable itself)
So android parcelling goes like this:
If you want to preserve list you need to create a class that will be serializable and won't extend arraylist but will contain it inside.
So composition over inheritance in case you want to preserve type
we cannot cast a superclass object into a sub-class object.
Cast is only possible if object which is to be casted passes the IS-A relationship.
you can have a look at this link.It will clear all doubts explicit casting from super class to subclass