Upgrade to Pro — share decks privately, control downloads, hide ads and more …

標準パッケージ初のgenerics利用事例 "sync/atomic.Pointer"

uji
October 15, 2022

標準パッケージ初のgenerics利用事例 "sync/atomic.Pointer"

uji

October 15, 2022
Tweet

More Decks by uji

Other Decks in Technology

Transcript

  1. © Money Forward, Inc. sync/atomicとは • Goの標準パッケージのうちの一つ • システムの他からは単体に見え、 割り込みができない操作を扱う

    (「不可分操作」や「アトミック操作」と呼ばれる) • goroutine間でデータを同期するための 最もプリミティブな仕組み ◦ mutexなどの他の排他制御と比べると 競合発生頻度が低い場合、余分なロックが少なく性能が良い
  2. © Money Forward, Inc. • Go1.19でメモリモデルが定義が更新された ◦ データ競合を避けるために適切な同期を使用することが より強く推奨されるようになった ◦

    アトミック操作は有効な手段の一つ • 現状のAPIは、通常の変数をアトミック関数に渡す シグネチャになっており、 どこがアトミック操作されるべきかがわかりにくい課題がある アップデートの背景 https://go.dev/ref/mem#overview https://research.swtch.com/gomm#maybe
  3. © Money Forward, Inc. boolやint32なども含めて atomic.Value[T] などでも良かったのでは? • Bool や

    Pointer は数値では無いので Add メソッドを持たない しかし数値型は Add を持つべき • atomic.Xxx[T] のような単一の型で これらの型の制約を表現する方法が現状ない • 無理に単一の型に統合するより、atomic.Bool や atomic.Int32 などに分けて 提供した方がユーザーフレンドリーとGoチームは考えた これらは使われる頻度も高く、genericsを考えなくて良い場面が増える なぜ Pointer[T]? https://github.com/golang/go/issues/50860
  4. © Money Forward, Inc. 古いAPIでやれることは追加された型で全て実現できる →deprecatedにして良いのでは? • 古いAPIは警告するほど壊れてはいないため deprecated にはならず残る

    (deprecatedにするproposalを出したところdeclineになった) • 新しく実装する際は利便性の高い 追加された型のAPIを使うのが良い 古いAPIとの使い分け https://github.com/golang/go/issues/55302
  5. © Money Forward, Inc. • メモリモデルの定義が更新され、 どこがアトミック操作されるべきかを わかりやすくする必要性が出てきた • 追加された型を利用することで、

    どこがアトミック操作されるべきかがわかりやすくなった • 新しく実装する際は利便性の高い 追加された型のAPIを使うのが良い • 古いAPIはdeprecated にはならず残る まとめ
  6. © Money Forward, Inc. • sync/atomic: add typed atomic values

    https://github.com/golang/go/issues/50860 • The Go Memory Model https://go.dev/ref/mem • Updating the Go Memory Model https://research.swtch.com/gomm • Go1.19 Memory Modelを読む【入門編】 https://docs.google.com/presentation/d/1jJvL__7VYHs4Qv-mGsuAThXpWiSpek27wXln9K2PVJU • Goならわかるシステムプログラミング 第2版 https://www.lambdanote.com/products/go-2 • Go 1.19のメモリ周りの更新 https://future-architect.github.io/articles/20220808a • proposal: sync/atomic: deprecate AddXxx, CompareAndSwapXxx, LoadXxx, StoreXxx, SwapXxx https://github.com/golang/go/issues/55302 参考文献