OOAD - การออกแบบเชิงวัตถุ

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

ขั้นตอนสำหรับการออกแบบเชิงวัตถุสามารถระบุได้ว่า -

  • ความหมายของบริบทของระบบ
  • การออกแบบสถาปัตยกรรมระบบ
  • การระบุวัตถุในระบบ
  • การสร้างแบบจำลองการออกแบบ
  • คุณสมบัติของอินเทอร์เฟซของอ็อบเจ็กต์

การออกแบบระบบ

การออกแบบระบบเชิงวัตถุเกี่ยวข้องกับการกำหนดบริบทของระบบตามด้วยการออกแบบสถาปัตยกรรมของระบบ

  • Context- บริบทของระบบมีส่วนที่คงที่และมีพลวัต บริบทคงที่ของระบบได้รับการออกแบบโดยใช้แผนภาพบล็อกอย่างง่ายของทั้งระบบซึ่งขยายเป็นลำดับชั้นของระบบย่อย โมเดลระบบย่อยแสดงโดยแพ็กเกจ UML บริบทแบบไดนามิกอธิบายว่าระบบโต้ตอบกับสภาพแวดล้อมอย่างไร มันถูกจำลองโดยใช้use case diagrams.

  • System Architecture- สถาปัตยกรรมระบบได้รับการออกแบบบนพื้นฐานของบริบทของระบบตามหลักการออกแบบสถาปัตยกรรมและความรู้เกี่ยวกับโดเมน โดยปกติระบบจะแบ่งเป็นชั้น ๆ และแต่ละชั้นจะถูกย่อยสลายเพื่อสร้างระบบย่อย

การสลายตัวเชิงวัตถุ

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

ข้อดีของการสลายตัวคือ -

  • ส่วนประกอบแต่ละส่วนมีความซับซ้อนน้อยกว่าจึงเข้าใจและจัดการได้ง่ายขึ้น

  • ช่วยให้การแบ่งกลุ่มพนักงานมีทักษะเฉพาะทาง

  • ช่วยให้สามารถแทนที่หรือแก้ไขระบบย่อยได้โดยไม่ส่งผลกระทบต่อระบบย่อยอื่น ๆ

การระบุภาวะพร้อมกัน

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

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

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

การระบุรูปแบบ

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

รูปแบบการออกแบบที่ใช้กันทั่วไป ได้แก่ -

  • รูปแบบFaçade
  • รูปแบบการแยกมุมมองโมเดล
  • รูปแบบผู้สังเกตการณ์
  • รูปแบบตัวควบคุมมุมมองโมเดล
  • เผยแพร่รูปแบบการสมัครสมาชิก
  • รูปแบบพร็อกซี

การควบคุมเหตุการณ์

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

เหตุการณ์คือข้อกำหนดของเหตุการณ์สำคัญที่มีตำแหน่งเป็นเวลาและพื้นที่

มีเหตุการณ์สี่ประเภทที่สามารถจำลองได้ ได้แก่ -

  • Signal Event - วัตถุที่มีชื่อถูกโยนโดยวัตถุหนึ่งและจับโดยวัตถุอื่น

  • Call Event - เหตุการณ์ซิงโครนัสที่แสดงถึงการจัดส่งการดำเนินการ

  • Time Event - เหตุการณ์ที่แสดงถึงกาลเวลา

  • Change Event - เหตุการณ์ที่แสดงถึงการเปลี่ยนแปลงในสถานะ

การจัดการเงื่อนไขขอบเขต

ขั้นตอนการออกแบบระบบจำเป็นต้องระบุถึงการเริ่มต้นและการยุติระบบโดยรวมรวมทั้งระบบย่อยแต่ละระบบ ด้านต่างๆที่จัดทำเป็นเอกสารมีดังนี้ -

  • การเริ่มต้นระบบกล่าวคือการเปลี่ยนระบบจากสถานะที่ไม่ได้เริ่มต้นเป็นสถานะคงที่

  • การยุติระบบกล่าวคือการปิดเธรดที่รันอยู่ทั้งหมดการล้างทรัพยากรและข้อความที่จะส่ง

  • การกำหนดค่าเริ่มต้นของระบบและการกำหนดค่าระบบใหม่เมื่อจำเป็น

  • คาดการณ์ถึงความล้มเหลวหรือการยุติระบบโดยไม่ต้องการ

เงื่อนไขขอบเขตถูกจำลองโดยใช้กรณีการใช้งานขอบเขต

การออกแบบวัตถุ

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

การออกแบบวัตถุประกอบด้วยขั้นตอนต่อไปนี้ -

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

การระบุวัตถุ

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

หน้าที่ของขั้นตอนนี้คือ -

  • การระบุและการปรับแต่งคลาสในแต่ละระบบย่อยหรือแพ็กเกจ

  • การกำหนดลิงก์และการเชื่อมโยงระหว่างคลาส

  • การออกแบบการเชื่อมโยงตามลำดับชั้นระหว่างชั้นเรียนเช่นลักษณะทั่วไป / ความเชี่ยวชาญและการสืบทอด

  • การออกแบบการรวม

