OOAD - การสร้างแบบจำลองแบบไดนามิก

โมเดลไดนามิกแสดงถึงลักษณะที่ขึ้นอยู่กับเวลาของระบบ เกี่ยวข้องกับการเปลี่ยนแปลงชั่วคราวในสถานะของวัตถุในระบบ แนวคิดหลักคือ -

  • สถานะซึ่งเป็นสถานการณ์ที่เงื่อนไขเฉพาะในช่วงอายุการใช้งานของวัตถุ

  • การเปลี่ยนแปลงการเปลี่ยนแปลงในสถานะ

  • เหตุการณ์เหตุการณ์ที่ทำให้เกิดการเปลี่ยน

  • การกระทำการคำนวณแบบต่อเนื่องและอะตอมที่เกิดขึ้นเนื่องจากเหตุการณ์บางอย่างและ

  • การเปลี่ยนแปลงพร้อมกัน

เครื่องสถานะจะจำลองลักษณะการทำงานของออบเจ็กต์เมื่อผ่านสถานะต่างๆในช่วงอายุการใช้งานอันเนื่องมาจากเหตุการณ์บางอย่างและการดำเนินการที่เกิดขึ้นเนื่องจากเหตุการณ์ เครื่องแสดงสถานะเป็นภาพกราฟิกผ่านแผนภาพการเปลี่ยนสถานะ

สถานะและการเปลี่ยนสถานะ

สถานะ

สถานะเป็นนามธรรมที่กำหนดโดยค่าของคุณลักษณะที่วัตถุมีในช่วงเวลาหนึ่ง ๆ เป็นสถานการณ์ที่เกิดขึ้นในช่วงเวลา จำกัด ตลอดอายุการใช้งานของออบเจ็กต์ซึ่งเป็นไปตามเงื่อนไขบางอย่างดำเนินกิจกรรมบางอย่างหรือรอให้เหตุการณ์บางอย่างเกิดขึ้น ในแผนภาพการเปลี่ยนสถานะสถานะจะแสดงด้วยสี่เหลี่ยมมน

ส่วนต่างๆของรัฐ

  • Name- สตริงทำให้สถานะหนึ่งแตกต่างจากอีกสถานะหนึ่ง รัฐอาจไม่มีชื่อใด ๆ

  • Entry/Exit Actions - หมายถึงกิจกรรมที่ดำเนินการในการเข้าและออกจากสถานะ

  • Internal Transitions - การเปลี่ยนแปลงภายในสถานะที่ไม่ก่อให้เกิดการเปลี่ยนแปลงในสถานะ

  • Sub–states - สถานะภายในรัฐ

สถานะเริ่มต้นและสถานะสุดท้าย

สถานะเริ่มต้นเริ่มต้นของวัตถุเรียกว่าสถานะเริ่มต้น สถานะสุดท้ายแสดงถึงการเสร็จสิ้นของการดำเนินการของเครื่องสถานะ สถานะเริ่มต้นและสถานะสุดท้ายเป็นสถานะหลอกและอาจไม่มีส่วนของสถานะปกติยกเว้นชื่อ ในแผนภาพการเปลี่ยนสถานะสถานะเริ่มต้นจะแสดงด้วยวงกลมสีดำที่เติม สถานะสุดท้ายจะแสดงโดยวงกลมสีดำที่เต็มไปด้วยล้อมรอบภายในวงกลมสีดำอีกวงที่ไม่ได้บรรจุ

การเปลี่ยน

การเปลี่ยนแปลงหมายถึงการเปลี่ยนแปลงสถานะของวัตถุ หากวัตถุอยู่ในสถานะหนึ่งเมื่อเกิดเหตุการณ์วัตถุอาจดำเนินกิจกรรมบางอย่างภายใต้เงื่อนไขที่กำหนดและเปลี่ยนสถานะ ในกรณีนี้มีการกล่าวถึงการเปลี่ยนสถานะว่าเกิดขึ้น การเปลี่ยนแปลงให้ความสัมพันธ์ระหว่างรัฐแรกและรัฐใหม่ การเปลี่ยนแปลงจะแสดงเป็นกราฟิกด้วยส่วนโค้งที่กำหนดทิศทางแบบทึบจากสถานะต้นทางไปยังสถานะปลายทาง

