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
8年物のJavaのシステムをKotlinに変えていく選択に至るまで
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Atsushi Takayama
November 05, 2021
Technology
1.1k
2
Share
8年物のJavaのシステムをKotlinに変えていく選択に至るまで
Atsushi Takayama
November 05, 2021
More Decks by Atsushi Takayama
See All by Atsushi Takayama
最高の開発者体験の追求が開発生産性を改善し続ける文化を生み出した話
edvakf
3
1.6k
NeurIPS 2021 論文読み会: How Modular should Neural Module Networks Be for Systematic Generalization?
edvakf
0
220
ピクシブ社内のImageFlux利用事例紹介
edvakf
2
3k
学びの文化を育む社内読書会のススメ
edvakf
0
310
フルCDNアーキテクチャでサービス設計した話
edvakf
5
4.1k
Goでバイナリを読む+α
edvakf
1
1k
お前はこれまでに作ったAPIの数を覚えているのか?
edvakf
0
2.7k
「ふつうのRailsアプリケーション」についての考え方
edvakf
2
930
ggplot.galleryというお遊びウェブアプリケーションを作った話
edvakf
0
430
Other Decks in Technology
See All in Technology
バイブコーディングで3倍早く⚪⚪を作ってみた
samakada
0
120
需要創出(Chatwork)×供給(BPaaS) フライホイールとMoat 実行能力の最適配置とAI戦略
kubell_hr
0
840
ニックトレイン2026[名古屋]
furutaatsuya
0
110
目的ファーストのハーネス設計 ~ハーネスの変更容易性を高めるための優先順位~
gotalab555
8
2.4k
巨大プラットフォームを進化させる「第3のROI」
recruitengineers
PRO
2
1.2k
コードや知識を組み込む / Incorporate Code and Knowledge
ks91
PRO
0
170
AzureのIaC管理からログ調査まで、随所に役立つSkillsとCustom-Instructions / Boosting IaC and Log Analysis with Skills
aeonpeople
0
260
AWS DevOps Agentはチームメイトになれるのか?/ Can AWS DevOps Agent become a teammate
kinunori
6
770
データ定義の混乱と戦う 〜 管理会計と財務会計 〜
wonohe
0
140
AI와 협업하는 조직으로의 여정
arawn
0
510
Rapid Start: Faster Internet Connections, with Ruby's Help
kazuho
2
770
AI駆動1on1〜AIに自分を育ててもらう〜
yoshiakiyasuda
0
150
Featured
See All Featured
Evolving SEO for Evolving Search Engines
ryanjones
0
180
DBのスキルで生き残る技術 - AI時代におけるテーブル設計の勘所
soudai
PRO
64
54k
Large-scale JavaScript Application Architecture
addyosmani
515
110k
Build The Right Thing And Hit Your Dates
maggiecrowley
39
3.1k
A Soul's Torment
seathinner
6
2.7k
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
0
1.2k
Chasing Engaging Ingredients in Design
codingconduct
0
170
Building Experiences: Design Systems, User Experience, and Full Site Editing
marktimemedia
0
480
Digital Ethics as a Driver of Design Innovation
axbom
PRO
1
270
We Are The Robots
honzajavorek
0
220
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4.2k
The Impact of AI in SEO - AI Overviews June 2024 Edition
aleyda
5
810
Transcript
8年物のJavaのシステムをKotlinに 変えていく選択に至るまで Server-Side Kotlin Lounge #1 2021.11.04
会社紹介 & 自己紹介 NewsPicksとKotlin 開発者体験とKotlin 会社のメイン開発言語を変えるということ なぜ「NewsPicksは」開発言語を変更するのか これから 01 02
03 04 05 06 2 目次
会社紹介 & 自己紹介 NewsPicksとKotlin 開発者体験とKotlin 会社のメイン開発言語を変えるということ なぜ「NewsPicksは」開発言語を変更するのか これから 01 02
03 04 05 06 3 目次
None
None
None
None
自己紹介 8 高山温 2020年にNewsPicksにCTOとして入社しました。 会社の長期的な競争力に繋がる技術的方針を担当。 「開発者体験」信者。 開発者体験を上げて 開発者がどんどん高速に開発できるようになることが、 どの会社にとっても最重要の注力技術。
Developers Summit 2021
その他の発信
会社紹介 & 自己紹介 NewsPicksとKotlin 開発者体験とKotlin 会社のメイン開発言語を変えるということ 改めて、なぜ「NewsPicksは」開発言語を変更するのか これから 01 02
03 04 05 06 11 目次
現Chief Product Officerの文字(もんじ)が 2017年にサーバーサイドKotlinについて発信
None
NewsPicks アカデミア 検索基盤 課金基盤 JobPicks レコメンド NewsPicks
2021年8月 NewsPicks本体と呼ばれる メインのシステムで Kotlinを使えるように 今後は段階的に移行予定 15
会社紹介 & 自己紹介 NewsPicksとKotlin 開発者体験とKotlin 会社のメイン開発言語を変えるということ 改めて、なぜ「NewsPicksは」開発言語を変更するのか これから 01 02
03 04 05 06 16 目次
開発者体験を後押しする数々の言語機能 17 今更ですが • null安全 • イミュータブル • 高階関数 •
代数的データ型 • Javaとの親和性 • etc.
社内の開発者の声(続き) 18 書きやすい やっぱボイラープレートコードが減る! 入門しやすい (良い意味で)Javaとそんなに変わらない! IntelliJでJavaからKotlinにコピペしたら自動変換される! モダン C#だと遙か昔から当たり前にできてたことがちゃんとできる! (逆にJavaは最新版でもそこまで行ってない)
ぶっちゃけどっちでもいい 書く必要があれば書くし、必要が無ければ書かないし
社内の開発者の声 19 「ぶっちゃけどっちでもいい」 • この意見はすごく重要 • アーリーアダプターの皆さんが思うほど、他の人は気にしてない • しかし、「絶対NG!!」は無かった ◦
Java→(Go, Ruby, PHP, Erlang, Rust, etc.) だとあるはず ◦ Java→Scalaでもウィザード以外はチョットツライ ◦ これも開発者体験
会社紹介 & 自己紹介 NewsPicksとKotlin 開発者体験とKotlin 会社のメイン開発言語を変えるということ 改めて、なぜ「NewsPicksは」開発言語を変更するのか これから 01 02
03 04 05 06 20 目次
開発言語は会社の重要戦略 21 そもそも開発言語を増やすのは高くつく • Googleは数万人規模になるまでメイン開発言語は C++, Java, Python, JavaScript だけ
◦ 最近 Go も追加 • 他のGAFAも似たような状況 多くの会社にとって、開発言語選択は数年に1回あるか無いか • 完全な移行はまず無い。長期間併存する前提 • 社内文化がどうしても分断されがち • 金銭的にも大きな投資 • 間違った選択をしたときの長期的リスクが大きい → ほとんどのケースでは移行なんてしないほうが合理的
会社紹介 & 自己紹介 NewsPicksとKotlin 開発者体験とKotlin 会社のメイン開発言語を変えるということ 改めて、なぜ「NewsPicksは」開発言語を変更するのか これから 01 02
03 04 05 06 22 目次
チームビジョン “個の強みを活かす。 ワクワクしながら 不確実性に飛び込む。 現状維持ではなく、 未来を創るための挑戦をしよう。”
「NewsPicksにとっては」Kotlinは合理的な選択 24 Java→Kotlin がメンバーにとって自然だった • アーリーアダプターにとってはテンションが上がる • 「絶対NG!!」が居ない 4年以上積み上げたボトムアップの実績 •
「非公式」から「公式」になることで、その流れが加速 • トップダウンだけでもボトムアップだけでもうまくいかない みんなで使うツールをみんなで良くして開発者体験を高めていく文化 • プログラミングに強いエンジニアも、UXに強いエンジニアも、テストに強いエンジニアもそ れぞれの得意領域で活躍してほしい 変化のコストとリスクを会社として負う • そのための意思表示としてのチームビジョン • 開発しにくいところは基盤開発のチームが全面協力
会社紹介 & 自己紹介 NewsPicksとKotlin 開発者体験とKotlin 会社のメイン開発言語を変えるということ 改めて、なぜ「NewsPicksは」開発言語を変更するのか これから 01 02
03 04 05 06 25 目次
決断してからが本番 26 レイトマジョリティまで含めた巻き込み • 2週に1回「社内Kotlin知見共有会」 ◦ 初心者歓迎!質問歓迎! • Kotlinで書きにくい処理を書きやすくする優秀なコピペ元を増やす •
社内外への発信 • 現在開催中の Kotlin Premier 2021 の発表もリアルタイムで翻訳💪 やるからには日本一を目指す • 「使ってるだけ」ではなく「日本一使いこなしている」へ ◦ この点でもJavaよりKotlinのほうがチャンスありそう
27 NewsPicksでは Kotlinを日本一使いこなしたい エンジニアを募集中です!!