「Jank」の版間の差分
Administrator (トーク | 投稿記録) (→概要 ) |
Administrator (トーク | 投稿記録) (→回避策) |
||
11行目: | 11行目: | ||
=== 非同期化 === | === 非同期化 === | ||
頑張って、可能な限り、非同期処理を使いまくり[[プログラム]]を実装する。 | 頑張って、可能な限り、非同期処理を使いまくり[[プログラム]]を実装する。 | ||
+ | これによりメインスレッドの負荷が激減する。 | ||
+ | |||
[[マルチスレッド]]や[[非同期処理]]に精通していない[[プログラマー]]に実装させると[[バグ]]だらけになる[[諸刃の剣]]である。 | [[マルチスレッド]]や[[非同期処理]]に精通していない[[プログラマー]]に実装させると[[バグ]]だらけになる[[諸刃の剣]]である。 | ||
+ | |||
+ | また、第三者の作ったバックグラウンドアプリが高負荷をかけてくるような状況ではどうにもならない。 | ||
+ | Androidであればプリインストールアプリなんかが悪さをする場合も結構ある。 | ||
=== ジャンクリデューサー === | === ジャンクリデューサー === | ||
このジャンク問題を軽減すべく、最近の[[Snapdragon]]の一部製品(型番の末尾に「G」が付く製品。[[Snapdragon 765G]]など)には「Jank Reducer」なる機能が搭載されている。これは大雑把にいえばGPUが一定の固定フレームレートを下回ったら「仕事がこねえ」「ジャンク発生したな」と判断し勝手にドローする機能のようだ。 | このジャンク問題を軽減すべく、最近の[[Snapdragon]]の一部製品(型番の末尾に「G」が付く製品。[[Snapdragon 765G]]など)には「Jank Reducer」なる機能が搭載されている。これは大雑把にいえばGPUが一定の固定フレームレートを下回ったら「仕事がこねえ」「ジャンク発生したな」と判断し勝手にドローする機能のようだ。 |
2021年11月17日 (水) 02:39時点における版
Jank(読み:じゃんく)とは、メインスレッドに高負荷がかかり、ユーザーインターフェースがフリーズしたような状態になる現象のことである。
概要
一般的にドローコールはメインスレッド(UIスレッドとも呼ばれる)でしか実行できない。これはWindowsでもmacOSでもiOSでもAndroidでも.NETでもJavaでも同じだ。
たとえば8コア(8スレッド)のハードウェアであってもOSにメインスレッドは常にひとつしかない。このためメインスレッドに強烈な高負荷がかかると処理の糞詰まりを引き起こし、ドローコールがいつまで経っても呼ばれず、GPUはスカスカなのに仕事がこないため、結果として画面が更新されずガクガクになる。
ジャンクは主にシングルスレッド性能が低く、コア数の多さで性能を盛ってるスマートフォンのCPU(SoC)で好発する。ジャンクはAndroidがガクガクになる主たる原因である。iOSではジャンクが発生するアプリの作りだとAppStoreの審査で蹴られるのであまり問題になることはない。
回避策
非同期化
頑張って、可能な限り、非同期処理を使いまくりプログラムを実装する。 これによりメインスレッドの負荷が激減する。
マルチスレッドや非同期処理に精通していないプログラマーに実装させるとバグだらけになる諸刃の剣である。
また、第三者の作ったバックグラウンドアプリが高負荷をかけてくるような状況ではどうにもならない。 Androidであればプリインストールアプリなんかが悪さをする場合も結構ある。
ジャンクリデューサー
このジャンク問題を軽減すべく、最近のSnapdragonの一部製品(型番の末尾に「G」が付く製品。Snapdragon 765Gなど)には「Jank Reducer」なる機能が搭載されている。これは大雑把にいえばGPUが一定の固定フレームレートを下回ったら「仕事がこねえ」「ジャンク発生したな」と判断し勝手にドローする機能のようだ。