シーケンス図とは?
UMLシーケンス図を理解するためには、まず統一モデリング言語図、別名 UML の役割を知っておくことが大切です。UML は、行動図、相互作用図、構造図などのさまざまな種類の図の作成と表記の基本となるモデリングツールキットです。
シーケンス図は、オブジェクトがどのように連携して動作し、順番にどのようなやり取りをするかを示す図です。ソフトウェア開発者やビジネスパーソンが、新しいシステムの設計を理解したり、既存のプロセスを整理する際に使われます。また、シーケンス図は「イベント図」や「イベントシナリオ」とも呼ばれることがあります。
シーケンス図には、UML 図とコードベースの図の2種類があります。後者はプログラミングコードをソースとするものであり、本ガイドでは触れません。Lucidchart の UML 作成ツールには、これらの図のモデル化に必要となるあらゆる図形と機能が揃っています。
シーケンス図を作成するメリット
シーケンス図は、企業や組織でのさまざまな場面で役立つツールです。シーケンス図を利用することで、以下のようなメリットがあります。
- UML のユースケースの詳細を明確に示すことができます。
- 高度な手順や機能、操作のロジックをモデル化し、視覚的に整理できます。
- プロセスの完了までに おけるオブジェクトやコンポーネントの相互作用を確認しやすくなります。
- 既存または将来のシナリオにおける詳細な機能を計画し、深く理解するための支援になります。
これらのメリットにより、シーケンス図は新しいシステムの設計や既存プロセスの整理において非常に便利です。
シーケンス図の活用法
シーケンス図は、企業や組織でのさまざまな場面で効果的に活用できるツールです。特に以下のようなシナリオにおいて、シーケンス図が有効です。
-
利用シナリオ: システムをどのように利用できるかを示す図として、シーケンス図を活用できます。これにより、システムのあらゆる利用シナリオのロジックがしっかりと想定されているかを確認することができます。
-
メソッドのロジック: UMLシーケンス図を使ってユースケースのロジックを検討するように、シーケンス図はあらゆる機能、手順、または複雑なプロセスのロジックを視覚的に整理するのに役立ちます。
-
サービスのロジック: 異なるクライアントが使用するサービスを高次のメソッドとして捉え、そのサービスをマッピングする際にもシーケンス図は有用です。
シーケンス図を使うことで、システム設計やプロセスの整理が容易になり、複雑なロジックを視覚的に把握することができます。
シーケンス図の構成要素
シーケンス図を理解するためには、図に使われる記号や構成要素を知っておく必要があります。シーケンス図は以下のアイコンと要素で構成されます。
記号 | 名称 | 説明 |
---|---|---|
オブジェクト記号 |
UML のクラスまたはオブジェクトを表します。オブジェクト記号は、システムのコンテキストにおけるオブジェクトの振る舞いを示します。この図形にクラスの属性は表示されません。 | |
アクティベーションボックス |
オブジェクトがタスクを完了するまでに要する時間を表します。タスクの所要時間が長いほど、アクティベーションボックスも長いものになります。 | |
アクター記号 |
システムと相互作用する、またはシステム外部に存在する実体を示します。 | |
パッケージ記号 |
UML 2.0 記法で用いら れ、図のインタラクティブな要素を含むものです。フレームとも呼ばれ、長方形の図形に図のラベルとなる小さな長方形を内包します。 | |
ライフライン記号 |
下方向に伸び、時間の経過を表します。垂直の破線で、作図対象となるプロセス間に、オブジェクトに対して連続して発生する事象を示します。ライフラインはラベル付きの長方形やアクター記号などから開始します。 | |
オプションループ (Opt) |
if/then シナリオ、すなわち特定の条件下でのみ起こる状況をモデル化します。 | |
代替記号 (Alt) |
複数のシーケンス間の (通常、相互排他的な) 選択を表します。内側に破線を含むラベル付きの長方形の図形で代替を示します。 |
一般的なメッセージ記号
以下の矢印やメッセージ記号を使い、オブジェクト間での情報の伝達方法を表します。これらの信号は、操作の開始と実行、または信号の送受信を示す場合があります。
記号 | 名称 | 説明 |
---|---|---|
同期メッセージ記号 |
実線と黒塗りの矢印で示されます。この記号は、送信者が続行するためにはメッセージへの応答が必要である場合に使われます。この図では、呼び出しと応答の双方を示す必要があります。 | |
非同期メッセージ記号 |
実線と線状の矢印で示されます。非同期メッセージは、送信者が続行する場合に応答を必要としません。この図には呼び出しのみを含めます。 | |
非同期リターンメッセージ記号 |
破線と線状の矢印で示されます。 | |
非同期作成メッセージ記号 |
破線と線状の矢印で示されます。このメッセージはオブジェクトを新規作成します。 | |
応答メッセージ記号 |
破線と線状の矢印で示されます。このメッセージは呼び出しに応答します。 | |
削除メッセージ記号 |
実線と黒塗りの矢印に X 印で示されます。このメッセージはオブジェクトを消滅させます。 |
シーケンス図の例
病院管理システムのシーケンス図
他の多くの業界と同様に、医療分野にもテクノロジーにより大きな変革がもたらされました。病院管理システム (別名: 病院情報システム) は、医師、事務管理者や病院職員が、診断、処方、予約、患者やその介護者に関する情報を始め、病院に関するすべての活動や関連して収集される情報を管理する上で役立つシステムです。以下の図では、主なプロセスの関わりを時系列で示しています。Lucidchart を使えば、この図をニーズに併せて調整し、同僚や共同編集者と共有することができます。
ATM システムのためのシーケンス図
銀行の顧客が完全に自動化されたプロセス経由で各自の銀行口座にアクセスできる仕組みが ATM です。シーケンス図 を作成して確認すれば、このプロセスを段階別に検討することができます。以下の例では、ATM システムにおける相互作用を順番に示しています。このテンプレートをクリックするだけで、シーケンス図を編集してニーズに合うようカスタマイズすることができます。
Lucidchart を使ってシーケンス図の書き方を簡単にマスター
Lucidchart のアカウントをお持ちでない方には、無料で登録することをおすすめします。ログインし、テンプレートを選択するか、文書を新規作成します。Lucidchart のインポート機能を使い、Visio などの他の作図プラットフォームから既存の図をインポートして作成途中の文書を共同編集したり、作業を続行することも可能です。
シーケンス図の書き方
- 構成要素の特定と追加
1つのシーケンス図で、いくつかの重要なタスクを完了することができます。シーケンス図を使うことで、以下を実現できます。
-
UML のユースケースの詳細を示す。
-
複雑な手続やシステムの動作方法をモデル化する。
-
プロセス完了までの過程におけるオブジェクトとコンポーネントの相互作用を順を追って確認する。
-
多数のさまざまなコンポーネントを含む現実または仮説的なシナリオをマッピングする。
こうした目標を達成するには、まず図に含めるべきシステムのコンポーネントを特定する必要があります。最初のコンポーネントとして欠かせないのが、オブジェクトです。オブジェクトは特にアクターとも呼ばれ、タスク実行やメッセージ送信の主要なプレイヤーとなる存在です。
例えば、ログインシーケンスにおいては、潜在的な訪問者/ユーザー、そして訪問者がログインしようとしているプラットフォームとの相互作用に使うログインページの2つがオブジェクトとなります。特定すべきコンポーネントのセットは他にもあります。オブジェクトが送信するメッセージです。オブジェクトから他のオブジェクトへ渡される情報はどのようなものでしょうか?
この例で示すユーザー認証プロセスにおいて、メッセージは、ウェブページへアクセスするためにユーザーがブラウザーに情報を入力する方法、さらに、そのブラウザーがその後指定のアプリケーションと認証情報をクロスチェックする方法を示します。
-
- 図形の追加またはインポート
Lucidchart では、プロフェッショナルなシーケンス図の作成に必要なあらゆる標準図形が揃った完全な UML 図形ライブラリを利用できます。エディターの左上隅の [図形] をクリックし、図形ライブラリマネージャーで [UML] を選択すれば、ツールバーに UML 図形を追加することができます。
この他にも図形が必要な場合には、画像検索機能でアイコンを検索するほか、お手持ちのステンシルやアイコンをインポートすることも可能です。Lucidchart では、一切の制限なく、さまざまな記号や図形を UML シーケンス図作成に活用できます。
- シーケンスマークアップでプロセスを自動化
Lucidchart のシーケンスマークアップ機能で、シーケンス図作成のプロセスがスピードアップします。すばやく、手間いらずで美しいシーケンス図が作成できる機能です。作図プロセスが自動化され、エディターへ直接マークアップ順序を入力するだけでシーケンス図を生成できます。
UML シーケンス図形ライブラリへ移動し、[マークアップを使用] を選択します。テキストパッドが開きます。ここに、シーケンスの順序とそのルールを入力します。準備が完了したら [作成] をクリックし、クリックでエディターに戻って自動生成されたシーケンス図を確認します。
- 手動でのシーケンス図の作成
UML 図形ライブラリを有効化した後は、シンプルなドラッグ・アンド・ドロップの動作でキャンバスへ図形を簡単に追加することができます。キャンバスの最上部にオブジェクトとなる長方形を追加し、それぞれにオブジェクトの名称となるラベルを追加します。システムの外部でもあり、内部でもあるオブジェクトについては、長方形の代わりにアクター記号を用いることもできます。この記号はツールボックスのユースケース図セクションで見つかります。
時間の流れをシーケンス形式で示すため、オブジェクト図形をクリックして線をドラッグで引き出します。すると、ライフラインを示す点線が直ちに表示されます。ライフラインの長さは、シーケンス内で示すメッセージの数により決まります。 - シーケンス図にテキストや概念を追加
メッセージを作成するには、図形ライブラリからアクティベーションボックスをドラッグします。アクティベーションボックスは細長い長方形の形状をしています。点線のライフラインへボックスをドラッグし、必要に応じてサイズを調整します。
アクティベーションボックスを配置したら、ボックスをクリックしてメッセージ矢印を引き出します。メッセージをクリックして入力し、ラベルを付与することができます。矢印の方向を変更するには、メッセージ矢印、情報アイコンの順にクリックし、[方向を反転] を選択します。
シーケンス図チュートリアルでさまざまなメッセージのキーを確認し、メッセージが正しい情報を送信していることを確認します。
シーケンス内でアクションが消滅した場合には、ライフラインの最後の削除記号 (X) を使用してその旨を示します。
どのオブジェクトでも、他の任意のオブジェクトとの間でメッセージの送受信を行うことができます。オブジェクト同士が隣接している必要はあ りません。すべてのメッセージを必ず正しいアクティベーションボックスに対応させます。最後のメッセージの描画が終了した時点で図は完成となります。
- シーケンス図の書式設定方法
Lucidchart では、最終的な書式設定も容易です。ロジックに確かな根拠があり、すべてのプロセスが正しく並んでいることを確認しましょう。ライフラインは特定の時間枠を示すものではありませんが、メッセージは常に垂直方向に順番に表す必要があります。
文書のチェックが完了したら、図上の希望の領域を選択して書式設定を行います。右サイドバーの「テーマ」機能をクリックして設定済みのスタイル形式を選択するほか、特定の図形や線を選択してフォント、色や線の設定を変更することもできます。フォント、線のスタイルやサイズをあらかじめ選択してデフォルトのスタイルに事前設定しておけば、時間を節約することができます。
- 公開、実行と共有
完成したシーケンス図を Lucidchart から共有・公開すれば、同僚にシステムを明確に説明することができます。共同編集設定により、図のコントロール権限は完全に保持することができます。図を社内 wiki に埋め込んで公開したり、使いやすい共有機能で他の Lucidchart ユーザーや非ユーザーへ送信するほか、完成したシーケンス図を Visio など、あらゆる形式でダウンロードできます。図をリンク経由やソーシャルメディアチャネル上で共有するオプションもあります。
多種多様なLucidchart インテグレーションを利用することで、G Suite などのプラットフォームでシーケンスを公開するほか、あらゆるスプレッドシート、文書やプレゼンテーションに図を追加することができます。無料の Microsoft アドオンで、Word、Excel や PowerPoint などの Microsoft Office ツールへのシーケンス図の追加も自在です。オペレーティングシステムの違いに関係なく使用でき、共同作業につきものの追加費用や制限もありません。