*

[android] JSONのパースにかかる時間

公開日: : 最終更新日:2013/03/27 android

リストデータなんかを保存したいというのはよくある要件だと思います。
DBは面倒だしカラム毎に集計するだとかDBっぽい要件もないので、オブジェクトをJSONに変換して保存しようかと思ったのですが、ロード時のパフォーマンスがでるのか心配だったのでorg.json.JSONArrayによるJSONのパースにかかる時間を測ってみました。
シリアライズという選択肢もあるっぽいのですが、
 JSONなら他の環境とも親和
 他の言語にも応用できそう
 なんか難しそう
なのでJSONの方向で考えてみました。

[条件]

・10,000件のデータを3種類な階層を持ったオブジェクトに格納(3種類は結果参照)。
・assetsにテキストファイルとして保存したJSONをロード
・オブジェクト内のデータは”keyN”:”valueN”といった短い文字列
・端末はGalaxyNexus
・OSバージョンは4.1
・計測のサンプルは3つ
・単位はms

[結果]

・1階*10,000件 (平たい)
階層1のオブジェクトを10,000件

パースのみ:484,368,330
ロード込み:794,650,616

・10階*10件*100件 (中間)
1階層あたり10件の文字列データを持ったオブジェクトを10階層。
これをさらに100件。計10,000件。

パースのみ:330,261,209
ロード込み:490,385,309

・250*1 (深い)
250階層のオブジェクトを1件。

パースのみ:5(200),7(280),5(200)
ロード込み:9(360),13(520),8(320)

※階層の深いJSONをパースしようとするとStackOverflowErrorが発生。
詳しい条件はわかりませんが、今回は少なくとも300階層以上のJSONのパースでエラーとなりました。
この結果のみデータ件数が250件なので、カッコ()内に40倍(250*40=10,000件)の値を表記しています。

[結論]

今回の結果のみで考察しました。

・パースのみであれば1万件あたりせいぜい500ms未満
・件数が同じであれば平たいデータの方がパース時間が長い傾向がある
・階層は250以下にすべし

以上

関連記事

no image

【android】 adbコマンド集

●adbサービス起動 adb start-server ●adbサービス終了 adb

記事を読む

no image

【android】webviewでアプリ内にwebページを読み込む

webviewを使ってandroidアプリ内にwebページを読み込む定型文です。 //vie

記事を読む

no image

【android】ホーム画面や他のアプリの前面にViewを表示する。

WindowManagerのTYPE_SYSTEM_ALERTのレイヤーにViewを表示することで、

記事を読む

no image

【android】リソースからいろいろ取得する

リソースで定義したいろいろをコード内で呼び出す方法です。 レイアウト //リソースからレ

記事を読む

no image

【android】stringsリソースにパラメータを埋め込む

●strings.xml %n$x n : 引数に渡す際の順番。n番目の引数。 x

記事を読む

no image

[android] ActivityとFragmentのライフサイクルいろいろ

Fragmentを使い始めてライフサイクル関係でハマることがあったので備忘録。 FragmentA

記事を読む

no image

【android】IMEの表示/非表示

//IMEを閉じる InputMethodManager inputMethodManager

記事を読む

no image

【android】言語・地域設定の取得

androidでは利用する言語と国名がjava.util.Localeのオブジェクトとして設定されて

記事を読む

no image

【android】アプリのバージョン情報を取得する

int versionCode = -1; String versionName = &quo

記事を読む

no image

【android】ネットワークの接続状況を確認する

コードから接続状況を確認。 ConnectivityManager co

記事を読む

Message

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

次のHTML タグと属性が使えます: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <s> <strike> <strong>

no image
知らないと損をする6つのライセンスまとめ

オープンソースやフリーウェア、フリー素材などが巷に溢れ、それらを利用す

no image
ガリレオ:ニュースブラウザをリリースしました。

概要 ガリレオはニュースを読んだり、検索する機能に特化したブラウザア

no image
【android】Activityとプロセスのライフサイクル

またもやライフサイクル周りでハマったのですが、Androidのライフサ

→もっと見る

PAGE TOP ↑