Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
決戦Kotlinコンバート
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Takuya Ohashi
May 07, 2018
Technology
480
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
決戦Kotlinコンバート
Javaで書いてた人間が急にKotlinでコンバートした際のハマった事集です。
Takuya Ohashi
May 07, 2018
More Decks by Takuya Ohashi
See All by Takuya Ohashi
冴えない彼女の育て方から学ぶ情熱と合理性の使い分け
pg0084
0
540
モバイルアプリでの Amazon Cognito のすゝめ
pg0084
2
540
Android近距離通信のあれこれ
pg0084
0
550
Other Decks in Technology
See All in Technology
本当の”仕事”を手放せる未来が見えた
mu7889yoon
0
190
Zenoh on Zephyr on LiteX
takasehideki
2
130
2026 AI Memory Architecture
nagatsu
0
580
GitHub Copilot運用のリアル ~AI Credit時代にどう向き合うか~
takafumisu2uk1
0
490
[チョークトーク資料]AWS DevOps Agent を使いこなす / AWS Dev Ops Agent Chalk Talk AWS Summit Japan 2026
kinunori
4
810
そこにあるから地図ができる~位置を示す"モノ"を愉しむ~ - Interface 2026年6月号GPS特集オフ会 / interface_202606_GPS_offline
sakaik
1
120
Microsoft のサポートとフィードバック総まとめ
murachiakira
PRO
0
120
從觀望到全公司落地:AI Agentic Coding 導入實戰 — 流程整合與安全治理
appleboy
0
170
製造現場での生成AIの活用、およびエージェントAIの実装のあり方、AVEVAの取り組み
iotcomjpadmin
0
180
スタートアップにAmazon EKSは早すぎる? マルチプロダクト戦略を加速する Platform Engineeringの実践 / Is Amazon EKS Too Soon for Startups? Practical Platform Engineering to Accelerate a Multi-Product Strategy
elmodev09
1
1.9k
クレデンシャル流出 ― 攻撃 3 時間 vs 復旧 10 時間。この非対称性にどう備えるか
kazzpapa3
3
620
[AWS Summit Japan 2026]迷っているあなたへ_小さな一歩が、やがて自分を助けてくれる
sh_fk2
2
430
Featured
See All Featured
エンジニアに許された特別な時間の終わり
watany
107
250k
From Legacy to Launchpad: Building Startup-Ready Communities
dugsong
0
240
Mind Mapping
helmedeiros
PRO
1
260
svc-hook: hooking system calls on ARM64 by binary rewriting
retrage
2
310
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4.3k
So, you think you're a good person
axbom
PRO
2
2.1k
Mozcon NYC 2025: Stop Losing SEO Traffic
samtorres
1
260
Digital Ethics as a Driver of Design Innovation
axbom
PRO
1
330
brightonSEO & MeasureFest 2025 - Christian Goodrich - Winning strategies for Black Friday CRO & PPC
cargoodrich
3
740
Self-Hosted WebAssembly Runtime for Runtime-Neutral Checkpoint/Restore in Edge–Cloud Continuum
chikuwait
0
620
Leading Effective Engineering Teams in the AI Era
addyosmani
9
2.1k
The Invisible Side of Design
smashingmag
301
52k
Transcript
決戦Kotlinコンバート MobileAct osaka #4 @pg0084
自己紹介 ・オオハシタクヤ @pg0084 ・フェンリルに所属 Androidエンジニア ・趣味はマクドナルド
2月8日DroidKaigi2018 最高カンファレンスでした。
しかし・・・。
Kotlinを知らない Androidアプリエンジニアに 人権がない!!
ということでJavaのプロジェクトを Kotlinコンバートしてみた
Javaファイル数約560
今回は約500ファイルをコンバート 将来的には全Kotlin化を目指します。
目次 1. kaptでビルドが通らない?Lombokの罠! 2. IcepickがKotlinに対応していない件につきまして 3. Interfaceの実装方法がバラバラだと困るSAM変換 4.値が更新されない?by lazyでfindVIew 5.コメントが入れ子にできる仕様で30秒思考停止
6.気の利いた謎のコンバート
Kaptでビルドが通らない? Lombokの罠!
Lombokとは アノテーションを付けるだけで、 getterやsetter、コンストラクターまで生 成してくれる便利ライブラリ。 @Getter @Setter @Data @AllArgsConstructor など
kaptとLombok の相性が悪いらしく Lombok で実装しているクラスのメンバはprivateなのでSetter、Getter にアクセスできないと言われ、ビルドエラーに。 ※この段階ではまだ1ファイルもコンバートしていません。 原因
とった策 将来的に全Kotlin化を想定しているのでLombokのアノテーションを全て外す Lombokを使っているクラスだけで300近くあるから手動は大変! delombokが便利! lombok.jarを使って以下のようなコマンドを打つだけ! 念のために別ディレクトリにdelombokされたファイルを出力します。 java -jar lombok.jar delombok
-f pretty {対象ディレクトリ} -d {出力先ディレクトリ}
Icepickが対応していない件につきまして
Icepickとは AndroidではActivityなどの破棄により、入力した値が破棄される。 状態の保存/復元をサポートするアノテーションライブラリ。 保持したい変数に@Stateをつけ、saveInstanceStateと restoreInstanceStateを呼んであげるだけ! 超便利なライブラリ。 Kotlinだと@JvmField アノテーションをつけないと動作しない! setter/getterではないField変数をそのまま公開しないといけなくなる ので何とも言えない気持ちになる
Icepickをandroid-stateに置き換え @Override public void onCreate(Bundle savedInstanceState) { Icepick.restoreInstanceState(this, savedInstanceState); }
@Override public void onSaveInstanceState(Bundle outState) { Icepick.saveInstanceState(this, outState); } Before
Icepickをandroid-stateに置き換え override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) } override fun
onSaveInstanceState(outState: Bundle?) { StateSaver.saveInstanceState(this, outState); } After
値が更新されない? by lazyでfindview
例えばこんなの val myTextView: TextView by lazy{ findViewById(R.id.my_text)} 参考:https://qiita.com/takahirom/items/49e18ec7084bb3b1937e 遅延初期化で利用できます。 が・・・。
バックスタックで戻った際やTabLayoutなどで開きなおした後に値を差し変 たいのに見た目が変わらない。
対策 lateinit var myTextView : TextView … override fun onCreate(savedInstanceState:
Bundle?) { super.onCreate(savedInstanceState) myButton = findViewById(R.id.my_text) 参考:https://qiita.com/takahirom/items/49e18ec7084bb3b1937e lateinitで実装するのが一般的のようです。
実装方法がバラバラだと困るinterfaceとSAM変換
SAM変換って? SAMとはSingle Abstract Methodの略で、SAMインターフェースは、 一つだけ抽象メソッドをもつインターフェースです。 button.setOnClickListener(object: View.OnClickListener { public override
fun onClick(v: View) { Log.v(TAG, "clicked") } });} button.setOnClickListener{ v -> Log.v(TAG, "clicked") } 下のように記述できる
Kotlin化が進んでくると class MyButton (context: Context) : android.support.v7.widget.AppCompatButton(context) { private var
listener: MyBtClickListener? = null init { setOnClickListener { v -> listener?.onMyButtonClick(v.toString()) } } internal interface MyBtClickListener { fun onMyButtonClick(v: String) } //リスナーを追加するメソッド fun set MyBtClickListener(listener: MyBtClickListener) { this.listener = listener } } こんなクラスがあるとします。
呼び出し方 Interfaceも呼び出す側もKotlinの場合 myButton.setMyListener{v->Log.d("hogehoge", v.toString())}. ビルドエラーになります。
こういう書き方にできる private var listener:((v: String)->Unit)? = null init { setOnClickListener
{ v -> listener?.invoke(v.toString()) } } myButton.setMyListener{v->Log.d("hogehoge", v.toString())}. ビルドが通って思った通りに動きます。
実装の仕方がバラバラだとハマる可能性 同じinterfaceを実装している場合、2パターンの実装している場合もあ る。 コンバートした後にinterfaceのまま残すか、関数型にして実装方法を 統一しなくてはいけない。 class MainActivity : AppCompatActivity(),MyButton.MyBtClickListener{ override
fun onMyButtonClick(v: View) { Log.d("hogehoge", v.toString()) } myButton.setMyListener{v->Log.d("hogehoge", v.toString())}.
コメントが入れ子にできる仕様で 30秒くらいフリーズした話
Kotlinではブロックコメントが入れ子にできる 入れ子になっていることにぱっと見気がつかない コメントで /*.XML とか書いてあったらコンバート後に間違い探しが発生!30秒思考 停止。 /** * /src/layout/*.xml */
Class MainActivity: AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) }
気の利いた謎のコンバート
例えばこんなの class Hoge{ private String param1; private String param2; public
Hoge(String parm1, String param2){ this.param1 = param1; this.param2 = param2; } } Hoge hoge = new Hoge(param1, null); Javaであえてnullを渡している処理が書いてあった。 そもそもnullをあえて渡しているのもどうかと思う人も多いと思いますが、 コンバートした結果
コンバート結果 class Hoge(val parm1: String, val param2: String) { }
val hoge = Hoge(param1, null!!) !! を付与ることでNotNullに変換することができる
null!!
まとめ Kotlinコンバートは思ったより手間がかかる
ご清聴ありがとうございました