ห้าส่วนของการเปลี่ยนแปลงคือ -

  • Source State - รัฐที่ได้รับผลกระทบจากการเปลี่ยนแปลง

  • Event Trigger - เหตุการณ์ที่เกิดขึ้นเนื่องจากวัตถุในสถานะต้นทางผ่านการเปลี่ยนแปลงหากเงื่อนไขการป้องกันเป็นที่พอใจ

  • Guard Condition - นิพจน์บูลีนซึ่งหากเป็นจริงจะทำให้เกิดการเปลี่ยนแปลงในการรับทริกเกอร์เหตุการณ์

  • Action - การคำนวณแบบไม่ขัดจังหวะและอะตอมที่เกิดขึ้นบนวัตถุต้นทางเนื่องจากเหตุการณ์บางอย่าง

  • Target State - สถานะปลายทางหลังจากเสร็จสิ้นการเปลี่ยนแปลง

Example

สมมติว่าบุคคลหนึ่งนั่งแท็กซี่จากสถานที่ X ไปยังสถานที่ Y สถานะของบุคคลนั้นอาจเป็น: กำลังรอ (รอแท็กซี่) ขี่ (เขามีแท็กซี่และกำลังเดินทางอยู่) และไปถึง (เขามาถึง ปลายทาง). รูปต่อไปนี้แสดงให้เห็นถึงการเปลี่ยนสถานะ

เหตุการณ์

เหตุการณ์คือเหตุการณ์บางอย่างที่ทำให้เกิดการเปลี่ยนสถานะของวัตถุหรือกลุ่มของวัตถุ กิจกรรมมีสถานที่ตั้งในช่วงเวลาและพื้นที่ แต่ไม่มีช่วงเวลาที่เกี่ยวข้อง โดยทั่วไปเหตุการณ์จะเกี่ยวข้องกับการกระทำบางอย่าง

ตัวอย่างของเหตุการณ์เช่นการคลิกเมาส์การกดแป้นการขัดจังหวะการซ้อนทับ ฯลฯ

เหตุการณ์ที่ทำให้เกิดการเปลี่ยนจะถูกเขียนควบคู่ไปกับส่วนโค้งของการเปลี่ยนแปลงในแผนภาพสถานะ

Example

เมื่อพิจารณาจากตัวอย่างที่แสดงในรูปด้านบนการเปลี่ยนจากสถานะรอเป็นสถานะขี่จะเกิดขึ้นเมื่อบุคคลนั้นขึ้นรถแท็กซี่ ในทำนองเดียวกันสถานะสุดท้ายก็มาถึงเมื่อเขาไปถึงปลายทาง เหตุการณ์ทั้งสองนี้สามารถเรียกได้ว่าเป็นเหตุการณ์ Get_Taxi และ Reach_Destination รูปต่อไปนี้แสดงเหตุการณ์ในเครื่องสถานะ

กิจกรรมภายนอกและภายใน

เหตุการณ์ภายนอกคือเหตุการณ์ที่ส่งผ่านจากผู้ใช้ระบบไปยังอ็อบเจ็กต์ภายในระบบ ตัวอย่างเช่นการคลิกเมาส์หรือปุ่ม − กดโดยผู้ใช้เป็นเหตุการณ์ภายนอก

เหตุการณ์ภายในคือเหตุการณ์ที่ส่งผ่านจากวัตถุหนึ่งไปยังวัตถุอื่นภายในระบบ ตัวอย่างเช่นสแตกล้นข้อผิดพลาดในการแบ่ง ฯลฯ

เหตุการณ์รอตัดบัญชี