การแสดงวัตถุ

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

มีรูปแบบการออกแบบสองประเภทที่ต้องผลิต -

  • Static Models - เพื่ออธิบายโครงสร้างคงที่ของระบบโดยใช้คลาสไดอะแกรมและออบเจ็กต์ไดอะแกรม

  • Dynamic Models - เพื่ออธิบายโครงสร้างแบบไดนามิกของระบบและแสดงปฏิสัมพันธ์ระหว่างคลาสโดยใช้แผนภาพปฏิสัมพันธ์และแผนภาพสถานะ - แผนภูมิ

การจำแนกประเภทของการดำเนินงาน

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

งานต่อไปนี้ดำเนินการเกี่ยวกับการดำเนินการ -

  • แผนภาพการเปลี่ยนสถานะของแต่ละออบเจ็กต์ในระบบได้รับการพัฒนา

  • การดำเนินการถูกกำหนดไว้สำหรับเหตุการณ์ที่ได้รับจากวัตถุ

  • กรณีที่เหตุการณ์หนึ่งทำให้เกิดเหตุการณ์อื่นในวัตถุเดียวกันหรือต่างกันถูกระบุ

  • มีการระบุการดำเนินการย่อยภายในการดำเนินการ

  • การดำเนินการหลักจะขยายไปยังแผนภาพกระแสข้อมูล

การออกแบบอัลกอริทึม

การดำเนินการในวัตถุถูกกำหนดโดยใช้อัลกอริทึม อัลกอริทึมเป็นขั้นตอนที่ช่วยแก้ปัญหาที่วางไว้ในการดำเนินการ อัลกอริทึมมุ่งเน้นไปที่วิธีการทำ

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

  • Computational Complexity - ความซับซ้อนจะกำหนดประสิทธิภาพของอัลกอริทึมในแง่ของเวลาในการคำนวณและข้อกำหนดของหน่วยความจำ

  • Flexibility - ความยืดหยุ่นเป็นตัวกำหนดว่าอัลกอริทึมที่เลือกสามารถใช้งานได้อย่างเหมาะสมหรือไม่โดยไม่สูญเสียความเหมาะสมในสภาพแวดล้อมต่างๆ

  • Understandability - สิ่งนี้กำหนดว่าอัลกอริทึมที่เลือกนั้นเข้าใจง่ายและนำไปใช้ได้หรือไม่

การออกแบบความสัมพันธ์

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

ผู้ออกแบบควรทำสิ่งต่อไปนี้เกี่ยวกับการเชื่อมโยง -

  • ระบุว่าการเชื่อมโยงเป็นแบบทิศทางเดียวหรือแบบสองทิศทาง

  • วิเคราะห์เส้นทางของการเชื่อมโยงและอัปเดตหากจำเป็น

  • ใช้การเชื่อมโยงเป็นวัตถุที่แตกต่างกันในกรณีของความสัมพันธ์หลายต่อหลายคน หรือเป็นการเชื่อมโยงไปยังวัตถุอื่นในกรณีของความสัมพันธ์แบบหนึ่งต่อหนึ่งหรือหนึ่งต่อหลาย

เกี่ยวกับการสืบทอดผู้ออกแบบควรดำเนินการดังต่อไปนี้ -

  • ปรับคลาสและความสัมพันธ์

  • ระบุคลาสนามธรรม

  • จัดเตรียมเพื่อให้มีการแบ่งปันพฤติกรรมเมื่อจำเป็น

การดำเนินการควบคุม

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

แนวทางในการนำแบบจำลองไดนามิกไปใช้คือ -

  • Represent State as a Location within a Program- นี่เป็นวิธีการขับเคลื่อนตามขั้นตอนแบบดั้งเดิมโดยตำแหน่งของการควบคุมจะกำหนดสถานะของโปรแกรม เครื่อง จำกัด สถานะสามารถนำไปใช้เป็นโปรแกรมได้ การเปลี่ยนรูปแบบคำสั่งอินพุตพา ธ ควบคุมหลักสร้างลำดับของคำสั่งกิ่งก้านสร้างเงื่อนไขและเส้นทางย้อนกลับจะสร้างลูปหรือการวนซ้ำ

  • State Machine Engine- แนวทางนี้แสดงถึงสถานะเครื่องจักรโดยตรงผ่านคลาสเครื่องยนต์ของสถานะ คลาสนี้เรียกใช้เครื่องสถานะผ่านชุดของการเปลี่ยนและการดำเนินการที่จัดเตรียมโดยแอ็พพลิเคชัน

  • Control as Concurrent Tasks- ในแนวทางนี้อ็อบเจ็กต์ถูกนำไปใช้เป็นงานในภาษาโปรแกรมหรือระบบปฏิบัติการ ที่นี่มีการนำเหตุการณ์มาใช้เป็นการโทรระหว่างงาน มันรักษาความพร้อมกันของวัตถุจริง

