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
自作ツールを作って分かった Go を使うことのメリット
Search
daichi
October 12, 2023
Programming
0
36
自作ツールを作って分かった Go を使うことのメリット
https://knowledgework.connpass.com/event/297546/
Enablement Bootcamp for Gopherizing #1 での発表資料
daichi
October 12, 2023
Tweet
Share
More Decks by daichi
See All by daichi
Blue/Greenデプロイの導入による 運用フローの改善
kudoas
1
830
自作OSSで仕事を楽にする
kudoas
0
40
ライブラリのアップデートをスムーズに楽しく進める工夫
kudoas
0
24
Other Decks in Programming
See All in Programming
PSR-15 はあなたのための ものではない? - phpcon2024
myamagishi
0
190
Online-Dokumentation, die hilft: Strukturen, Prozesse, Tools
ahus1
0
100
StarlingMonkeyを触ってみた話 - 2024冬
syumai
3
310
見えないメモリを観測する: PHP 8.4 `pg_result_memory_size()` とSQL結果のメモリ管理
kentaroutakeda
0
800
Monixと常駐プログラムの勘どころ / Scalaわいわい勉強会 #4
stoneream
0
300
React 19でお手軽にCSS-in-JSを自作する
yukukotani
5
450
EC2からECSへ 念願のコンテナ移行と巨大レガシーPHPアプリケーションの再構築
sumiyae
2
480
Effective Signals in Angular 19+: Rules and Helpers
manfredsteyer
PRO
0
180
DevFest - Serverless 101 with Google Cloud Functions
tunmise
0
130
iOS開発におけるCopilot For XcodeとCode Completion / copilot for xcode
fuyan777
1
580
create_tableをしただけなのに〜囚われのuuid編〜
daisukeshinoku
0
300
GitHubで育つ コラボレーション文化 : ニフティでのインナーソース挑戦事例 - 2024-12-16 GitHub Universe 2024 Recap in ZOZO
niftycorp
PRO
0
500
Featured
See All Featured
Producing Creativity
orderedlist
PRO
342
39k
A Modern Web Designer's Workflow
chriscoyier
693
190k
Building Adaptive Systems
keathley
38
2.3k
GraphQLとの向き合い方2022年版
quramy
44
13k
Building an army of robots
kneath
302
44k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
44
9.3k
A designer walks into a library…
pauljervisheath
205
24k
A better future with KSS
kneath
238
17k
Building Flexible Design Systems
yeseniaperezcruz
327
38k
Optimising Largest Contentful Paint
csswizardry
33
3k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
356
29k
The Language of Interfaces
destraynor
155
24k
Transcript
自作ツールを作って分かった Go を使うことのメリット Enablment Bootcamp for Gopherizing 2023-10-12 @オンライン
だいち / @_da1kong Classi 株式会社 2022年4月 新卒入社 API・画面開発や業務フローの改善
企業 経歴 業務
Background / Motivation Bootcamp 以前は Goをほとんど書いたことはなかった これを機会を Go を書ける素地を身に付けたい 実際に学んだこと:Goらしいコード・テスト・エラー処理
など ここからは コードを書くこと で理解を深めたい 普段は Ruby・TypeScript を書いているので その経験と比較すると Go の理解も進めやすい Bootcamp資料より引用
作ったもの kudoas/gis (GitHub Issue Syncer) コマンド実行で自動的に 子Issue と
親Issue の情報を同期できるツール Issue から Issue を作ると 親Issueの情報 (label, millstone など) が 子 Issue に引き継がれないため このツールをまだ育てている最中なので 機能は最小限です🙏
子 Issue から親 Issue fieldを取得する 内部実装を簡単に紹介 OAuth2.0 で GitHub API
を認可する 子 Issue fieldをアップデートする 1 2 3
開発で使用したツール・ライブラリ等 Editor VSCode Go Version 1.21.3 Library golang/oauth2
OAuth2.0 による認可のクライアント実装 shurcooL/githubv4 GitHub API v4 SDK
Goを使って開発したときに感じたメリット
GraphQL との連携が扱いやすい GitHub API のレスポンスを格納する構造体を定義 クエリを呼び出してレスポンスを構造体に格納する API
のレスポンスが構造体に合わない場合は エラーになる GraphQLのクエリと構造体が紐づいている 取得した値に型のサポートがつく
構造体によって リクエスト・レスポンスの形式が正しいか を担保できる 型が決まっているので、呼び出す際にコード補完が効いて書きやすい テストをスタブする際もライブラリのインターフェースを守れる テストを書く場合は外部と通信するAPIのインターフェースは スタブすることが多い スタブ自体が間違っていてもテストは通るが、実行するとバグになる 引数や返り値の型を担保した上でより本物に近いスタブが作れる
他の動的型付け言語 (Ruby) で実装した場合の違い
Goを勉強する上で感じたメリット
Go のコードは読みやすい gofmt という標準ライブラリの存在 すぐにコードを書き始められる import の順番・インデントのスペース数が統一されている Go らしいコードを意識して書かれているものが多い Clarity(明確さ)や
Simplicity(単純さ)を重視している 引用:Style principles - Go Style Guide ライブラリを使った実践的なコードを追いやすい
ライブラリを使った実践的なコードを追いやすい README GoDoc GitHub Code Search より実践的な コードを知りたい🤔 読みやすい
ライブラリの実装の詳細を追いやすい VSCode 上のコードジャンプですぐに 実装の詳細 を確認できる 言語仕様もシンプルなので読みやすい 他の言語との比較 Ruby はそもそもコードジャンプがしにくい
TypeScript は 型定義ファイル(d.ts) を参照する場合が多い
実際に自作ツールを開発することで Go のメリットが少しずつ見えてきた 型によるコードの保護が手厚い 実装する上で他のコードを参照しやすい ライブラリの実装の詳細を追いやすい Bootcamp で Go の素地がついてきたと感じた
ここから更に手を動かしながら学んでいきたい まとめ