เหตุการณ์ที่รอการตัดบัญชีคือเหตุการณ์ที่อ็อบเจ็กต์ไม่ได้รับการจัดการทันทีในสถานะปัจจุบัน แต่เรียงต่อกันเป็นคิวเพื่อให้สามารถจัดการกับอ็อบเจ็กต์ในสถานะอื่นได้ในเวลาต่อมา

คลาสกิจกรรม

คลาสเหตุการณ์บ่งชี้กลุ่มของเหตุการณ์ที่มีโครงสร้างและพฤติกรรมร่วมกัน เช่นเดียวกับคลาสของอ็อบเจ็กต์คลาสของเหตุการณ์อาจถูกจัดโครงสร้างตามลำดับชั้น คลาสเหตุการณ์อาจมีแอตทริบิวต์ที่เกี่ยวข้องเวลาเป็นแอตทริบิวต์โดยนัย ตัวอย่างเช่นเราสามารถพิจารณาเหตุการณ์การออกเดินทางของเที่ยวบินของสายการบินซึ่งเราสามารถจัดกลุ่มเป็นชั้นเรียนต่อไปนี้ -

Flight_Departs (Flight_No, From_City, To_City, เส้นทาง)

การดำเนินการ

กิจกรรม

กิจกรรมคือการดำเนินการตามสถานะของวัตถุที่ต้องใช้ช่วงเวลาหนึ่ง เป็นการดำเนินการอย่างต่อเนื่องภายในระบบที่สามารถหยุดชะงักได้ กิจกรรมจะแสดงในแผนภาพกิจกรรมที่แสดงภาพการไหลจากกิจกรรมหนึ่งไปยังอีกกิจกรรมหนึ่ง

หนังบู๊

การกระทำคือการดำเนินการของอะตอมที่ดำเนินการอันเป็นผลมาจากเหตุการณ์บางอย่าง โดยปรมาณูหมายความว่าการกระทำนั้นไม่สามารถขัดจังหวะได้กล่าวคือหากการดำเนินการเริ่มดำเนินการมันจะดำเนินไปสู่ความสมบูรณ์โดยไม่ถูกขัดขวางจากเหตุการณ์ใด ๆ การดำเนินการอาจดำเนินการกับวัตถุที่มีการกระตุ้นเหตุการณ์หรือบนวัตถุอื่นที่มองเห็นได้สำหรับวัตถุนี้ ชุดของการดำเนินการประกอบด้วยกิจกรรม

การดำเนินการเข้าและออก

การดำเนินการเข้าคือการกระทำที่ดำเนินการเมื่อเข้าสู่สถานะโดยไม่คำนึงถึงการเปลี่ยนแปลงที่นำไปสู่

ในทำนองเดียวกันการดำเนินการที่ดำเนินการในขณะที่ออกจากสถานะโดยไม่คำนึงถึงการเปลี่ยนแปลงที่นำออกไปเรียกว่าการดำเนินการออก

สถานการณ์

สถานการณ์คือคำอธิบายของลำดับการดำเนินการที่ระบุ มันแสดงให้เห็นพฤติกรรมของวัตถุที่อยู่ระหว่างชุดการกระทำที่เฉพาะเจาะจง สถานการณ์จำลองหลักแสดงให้เห็นถึงลำดับที่สำคัญและสถานการณ์รองแสดงถึงลำดับทางเลือก

ไดอะแกรมสำหรับการสร้างแบบจำลองแบบไดนามิก

มีแผนภาพหลักสองแผนที่ใช้สำหรับการสร้างแบบจำลองแบบไดนามิก -

แผนภาพปฏิสัมพันธ์

แผนภาพปฏิสัมพันธ์อธิบายพฤติกรรมพลวัตของวัตถุต่างๆ ประกอบด้วยชุดของวัตถุความสัมพันธ์และข้อความที่วัตถุส่งและรับ ดังนั้นปฏิสัมพันธ์จึงจำลองพฤติกรรมของกลุ่มวัตถุที่สัมพันธ์กัน แผนภาพปฏิสัมพันธ์สองประเภทคือ -

  • Sequence Diagram - แสดงถึงการจัดลำดับข้อความชั่วคราวในลักษณะตาราง

  • Collaboration Diagram - แสดงถึงการจัดโครงสร้างของวัตถุที่ส่งและรับข้อความผ่านจุดยอดและส่วนโค้ง

