LoginSignup
2
6

More than 1 year has passed since last update.

【ミライトデザイン社内勉強会#25】Clean Architecture 輪読会 「第1部:イントロダクション」「第2部:プログラミングパラダイム」

Last updated at Posted at 2021-05-23

Clean Architecture 達人に学ぶソフトウェアの構造と設計 | Robert C.Martin, 角 征典, 高木 正弘 |本 | 通販 | Amazon

第1部 イントロダクション

第1章 設計とアーキテクチャ
第2章 2つの価値のお話

生産性を可視化するにはどういった手法があるのか知りたい

そもそもアーキテクチャってどういう意味?

  • 「構造」とか「構成」みたいなこと

アイゼンハワーのマトリックスがよくわからなかった。「緊急」と「重要」の違いってなに?

「緊急」と「重要」の違い
「緊急」は、タスクに早急な対応が必要であることを意味します。これらは「今」やるべきこと。緊急のタスクは何よりも優先して処理される必要があります。
一方で「重要」は、長期的に見て達成した方がよい目標・使命などのことを指します。通常、「重要」タスクはゆっくり時間をかけてこなすもので、達成すれば新たな可能性が広がるようなものもあります。

  • 緊急のものだけを進めていると、重要な作業が進まなくなってしまうので、緊急と重要なものを分けて優先順位をつけたほうがいい

開発者もステークホルダーであるって考え方と、僕らが声を上げて守るものがあるって話が好き p.45

  • 機能よりも構造にフォーカスするという話

第2部 構成要素からはじめよ:プログラミングパラダイム

第3章 パラダイムの概要
第4章 構造化プログラミング
第5章 オブジェクト指向プログラミング
第6章 関数型プログラミング

構造化プログラミングが考えられるまではif文とかfor文みたいなものはなかったの?

  • Goto文でいろんなことができてたけど、「順次」「選択」「反復」で十分実現できる
  • プログラミングは「順次」「選択」「反復」で構成されてるってことがこの段階で分類できた。
  • Gotoが悪いわけではなく、良いGotoと悪いGotoがある

https://ja.wikipedia.org/wiki/Goto文#ダイクストラの主張

Javaとかのオブジェクト指向言語はオブジェクト指向兼、構造化プログラミングなマルチパラダイム(?)な言語が多いイメージだけど、関数型言語でも構造化プログラミングのパラダイムは使われていたりするの?

  • 「順次」「選択」「反復」は全ての言語で実現されているんだと思う
    • 関数型だとモナドとか言う謎の技を使うと実現できたりする
      • ちなみに if は普通の感覚で使えないし for はない
  • 今使われている言語のほとんどは構造化プログラミング
  • 上から順番に実行されるとか、ifで分岐するとか現在では当たり前になっているものが構造化プログラミング
  • 構造化プログラミングではない言語の例

関数型とオブジェクト指向どちらもいけるハイブリットな言語みたいなものはあるの?

  • んなら scala やるべや

  • 最近では基本どの言語もほぼハイブリッドみたいなもん。

  • ただ、一概にハイブリッドで色々できる方がいいとは限らない

    • やり方が複数ある場合などチームで方針を決めたりする必要が出てくる

オブジェクト指向プログラミングと関数型プログラムの使い分けは?

  • 個人的な感覚だと、関数型プログラみん は domain layer とかはすごい向いている点があるけど、その外のレイヤー作るのが大変そう

    • haskell には yesod というでかい web フレームワークがあって db から template engine まで関数で書くこともできるけど
  • 数学とか定理証明とか計算機とか、純粋な計算がプロダクトの中心になる様な領域だと、OOP より向いているのかなと思う

抽象データ型とメッセージングのオブジェクト指向どっちが良いの?

  • 調べてみたら、オブジェクト指向には「抽象データ型」と「メッセージング」の2つの手法があるらしい。どっちが良いとかあるの?

  • ほとんどは抽象データ型の思想で設計している

    • オブジェクト指向の話をしている時は基本的には抽象データ型が前提になっていること多い
    • 一旦メッセージングについては忘れても良い気がする
    • メッセージングが時代遅れという意味ではないよ

宣伝 → 副作用と参照透過性と冪等性を理解して、テストでドメインを磨く - Qiita

  • 副作用がある関数: 何かの状態を変更するか
  • 参照等価性がある関数: 必ずアウトパラが同じになる
  • 冪等性のある関数: 何度実行しても同じ状態になる ( アウトパラが同じとは限らない )

次回

【ミライトデザイン社内勉強会#26】Clean Architecture 輪読会 「第3部:設計の原則」 - Qiita

2
6
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
6