質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

91.26%

  • Android

    5369questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

  • JSON

    806questions

    JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

  • Kotlin

    119questions

    Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。

KotlinでJsonをパースするのに時間が掛かりすぎて困っています

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 81

HAL316

score 0

前提

サーバとWebAPIでやり取りするAndroidアプリを作るにあたって必要なJsonのパースについての質問です。
パースした後にViewに詰め込んで表示してみたのですが、想定していたより表示されるタイミングが数秒遅くて原因を調べるためにパースの部分だけを切り出してみました。
Jsonはコードの中に直接書き込んでありますが、この程度のJsonでもパース(或いは初期化)に時間がかかるものなのでしょうか?
使い方がおかしいのでしょうか?
二度連続して同じjsonをパースすると二度目は10ミリ秒程度でした。

  • ZTE Blade V7Lite(Android6.0)で3000ミリ秒前後
  • X06HT HTC Desire(Android4.4.1)で6000ミリ秒前後
  • Genymotion Google Pixel(Android7.1.0)で600ミリ秒前後

Logcat

12-19 18:05:30.946 17683-17683/jackson.sample D/MainActivity: START
12-19 18:05:33.781 17683-17683/jackson.sample D/MainActivity: END
12-19 18:05:33.782 17683-17683/jackson.sample D/MainActivity: 掛かった時間: 2835
12-19 18:05:33.782 17683-17683/jackson.sample D/MainActivity: My name is Satoshi.
12-19 18:05:33.782 17683-17683/jackson.sample D/MainActivity: My name is Ken.
12-19 18:05:33.782 17683-17683/jackson.sample D/MainActivity: My name is Yoppy.
12-19 18:05:33.782 17683-17683/jackson.sample D/MainActivity: My name is Satoshi.
12-19 18:05:33.782 17683-17683/jackson.sample D/MainActivity: My name is Ken.
12-19 18:05:33.782 17683-17683/jackson.sample D/MainActivity: My name is Yoppy.
12-19 18:05:33.782 17683-17683/jackson.sample D/MainActivity: My name is Satoshi.
12-19 18:05:33.782 17683-17683/jackson.sample D/MainActivity: My name is Ken.
12-19 18:05:33.782 17683-17683/jackson.sample D/MainActivity: My name is Yoppy.

build.gradle (Module: app)

dependencies {
    // 追記してSync済み
    compile "com.fasterxml.jackson.module:jackson-module-kotlin:2.9.0"
}

MainActivity.kt

package jackson.sample

import android.os.Bundle
import android.support.v7.app.AppCompatActivity
import android.util.Log
import com.fasterxml.jackson.module.kotlin.jacksonObjectMapper
import com.fasterxml.jackson.module.kotlin.readValue

class MainActivity : AppCompatActivity() {

    val json = """
{
    "info": {
        "total": 9
    },
    "posts": [
        {
            "id": 1,
            "body": "Hello",
            "author": {
                "id": 1,
                "name": "Satoshi",
                "profile": {
                    "body": "My name is Satoshi."
                }
            }
        },
        {
            "id": 2,
            "body": "Hello",
            "author": {
                "id": 2,
                "name": "Ken",
                "profile": {
                    "body": "My name is Ken."
                }
            }
        },
        {
            "id": 3,
            "body": "Hello",
            "author": {
                "id": 3,
                "name": "Yoppy",
                "profile": {
                    "body": "My name is Yoppy."
                }
            }
        },
        {
            "id": 11,
            "body": "Hello",
            "author": {
                "id": 1,
                "name": "Satoshi",
                "profile": {
                    "body": "My name is Satoshi."
                }
            }
        },
        {
            "id": 12,
            "body": "Hello",
            "author": {
                "id": 2,
                "name": "Ken",
                "profile": {
                    "body": "My name is Ken."
                }
            }
        },
        {
            "id": 13,
            "body": "Hello",
            "author": {
                "id": 3,
                "name": "Yoppy",
                "profile": {
                    "body": "My name is Yoppy."
                }
            }
        },
        {
            "id": 21,
            "body": "Hello",
            "author": {
                "id": 1,
                "name": "Satoshi",
                "profile": {
                    "body": "My name is Satoshi."
                }
            }
        },
        {
            "id": 22,
            "body": "Hello",
            "author": {
                "id": 2,
                "name": "Ken",
                "profile": {
                    "body": "My name is Ken."
                }
            }
        },
        {
            "id": 23,
            "body": "Hello",
            "author": {
                "id": 3,
                "name": "Yoppy",
                "profile": {
                    "body": "My name is Yoppy."
                }
            }
        }
    ]
}
"""

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
    }

    override fun onResume() {
        super.onResume()
        parseJson(json)
    }

    private fun parseJson(json: String) {
        Log.d(TAG, "START")
        val start: Long = System.currentTimeMillis()
        val result = mapper.readValue<PostsResult>(json)
        val end: Long = System.currentTimeMillis()
        Log.d(TAG, "END")
        val interval = end - start
        Log.d(TAG, "掛かった時間: " + interval.toString())
        result.posts?.let { posts ->
            for (post in posts) {
                Log.d(TAG, post.author!!.profile!!.body)
            }
        }
    }

    companion object {
        val TAG = MainActivity::class.java.simpleName
        val mapper = jacksonObjectMapper()
    }
}

Model.kt

package jackson.sample

data class PostsResult(val info: Info, val posts: List<Post>?) {
    data class Info(val total: Int)
}
data class Post(val id: Int?, val author: Author?, val body: String?)
data class Author(val id: Int?, val name: String?, val profile: Profile?)
data class Profile(val body: String?)

試したこと

  • jacksonObjectMapper()をcompanion objectではなく使用する直前に変えた -> 変わらず
  • パースを二度連続してやってみた -> 二度目は速い
  • data classでnullableを使っているので遅いのかと思い、?を取ってみた -> 変わらず

補足情報(言語/FW/ツール等のバージョンなど)

  • Kotlin
  • Android Studio3.0.1
  • FasterXML/jackson-module-kotlin
  • 機種:ZTE BLADE V7Lite, Desire HTC X06HT, Genymotion Google Pixel
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

check解決した方法

0

解決とは言えないかもしれませんが、Jacksonの使用をやめ、Gsonを使うことにしました。
Jacksonの使い方が間違っていただけ or 用途違いかもしれませんが、Gsonを使うことで想定内の時間でパースできました。

githubのissueでも同じように初回パースが極めて遅いことへの言及がありました。
First initialization jacksonObjectMapper() and first parse of .readValue is quite slow #69
https://github.com/FasterXML/jackson-module-kotlin/issues/69

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

ただいまの回答率

91.26%

関連した質問

同じタグがついた質問を見る

  • Android

    5369questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

  • JSON

    806questions

    JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

  • Kotlin

    119questions

    Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。