แผนภาพการเปลี่ยนสถานะ

แผนภาพการเปลี่ยนสถานะหรือเครื่องแสดงสถานะอธิบายพฤติกรรมพลวัตของวัตถุชิ้นเดียว มันแสดงให้เห็นลำดับของสถานะที่วัตถุผ่านไปในช่วงชีวิตของมันการเปลี่ยนสถานะเหตุการณ์และเงื่อนไขที่ทำให้เกิดการเปลี่ยนแปลงและการตอบสนองอันเนื่องมาจากเหตุการณ์

ภาวะพร้อมกันของเหตุการณ์

ในระบบอาจมีการเกิดพร้อมกันสองประเภท พวกเขาคือ -

ระบบพร้อมกัน

ที่นี่การทำงานพร้อมกันถูกจำลองขึ้นในระดับระบบ ระบบโดยรวมได้รับการจำลองเป็นการรวมตัวของเครื่องสเตตซึ่งแต่ละเครื่องทำงานพร้อมกันกับเครื่องอื่น ๆ

การทำงานพร้อมกันภายในวัตถุ

ที่นี่วัตถุสามารถสร้างเหตุการณ์ที่เกิดขึ้นพร้อมกันได้ วัตถุอาจมีสถานะที่ประกอบด้วยสถานะย่อยและเหตุการณ์ที่เกิดขึ้นพร้อมกันอาจเกิดขึ้นในแต่ละสถานะย่อย

แนวคิดที่เกี่ยวข้องกับการเกิดพร้อมกันภายในวัตถุมีดังนี้ -

รัฐที่เรียบง่ายและประกอบ

สภาวะธรรมดาไม่มีโครงสร้างย่อย สถานะที่มีสถานะที่เรียบง่ายกว่าซ้อนอยู่ภายในเรียกว่าสถานะผสม สถานะย่อยคือสถานะที่ซ้อนอยู่ภายในสถานะอื่น โดยทั่วไปจะใช้เพื่อลดความซับซ้อนของเครื่องสเตต สถานะย่อยสามารถซ้อนกันได้หลายระดับ

สถานะผสมอาจมีทั้งสถานะย่อยตามลำดับหรือสถานะย่อยพร้อมกัน

สถานะย่อยตามลำดับ

ในสถานะย่อยตามลำดับการควบคุมการดำเนินการจะส่งผ่านจากสถานะย่อยหนึ่งไปยังอีกสถานะย่อยทีละสถานะตามลำดับ มีสถานะเริ่มต้นมากที่สุดหนึ่งสถานะและสถานะสุดท้ายในเครื่องสถานะเหล่านี้

รูปต่อไปนี้แสดงให้เห็นถึงแนวคิดของสถานะย่อยตามลำดับ

สถานะย่อยพร้อมกัน

ในสถานะย่อยที่เกิดขึ้นพร้อมกันสถานะย่อยจะดำเนินการแบบขนานหรือกล่าวอีกนัยหนึ่งคือแต่ละรัฐมีการเรียกใช้เครื่องสถานะภายในพร้อมกัน เครื่องของรัฐแต่ละเครื่องมีสถานะเริ่มต้นและสถานะสุดท้ายของตัวเอง หากสถานะย่อยที่เกิดขึ้นพร้อมกันหนึ่งถึงสถานะสุดท้ายก่อนอีกสถานะหนึ่งการควบคุมจะรอที่สถานะสุดท้าย เมื่อเครื่องสเตตที่ซ้อนกันทั้งหมดถึงสถานะสุดท้ายสถานะย่อยจะรวมกลับเป็นโฟลว์เดียว

รูปต่อไปนี้แสดงแนวคิดของสถานะย่อยที่เกิดขึ้นพร้อมกัน