Существует ArrayList, который имеет вложенные HashMaps. Получить значение из родительского HashMap легко, но когда я пытаюсь получить значение из вложенного HashMap (child), я получаю ClassCastException. Вот пример того, как это выглядит (похоже на предыдущий пост):
ArrayList<HashMap<String, Object>> data = new ArrayList<HashMap<String, Object>>();
HashMap<String, Object> parentHash = new HashMap<String, Object>();
HashMap<String, String> childHash = new HashMap<String, String>();
childHash.put("child_id", "id")
childHash.put("name", "first last");
childHash.put("sex", "man");
parentHash.put("parent_id", "id");
parentHash.put("name", "first last");
parentHash.put("sex", "woman");
parentHash.put("children", childHash);
data.add(parentHash);
Для приведения я использую следующий код (к сожалению, я получаю ClassCastException):
Map<String, String> fetchedChildData = (Map<String, String>) data.get(position).get("children");
showAlert("Test", "Ok", (String) fetchedChildData.get("child_id"));
Может кто-нибудь сказать мне, что я здесь делаю не так?
Errorlist:
04-03 17:34:01.640: W/dalvikvm(26248): threadid=1: thread exiting with uncaught exception (group=0x4001e578)
04-03 17:34:01.645: E/AndroidRuntime(26248): FATAL EXCEPTION: main
04-03 17:34:01.645: E/AndroidRuntime(26248): java.lang.ClassCastException: java.util.ArrayList
04-03 17:34:01.645: E/AndroidRuntime(26248): at com.on_d_mand.live_dashboard.EventListMenu$2.onItemClick(EventListMenu.java:265)
04-03 17:34:01.645: E/AndroidRuntime(26248): at android.widget.AdapterView.performItemClick(AdapterView.java:284)
04-03 17:34:01.645: E/AndroidRuntime(26248): at android.widget.ListView.performItemClick(ListView.java:3740)
04-03 17:34:01.645: E/AndroidRuntime(26248): at android.widget.AbsListView$PerformClick.run(AbsListView.java:1992)
04-03 17:34:01.645: E/AndroidRuntime(26248): at android.os.Handler.handleCallback(Handler.java:587)
04-03 17:34:01.645: E/AndroidRuntime(26248): at android.os.Handler.dispatchMessage(Handler.java:92)
04-03 17:34:01.645: E/AndroidRuntime(26248): at android.os.Looper.loop(Looper.java:130)
04-03 17:34:01.645: E/AndroidRuntime(26248): at android.app.ActivityThread.main(ActivityThread.java:3691)
04-03 17:34:01.645: E/AndroidRuntime(26248): at java.lang.reflect.Method.invokeNative(Native Method)
04-03 17:34:01.645: E/AndroidRuntime(26248): at java.lang.reflect.Method.invoke(Method.java:507)
04-03 17:34:01.645: E/AndroidRuntime(26248): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:912)
04-03 17:34:01.645: E/AndroidRuntime(26248): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:670)
04-03 17:34:01.645: E/AndroidRuntime(26248): at dalvik.system.NativeStart.main(Native Method)