ชั้นเรียนบรรจุภัณฑ์

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

ลักษณะต่างๆของบรรจุภัณฑ์ ได้แก่ -

  • Hiding Internal Information from Outside View - อนุญาตให้มองคลาสเป็น "กล่องดำ" และอนุญาตให้เปลี่ยนการใช้คลาสได้โดยไม่ต้องให้ไคลเอ็นต์ของคลาสใด ๆ แก้ไขโค้ด

  • Coherence of Elements - องค์ประกอบเช่นคลาสการดำเนินการหรือโมดูลจะสอดคล้องกันหากมีการจัดระเบียบในแผนที่สอดคล้องกันและทุกส่วนมีความสัมพันธ์กันภายในเพื่อให้บรรลุเป้าหมายร่วมกัน

  • Construction of Physical Modules - แนวทางต่อไปนี้ช่วยในขณะสร้างโมดูลทางกายภาพ -

    • คลาสในโมดูลควรแสดงถึงสิ่งที่คล้ายกันหรือส่วนประกอบในออบเจ็กต์คอมโพสิตเดียวกัน

    • คลาสที่เชื่อมต่ออย่างใกล้ชิดควรอยู่ในโมดูลเดียวกัน

    • ควรวางคลาสที่ไม่เชื่อมต่อหรือเชื่อมต่อที่อ่อนแอในโมดูลแยกต่างหาก

    • โมดูลควรมีการทำงานร่วมกันที่ดีกล่าวคือมีความร่วมมือสูงระหว่างส่วนประกอบต่างๆ

    • โมดูลควรมีการเชื่อมต่อกับโมดูลอื่น ๆ ต่ำเช่นการโต้ตอบหรือการพึ่งพาซึ่งกันและกันระหว่างโมดูลควรมีค่าน้อยที่สุด

การเพิ่มประสิทธิภาพการออกแบบ

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

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

สิ่งต่าง ๆ ที่อาจทำได้เพื่อการเพิ่มประสิทธิภาพการออกแบบ ได้แก่ -

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

การเพิ่มความสัมพันธ์ที่ซ้ำซ้อน

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

การละเว้นการเชื่อมโยงที่ไม่สามารถใช้งานได้

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

การเพิ่มประสิทธิภาพของอัลกอริทึม

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

การเพิ่มประสิทธิภาพของอัลกอริทึมทำได้โดย -

  • การจัดเรียงลำดับของงานคำนวณใหม่
  • การกลับคำสั่งดำเนินการของลูปจากที่วางไว้ในโมเดลการทำงาน
  • การกำจัดเส้นทางที่ตายแล้วภายในอัลกอริทึม

การบันทึกและการจัดเก็บแอตทริบิวต์ที่ได้มา

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

อย่างไรก็ตามสิ่งนี้อาจก่อให้เกิดความผิดปกติของการอัปเดตกล่าวคือการเปลี่ยนแปลงค่าของแอตทริบิวต์พื้นฐานโดยไม่มีการเปลี่ยนแปลงที่สอดคล้องกันในค่าของแอตทริบิวต์ที่ได้รับ เพื่อหลีกเลี่ยงปัญหานี้ให้ทำตามขั้นตอนต่อไปนี้ -

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

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

เอกสารประกอบการออกแบบ

เอกสารเป็นส่วนสำคัญของกระบวนการพัฒนาซอฟต์แวร์ใด ๆ ที่บันทึกขั้นตอนการสร้างซอฟต์แวร์ การตัดสินใจในการออกแบบจำเป็นต้องจัดทำเป็นเอกสารสำหรับระบบซอฟต์แวร์ที่ไม่สำคัญใด ๆ สำหรับการส่งการออกแบบไปยังผู้อื่น

พื้นที่การใช้งาน

แม้ว่าจะเป็นผลิตภัณฑ์รอง แต่เอกสารที่ดีก็เป็นสิ่งที่ขาดไม่ได้โดยเฉพาะในประเด็นต่อไปนี้ -

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

สารบัญ

เอกสารที่เป็นประโยชน์ควรมีเนื้อหาดังต่อไปนี้ -

  • High–level system architecture - แผนภาพกระบวนการและแผนภาพโมดูล

  • Key abstractions and mechanisms - ไดอะแกรมคลาสและไดอะแกรมวัตถุ

  • Scenarios that illustrate the behavior of the main aspects - แผนภาพพฤติกรรม

คุณสมบัติ

คุณสมบัติของเอกสารที่ดี ได้แก่ -

  • กระชับและในเวลาเดียวกันไม่คลุมเครือสอดคล้องและครบถ้วน

  • ตรวจสอบย้อนกลับได้ตามข้อกำหนดข้อกำหนดของระบบ

  • Well-structured

  • Diagrammatic แทนการบรรยาย