OOAD - คู่มือฉบับย่อ

ประวัติโดยย่อ

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

  • ภาษาเชิงวัตถุภาษาแรกคือ Simula (การจำลองระบบจริง) ซึ่งได้รับการพัฒนาในปีพ. ศ. 2503 โดยนักวิจัยจากศูนย์คอมพิวเตอร์แห่งนอร์เวย์

  • ในปี 1970 Alan Kay และกลุ่มวิจัยของเขาที่ Xerox PARK ได้สร้างคอมพิวเตอร์ส่วนบุคคลชื่อ Dynabook และภาษาการเขียนโปรแกรมเชิงวัตถุบริสุทธิ์ (OOPL) ตัวแรก - Smalltalk สำหรับการเขียนโปรแกรม Dynabook

  • ในช่วงทศวรรษที่ 1980 Grady Booch ได้ตีพิมพ์บทความชื่อ Object Oriented Design ซึ่งนำเสนอการออกแบบสำหรับภาษาโปรแกรมเป็นหลัก Ada ในรุ่นต่อ ๆ มาเขาได้ขยายแนวคิดของเขาไปสู่วิธีการออกแบบเชิงวัตถุที่สมบูรณ์

  • ในทศวรรษที่ 1990 Coad ได้รวมเอาแนวคิดเชิงพฤติกรรมเข้ากับวิธีการเชิงวัตถุ

นวัตกรรมที่สำคัญอื่น ๆ ได้แก่ Object Modeling Techniques (OMT) โดย James Rumbaugh และ Object-Oriented Software Engineering (OOSE) โดย Ivar Jacobson

การวิเคราะห์เชิงวัตถุ

Object – Oriented Analysis (OOA) เป็นขั้นตอนในการระบุข้อกำหนดทางวิศวกรรมซอฟต์แวร์และการพัฒนาข้อกำหนดซอฟต์แวร์ในแง่ของโมเดลอ็อบเจ็กต์ของระบบซอฟต์แวร์ซึ่งประกอบด้วยอ็อบเจ็กต์ที่มีปฏิสัมพันธ์

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

Grady Booch ได้กำหนด OOA เป็น“การวิเคราะห์เชิงวัตถุเป็นวิธีการวิเคราะห์ที่ต้องการวิเคราะห์จากมุมมองของการเรียนและวัตถุที่พบในคำศัพท์ของโดเมนปัญหา”

งานหลักในการวิเคราะห์เชิงวัตถุ (OOA) ได้แก่ -

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

โมเดลทั่วไปที่ใช้ใน OOA ได้แก่ กรณีการใช้งานและโมเดลอ็อบเจ็กต์

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

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

รายละเอียดการใช้งานโดยทั่วไป ได้แก่ -

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

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

การเขียนโปรแกรมเชิงวัตถุ

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

คุณสมบัติที่สำคัญของการเขียนโปรแกรมเชิงวัตถุคือ -

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

ตัวอย่างบางส่วนของภาษาโปรแกรมเชิงวัตถุ ได้แก่ C ++, Java, Smalltalk, Delphi, C #, Perl, Python, Ruby และ PHP

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

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

วัตถุและคลาส

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

วัตถุ

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

  • เอกลักษณ์ที่แยกความแตกต่างจากวัตถุอื่น ๆ ในระบบ

  • สถานะที่กำหนดคุณสมบัติลักษณะของวัตถุตลอดจนค่าของคุณสมบัติที่วัตถุนั้นเก็บไว้

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

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

คลาส

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

องค์ประกอบของคลาสคือ -

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

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

Example

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

  • x - พิกัดเพื่อแสดงพิกัด x ของจุดศูนย์กลาง
  • y - พิกัดเพื่อแสดงพิกัด y ของศูนย์กลาง
  • a เพื่อแสดงรัศมีของวงกลม

การดำเนินการบางอย่างสามารถกำหนดได้ดังนี้ -

  • findArea () วิธีคำนวณพื้นที่
  • findCircumference () วิธีคำนวณเส้นรอบวง
  • สเกล () วิธีเพิ่มหรือลดรัศมี

ในระหว่างการสร้างอินสแตนซ์จะมีการกำหนดค่าสำหรับแอตทริบิวต์บางอย่างเป็นอย่างน้อย ถ้าเราสร้างวัตถุ my_circle เราสามารถกำหนดค่าเช่น x-Coord: 2, y-Coord: 3 และ a: 4 เพื่อแสดงสถานะของมัน ตอนนี้ถ้าการดำเนินการมาตราส่วน () ถูกดำเนินการบน my_circle โดยมีค่ามาตราส่วนเป็น 2 ค่าของตัวแปร a จะกลายเป็น 8 การดำเนินการนี้ทำให้สถานะของ my_circle เปลี่ยนแปลงไปกล่าวคือวัตถุได้แสดงพฤติกรรมบางอย่าง

การห่อหุ้มและการซ่อนข้อมูล

การห่อหุ้ม

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

การซ่อนข้อมูล

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

Example

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

  • setValues ​​() วิธีกำหนดค่าให้กับ x-Coord, y-Coord และ a
  • getValues ​​() วิธีการดึงค่าของ x-Coord, y-Coord และ a

ที่นี่ข้อมูลส่วนตัวของวัตถุ my_circle ไม่สามารถเข้าถึงได้โดยตรงด้วยวิธีการใด ๆ ที่ไม่ได้ห่อหุ้มภายในคลาส Circle ควรเข้าถึงได้โดยใช้เมธอด setValues ​​() และ getValues ​​() แทน

ข้อความผ่าน

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

คุณสมบัติของการส่งข้อความคือ -

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

มรดก

การสืบทอดเป็นกลไกที่อนุญาตให้สร้างคลาสใหม่จากคลาสที่มีอยู่โดยการขยายและปรับแต่งความสามารถ คลาสที่มีอยู่เรียกว่าคลาสพื้นฐาน / คลาสพาเรนต์ / ซูเปอร์คลาสและคลาสใหม่เรียกว่าคลาสที่ได้รับ / คลาสย่อย / คลาสย่อย คลาสย่อยสามารถสืบทอดหรือรับคุณสมบัติและวิธีการของ super-class ได้โดยที่ super-class อนุญาต นอกจากนี้คลาสย่อยอาจเพิ่มแอตทริบิวต์และวิธีการของตนเองและอาจปรับเปลี่ยนวิธีการระดับสูง การถ่ายทอดทางพันธุกรรมกำหนดความสัมพันธ์“ คือ - a”

Example

จากสัตว์เลี้ยงลูกด้วยนมระดับชั้นสามารถได้มาหลายคลาสเช่นมนุษย์แมวสุนัขวัว ฯลฯ มนุษย์แมวสุนัขและวัวล้วนมีลักษณะที่แตกต่างกันของสัตว์เลี้ยงลูกด้วยนม นอกจากนี้แต่ละคนมีลักษณะเฉพาะของตัวเอง อาจกล่าวได้ว่าวัว“ เป็น -” สัตว์เลี้ยงลูกด้วยนม

ประเภทของมรดก

  • Single Inheritance - คลาสย่อยมาจากซูเปอร์คลาสเดียว

  • Multiple Inheritance - คลาสย่อยมาจากคลาสซุปเปอร์มากกว่าหนึ่งคลาส

  • Multilevel Inheritance - คลาสย่อยมาจากคลาสซุปเปอร์ซึ่งจะมาจากคลาสอื่นและอื่น ๆ

  • Hierarchical Inheritance - คลาสมีคลาสย่อยจำนวนหนึ่งซึ่งแต่ละคลาสอาจมีคลาสย่อยตามมาโดยดำเนินการต่อไปในหลายระดับเพื่อสร้างโครงสร้างต้นไม้

  • Hybrid Inheritance - การรวมกันของการสืบทอดหลายระดับและหลายระดับเพื่อสร้างโครงสร้างตาข่าย

รูปต่อไปนี้แสดงตัวอย่างของการสืบทอดประเภทต่างๆ

ความแตกต่าง

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

Example

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

ลักษณะทั่วไปและความเชี่ยวชาญ

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

ลักษณะทั่วไป

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

ความเชี่ยวชาญ

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

รูปต่อไปนี้แสดงตัวอย่างของลักษณะทั่วไปและความเชี่ยวชาญ

ลิงค์และการเชื่อมโยง

ลิงค์

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

สมาคม

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

ปริญญาสมาคม

ระดับของการเชื่อมโยงหมายถึงจำนวนชั้นเรียนที่เกี่ยวข้องกับการเชื่อมต่อ ปริญญาอาจเป็นยูนารีไบนารี่หรือเทอร์นารี

  • unary relationship เชื่อมต่อออบเจ็กต์ของคลาสเดียวกัน

  • binary relationship เชื่อมต่อออบเจ็กต์ของสองคลาส

  • ternary relationship เชื่อมต่อออบเจ็กต์ตั้งแต่สามคลาสขึ้นไป

อัตราส่วนการเต้นของหัวใจของสมาคม

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

  • One–to–One - อ็อบเจ็กต์เดียวของคลาส A เชื่อมโยงกับอ็อบเจ็กต์เดียวของคลาส B

  • One–to–Many - อ็อบเจ็กต์เดียวของคลาส A เชื่อมโยงกับอ็อบเจ็กต์หลายคลาส B

  • Many–to–Many - ออบเจ็กต์ของคลาส A อาจเชื่อมโยงกับอ็อบเจ็กต์คลาส B จำนวนมากและในทางกลับกันอ็อบเจ็กต์ของคลาส B อาจเชื่อมโยงกับอ็อบเจ็กต์คลาส A

การรวมหรือองค์ประกอบ

การรวมหรือองค์ประกอบเป็นความสัมพันธ์ระหว่างคลาสที่คลาสสามารถประกอบขึ้นจากการรวมกันของอ็อบเจ็กต์ของคลาสอื่น ๆ อนุญาตให้วางวัตถุภายในเนื้อหาของคลาสอื่นได้โดยตรง การรวมเรียกว่าความสัมพันธ์ "ส่วนหนึ่งของ" หรือ "มี - a" โดยมีความสามารถในการนำทางจากทั้งหมดไปยังส่วนต่างๆ ออบเจ็กต์รวมคืออ็อบเจ็กต์ที่ประกอบด้วยอ็อบเจ็กต์อื่นอย่างน้อยหนึ่งอ็อบเจ็กต์

Example

ในความสัมพันธ์“ รถยนต์มี - มอเตอร์” รถยนต์คือวัตถุทั้งหมดหรือมวลรวมและมอเตอร์เป็น“ ส่วนหนึ่งของ” ของรถ การรวมตัวอาจแสดงถึง -

  • Physical containment - ตัวอย่างคอมพิวเตอร์ประกอบด้วยจอภาพซีพียูเมาส์แป้นพิมพ์และอื่น ๆ

  • Conceptual containment - ตัวอย่างผู้ถือหุ้นมี - หุ้น

ประโยชน์ของ Object Model

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

ประโยชน์ของการใช้แบบจำลองวัตถุคือ -

  • ช่วยในการพัฒนาซอฟต์แวร์ได้เร็วขึ้น

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

  • รองรับการอัพเกรดที่ค่อนข้างยุ่งยาก

  • ช่วยให้สามารถใช้วัตถุการออกแบบและฟังก์ชันซ้ำได้

  • ช่วยลดความเสี่ยงในการพัฒนาโดยเฉพาะอย่างยิ่งในการรวมระบบที่ซับซ้อน

เราทราบดีว่าเทคนิค Object-Oriented Modeling (OOM) จะแสดงภาพสิ่งต่างๆในแอปพลิเคชันโดยใช้แบบจำลองที่จัดเรียงรอบวัตถุ แนวทางการพัฒนาซอฟต์แวร์ใด ๆ ต้องผ่านขั้นตอนต่อไปนี้ -

  • Analysis,
  • การออกแบบและ
  • Implementation.

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

ขั้นตอนในการพัฒนาซอฟต์แวร์เชิงวัตถุ

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

การวิเคราะห์เชิงวัตถุ

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

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

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

System Design

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

Object Design

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

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

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

การใช้งานและการทดสอบเชิงวัตถุ

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

หลักการของระบบเชิงวัตถุ

กรอบแนวคิดของระบบเชิงวัตถุขึ้นอยู่กับรูปแบบวัตถุ มีองค์ประกอบสองประเภทในระบบเชิงวัตถุ -

Major Elements- โดยหลัก ๆ แล้วหมายความว่าหากโมเดลไม่มีองค์ประกอบใดองค์ประกอบหนึ่งเหล่านี้ก็จะไม่เป็นเชิงวัตถุ องค์ประกอบหลัก 4 ประการ ได้แก่ -

  • Abstraction
  • Encapsulation
  • Modularity
  • Hierarchy

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

  • Typing
  • Concurrency
  • Persistence

สิ่งที่เป็นนามธรรม

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

Grady Booch ได้กำหนดสิ่งที่เป็นนามธรรมไว้ดังนี้ -

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

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

การห่อหุ้ม

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

ความเป็นโมดูลาร์

Modularity เป็นกระบวนการในการแยกปัญหา (โปรแกรม) ออกเป็นชุดของโมดูลเพื่อลดความซับซ้อนโดยรวมของปัญหา Booch ได้กำหนด modularity เป็น -

“ Modularity เป็นคุณสมบัติของระบบที่ถูกย่อยสลายเป็นชุดของโมดูลที่เชื่อมต่อกันและเชื่อมโยงกันอย่างหลวม ๆ ”

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

ลำดับชั้น

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

ลำดับชั้นสองประเภทใน OOA คือ -

  • “IS–A” hierarchy- เป็นการกำหนดความสัมพันธ์ตามลำดับชั้นในการสืบทอดโดยที่มาจาก super-class อาจได้รับ subclasses จำนวนหนึ่งซึ่งอาจมี subclasses อีกครั้งเป็นต้น ตัวอย่างเช่นหากเราได้รับคลาส Rose จากคลาส Flower เราสามารถพูดได้ว่ากุหลาบ“ is – – a”

  • “PART–OF” hierarchy- เป็นการกำหนดความสัมพันธ์แบบลำดับชั้นในการรวมโดยคลาสอาจประกอบด้วยคลาสอื่น ๆ ตัวอย่างเช่นดอกไม้ประกอบด้วยกลีบเลี้ยงกลีบดอกเกสรตัวผู้และดอกคาร์เพิล อาจกล่าวได้ว่ากลีบดอกไม้เป็นดอกไม้“ ส่วนหนึ่งของ”

กำลังพิมพ์

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

การพิมพ์สองประเภทคือ -

  • Strong Typing - ที่นี่การดำเนินการกับวัตถุจะถูกตรวจสอบในช่วงเวลาของการรวบรวมเช่นเดียวกับภาษาโปรแกรม Eiffel

  • Weak Typing- ที่นี่ข้อความอาจถูกส่งไปยังชั้นเรียนใดก็ได้ การดำเนินการจะถูกตรวจสอบในขณะดำเนินการเท่านั้นเช่นเดียวกับในภาษาโปรแกรม Smalltalk

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

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

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

วิริยะ

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

ในการวิเคราะห์ระบบหรือขั้นตอนการวิเคราะห์เชิงวัตถุของการพัฒนาซอฟต์แวร์ข้อกำหนดของระบบจะถูกกำหนดคลาสจะถูกระบุและระบุความสัมพันธ์ระหว่างคลาส

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

การสร้างแบบจำลองวัตถุ

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

กระบวนการสร้างแบบจำลองวัตถุสามารถมองเห็นได้ในขั้นตอนต่อไปนี้ -

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

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

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

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

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

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

การสร้างแบบจำลองการทำงาน

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

กระบวนการสร้างแบบจำลองการทำงานสามารถมองเห็นได้ในขั้นตอนต่อไปนี้ -

  • ระบุอินพุตและเอาต์พุตทั้งหมด
  • สร้างแผนภาพกระแสข้อมูลที่แสดงการพึ่งพาการทำงาน
  • ระบุวัตถุประสงค์ของแต่ละฟังก์ชัน
  • ระบุข้อ จำกัด
  • ระบุเกณฑ์การเพิ่มประสิทธิภาพ

การวิเคราะห์เชิงโครงสร้างเทียบกับการวิเคราะห์เชิงวัตถุ

แนวทางการวิเคราะห์โครงสร้าง / การออกแบบโครงสร้าง (SASD) เป็นแนวทางดั้งเดิมของการพัฒนาซอฟต์แวร์ตามแบบจำลองน้ำตก ขั้นตอนของการพัฒนาระบบโดยใช้ SASD ได้แก่ -

  • การศึกษาความเป็นไปได้
  • การวิเคราะห์ความต้องการและข้อกำหนด
  • การออกแบบระบบ
  • Implementation
  • การตรวจสอบหลังการใช้งาน

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

ข้อดี / ข้อเสียของการวิเคราะห์เชิงวัตถุ

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

ข้อดี / ข้อเสียของการวิเคราะห์โครงสร้าง

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

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

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

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

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

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

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

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

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

สถานะ

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

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

  • 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 - แสดงถึงการจัดโครงสร้างของวัตถุที่ส่งและรับข้อความผ่านจุดยอดและส่วนโค้ง

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Functional Modeling ให้มุมมองกระบวนการของโมเดลการวิเคราะห์เชิงวัตถุและภาพรวมของสิ่งที่ระบบควรทำ เป็นการกำหนดฟังก์ชันของกระบวนการภายในระบบโดยใช้ Data Flow Diagrams (DFDs) มันแสดงให้เห็นถึงการได้มาจากฟังก์ชันของค่าข้อมูลโดยไม่ได้ระบุว่าค่าเหล่านี้ได้มาอย่างไรเมื่อคำนวณหรือทำไมจึงต้องคำนวณ

แผนภาพกระแสข้อมูล

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

Rumbaugh et al. ได้กำหนด DFD ไว้ว่า“ แผนภาพกระแสข้อมูลคือกราฟที่แสดงการไหลของค่าข้อมูลจากแหล่งที่มาในออบเจ็กต์ผ่านกระบวนการที่เปลี่ยนค่าเหล่านั้นไปยังปลายทางบนวัตถุอื่น ๆ ”

สี่ส่วนหลักของ DFD ได้แก่ -

  • Processes,
  • กระแสข้อมูล
  • นักแสดงและ
  • ที่เก็บข้อมูล

ส่วนอื่น ๆ ของ DFD ได้แก่ -

  • ข้อ จำกัด และ
  • ควบคุมโฟลว์

คุณสมบัติของ DFD

กระบวนการ

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

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

Example - รูปต่อไปนี้แสดงกระบวนการ Compute_HCF_LCM ที่ยอมรับจำนวนเต็มสองจำนวนเป็นอินพุตและเอาต์พุต HCF (ปัจจัยร่วมสูงสุด) และ LCM (ตัวคูณร่วมน้อยที่สุด)

กระแสข้อมูล

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

Representation in DFD - โฟลว์ข้อมูลแสดงด้วยส่วนโค้งกำกับหรือลูกศรซึ่งมีชื่อของรายการข้อมูลที่ดำเนินการอยู่

ในรูปด้านบน Integer_a และ Integer_b เป็นตัวแทนของข้อมูลอินพุตที่ไหลไปยังกระบวนการในขณะที่ LCM และ HCF เป็นกระแสข้อมูลเอาต์พุต

กระแสข้อมูลอาจถูกแยกออกในกรณีต่อไปนี้ -

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

  • โฟลว์ข้อมูลประกอบด้วยค่ารวมและแต่ละองค์ประกอบจะถูกส่งไปยังที่ต่างๆดังแสดงในรูปต่อไปนี้ ที่นี่ส่วนประกอบที่แยกแต่ละชิ้นจะมีป้ายกำกับ

นักแสดง

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

Representation in DFD- นักแสดงแสดงด้วยสี่เหลี่ยมผืนผ้า นักแสดงเชื่อมต่อกับอินพุตและเอาต์พุตและอยู่บนขอบเขตของ DFD

Example - รูปต่อไปนี้แสดงตัวแสดง ได้แก่ Customer และ Sales_Clerk ในระบบการขายแบบเคาน์เตอร์

ที่เก็บข้อมูล

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

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

Example- รูปต่อไปนี้แสดงที่เก็บข้อมูล Sales_Record ที่เก็บรายละเอียดของการขายทั้งหมด ข้อมูลที่ป้อนไปยังที่เก็บข้อมูลประกอบด้วยรายละเอียดของการขายเช่นสินค้ายอดเรียกเก็บเงินวันที่ ฯลฯ ในการค้นหายอดขายเฉลี่ยกระบวนการจะดึงบันทึกการขายและคำนวณค่าเฉลี่ย

ข้อ จำกัด

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

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

  • ใน Dynamic Modeling ข้อ จำกัด จะกำหนดความสัมพันธ์ระหว่างสถานะและเหตุการณ์ของออบเจ็กต์ต่างๆ

  • ใน Functional Modeling ข้อ จำกัด จะกำหนดข้อ จำกัด เกี่ยวกับการแปลงและการคำนวณ

Representation - ข้อ จำกัด แสดงเป็นสตริงภายในวงเล็บปีกกา

Example- รูปต่อไปนี้แสดงส่วนหนึ่งของ DFD สำหรับคำนวณเงินเดือนของพนักงานของ บริษัท ที่ตัดสินใจให้สิ่งจูงใจแก่พนักงานทุกคนในแผนกขายและเพิ่มเงินเดือนของพนักงานทุกคนในแผนกทรัพยากรบุคคล จะเห็นได้ว่าข้อ จำกัด {ฝ่าย: ฝ่ายขาย} ทำให้เกิดแรงจูงใจในการคำนวณเฉพาะในกรณีที่แผนกเป็นฝ่ายขายและข้อ จำกัด {ฝ่าย: HR} ทำให้คำนวณส่วนเพิ่มได้ก็ต่อเมื่อแผนกนั้นเป็น HR

ควบคุมโฟลว์

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

Representation in DFD - โฟลว์การควบคุมแสดงด้วยส่วนโค้งประจากกระบวนการที่สร้างค่าบูลีนไปยังกระบวนการที่ควบคุมโดยพวกเขา

Example- รูปต่อไปนี้แสดงถึง DFD สำหรับการหารเลขคณิต Divisor ได้รับการทดสอบว่าไม่ใช่ศูนย์ ถ้าไม่ใช่ศูนย์โฟลว์การควบคุม OK จะมีค่าเป็น True จากนั้นกระบวนการ Divide จะคำนวณ Quotient และ Remainder

การพัฒนาแบบจำลอง DFD ของระบบ

ในการพัฒนาโมเดล DFD ของระบบจะมีการสร้างลำดับชั้นของ DFD DFD ระดับบนสุดประกอบด้วยกระบวนการเดียวและผู้แสดงโต้ตอบกับมัน

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

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

รูปแบบการทำงานสำหรับซอฟต์แวร์ขายส่งมีให้ด้านล่าง รูปด้านล่างแสดง DFD ระดับบนสุด มันแสดงซอฟต์แวร์เป็นกระบวนการเดียวและตัวแสดงที่โต้ตอบกับมัน

ตัวแสดงในระบบ ได้แก่ -

  • Customers
  • Salesperson
  • Proprietor

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

ในระบบสามารถระบุกระบวนการได้ 3 ขั้นตอน ได้แก่ -

  • ลงทะเบียนลูกค้า
  • กระบวนการขาย
  • ขอของขวัญ

ที่เก็บข้อมูลที่จะต้องมีคือ -

  • รายละเอียดลูกค้า
  • รายละเอียดการขาย
  • รายละเอียดของขวัญ

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

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

ข้อดีและข้อเสียของ DFD

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

ความสัมพันธ์ระหว่างโมเดลวัตถุไดนามิกและฟังก์ชัน

Object Model, Dynamic Model และ Functional Model เป็นส่วนเสริมซึ่งกันและกันสำหรับการวิเคราะห์เชิงวัตถุที่สมบูรณ์

  • การสร้างแบบจำลองวัตถุพัฒนาโครงสร้างคงที่ของระบบซอฟต์แวร์ในแง่ของวัตถุ ดังนั้นจึงแสดงให้เห็นถึง "ผู้กระทำ" ของระบบ

  • Dynamic Modeling พัฒนาพฤติกรรมชั่วขณะของวัตถุเพื่อตอบสนองต่อเหตุการณ์ภายนอก แสดงลำดับของการดำเนินการกับวัตถุ

  • แบบจำลองการทำงานจะให้ภาพรวมของสิ่งที่ระบบควรทำ

Functional Model และ Object Model

สี่ส่วนหลักของ Functional Model ในแง่ของ Object Model คือ -

  • Process - กระบวนการหมายถึงวิธีการของวัตถุที่ต้องดำเนินการ

  • Actors - นักแสดงเป็นวัตถุในแบบจำลองวัตถุ

  • Data Stores - สิ่งเหล่านี้เป็นวัตถุในโมเดลวัตถุหรือคุณลักษณะของวัตถุ

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

Functional Model และ Dynamic Model

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

แบบจำลองวัตถุและแบบจำลองแบบไดนามิก

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

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

ประวัติย่อ

ได้รับการพัฒนาในปี 1990 โดยเป็นการผสมผสานระหว่างเทคนิคต่างๆซึ่งเป็นเทคนิค OOAD ที่โดดเด่นโดย Grady Booch, OMT (Object Modeling Technique) โดย James Rumbaugh และ OOSE (Object Oriented Software Engineering) โดย Ivar Jacobson UML พยายามสร้างมาตรฐานแบบจำลองความหมายสัญกรณ์วากยสัมพันธ์และไดอะแกรมของ OOAD

ระบบและโมเดลใน UML

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

Model - แบบจำลองเป็นนามธรรมที่เรียบง่ายสมบูรณ์และสอดคล้องกันของระบบสร้างขึ้นเพื่อให้เข้าใจระบบได้ดีขึ้น

View - มุมมองคือการฉายภาพแบบจำลองของระบบจากมุมมองเฉพาะ

แบบจำลองแนวคิดของ UML

แบบจำลองแนวคิดของ UML ประกอบด้วยองค์ประกอบหลักสามประการ -

  • หน่วยการสร้างพื้นฐาน
  • Rules
  • กลไกทั่วไป

หน่วยการสร้างพื้นฐาน

โครงสร้างพื้นฐานทั้งสามของ UML คือ -

  • Things
  • Relationships
  • Diagrams

สิ่งต่างๆ

UML มีสี่สิ่ง ได้แก่ -

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

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

  • Grouping Things- ประกอบด้วยส่วนขององค์กรของแบบจำลอง UML มีเพียงชนิดเดียวของการจัดกลุ่มคือแพคเกจ

  • Annotational Things - นี่คือคำอธิบายในโมเดล UML ที่แสดงความคิดเห็นที่ใช้เพื่ออธิบายองค์ประกอบ

ความสัมพันธ์

ความสัมพันธ์คือการเชื่อมต่อระหว่างสิ่งต่างๆ ความสัมพันธ์สี่ประเภทที่สามารถแสดงใน UML ได้แก่ -

  • Dependency- นี่คือความสัมพันธ์เชิงความหมายระหว่างสองสิ่งที่การเปลี่ยนแปลงในสิ่งหนึ่งนำมาซึ่งการเปลี่ยนแปลงในอีกสิ่งหนึ่ง อดีตเป็นสิ่งที่เป็นอิสระในขณะที่สิ่งหลังเป็นสิ่งที่พึ่งพา

  • Association - นี่คือความสัมพันธ์เชิงโครงสร้างที่แสดงถึงกลุ่มของลิงก์ที่มีโครงสร้างและพฤติกรรมร่วมกัน

  • Generalization - นี่แสดงถึงความสัมพันธ์ลักษณะทั่วไป / ความเชี่ยวชาญซึ่งคลาสย่อยสืบทอดโครงสร้างและพฤติกรรมจากซุปเปอร์คลาส

  • Realization - นี่คือความสัมพันธ์เชิงความหมายระหว่างตัวแยกประเภทตั้งแต่สองตัวขึ้นไปซึ่งตัวลักษณนามหนึ่งวางสัญญาที่ตัวแยกประเภทอื่นรับรองว่าจะปฏิบัติ

ไดอะแกรม

แผนภาพคือการแสดงภาพกราฟิกของระบบ ประกอบด้วยกลุ่มขององค์ประกอบโดยทั่วไปในรูปแบบของกราฟ UML มีเก้าแผนภาพทั้งหมดกล่าวคือ -

  • แผนภาพชั้นเรียน
  • แผนภาพวัตถุ
  • ใช้ Case Diagram
  • แผนภาพลำดับ
  • แผนภาพการทำงานร่วมกัน
  • แผนภาพแผนภูมิสถานะ
  • แผนภาพกิจกรรม
  • แผนภาพส่วนประกอบ
  • แผนภาพการปรับใช้

กฎ

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

  • Names
  • Scope
  • Visibility
  • Integrity
  • Execution

กลไกทั่วไป

UML มีกลไกทั่วไปสี่ประการ -

  • Specifications
  • Adornments
  • หน่วยงานทั่วไป
  • กลไกการขยาย

ข้อมูลจำเพาะ

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

เครื่องประดับ

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

หน่วยงานทั่วไป

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

  • Division of classes and objects- คลาสคือสิ่งที่เป็นนามธรรมของกลุ่มวัตถุที่คล้ายกัน วัตถุคือตัวอย่างที่เป็นรูปธรรมที่มีอยู่จริงในระบบ

  • Division of Interface and Implementation- อินเทอร์เฟซกำหนดกฎสำหรับการโต้ตอบ การนำไปใช้งานคือการทำให้เป็นจริงอย่างเป็นรูปธรรมของกฎที่กำหนดไว้ในอินเทอร์เฟซ

กลไกการขยาย

UML เป็นภาษาปลายเปิด เป็นไปได้ที่จะขยายขีดความสามารถของ UML ในลักษณะควบคุมเพื่อให้เหมาะกับความต้องการของระบบ กลไกการขยายคือ -

  • Stereotypes - ขยายคำศัพท์ของ UML ซึ่งสามารถสร้าง Building Block ใหม่จากที่มีอยู่ได้

  • Tagged Values - ขยายคุณสมบัติของหน่วยการสร้าง UML

  • Constraints - ขยายความหมายของหน่วยการสร้าง UML

UML กำหนดสัญกรณ์เฉพาะสำหรับแต่ละหน่วยการสร้าง

คลาส

ชั้นเรียนแสดงด้วยสี่เหลี่ยมผืนผ้าที่มีสามส่วน -

  • ส่วนบนสุดที่มีชื่อของคลาส
  • ส่วนตรงกลางมีแอตทริบิวต์คลาส
  • ส่วนด้านล่างแสดงการดำเนินการของชั้นเรียน

การมองเห็นคุณลักษณะและการดำเนินการสามารถแสดงได้ด้วยวิธีต่อไปนี้ -

  • Public- สมาชิกสาธารณะสามารถมองเห็นได้จากทุกที่ในระบบ ในแผนภาพชั้นเรียนจะนำหน้าด้วยสัญลักษณ์ '+'

  • Private- สมาชิกส่วนตัวสามารถมองเห็นได้จากในชั้นเรียนเท่านั้น ไม่สามารถเข้าถึงได้จากภายนอกชั้นเรียน สมาชิกส่วนตัวนำหน้าด้วยสัญลักษณ์ '-'

  • Protected- สมาชิกที่ได้รับการป้องกันสามารถมองเห็นได้จากภายในคลาสและจากคลาสย่อยที่สืบทอดมาจากคลาสนี้ แต่ไม่ใช่จากภายนอก คำนำหน้าด้วยสัญลักษณ์ '#'

คลาสนามธรรมมีชื่อคลาสที่เขียนเป็นตัวเอียง

Example- ให้เราพิจารณาคลาส Circle ที่เปิดตัวก่อนหน้านี้ แอตทริบิวต์ของ Circle คือ x-พิกัดพิกัด y และรัศมี การดำเนินการคือ findArea (), findCircumference () และ scale () สมมติว่า x-Coord และ y-Coord เป็นสมาชิกข้อมูลส่วนตัว, radius เป็นสมาชิกข้อมูลที่ได้รับการป้องกันและฟังก์ชันของสมาชิกเป็นแบบสาธารณะ รูปต่อไปนี้เป็นการแสดงแผนภาพของคลาส

วัตถุ

วัตถุถูกแสดงเป็นรูปสี่เหลี่ยมผืนผ้าโดยมีสองส่วน -

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

    • object-name - ชื่อชั้น

    • object-name - ชื่อชั้น :: ชื่อแพ็คเกจ

    • class-name - ในกรณีของวัตถุที่ไม่ระบุชื่อ

  • ส่วนด้านล่างแสดงถึงค่าของแอตทริบิวต์ ใช้รูปแบบแอตทริบิวต์ name = ค่า

  • บางครั้งวัตถุจะแสดงโดยใช้สี่เหลี่ยมมน

Example- ให้เราพิจารณาวัตถุของคลาส Circle ชื่อ c1 เราถือว่าจุดศูนย์กลางของ c1 อยู่ที่ (2, 3) และรัศมีของ c1 คือ 5 รูปต่อไปนี้แสดงถึงวัตถุ

ส่วนประกอบ

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

Notation - ในแผนภาพ UML ส่วนประกอบจะแสดงด้วยสี่เหลี่ยมผืนผ้าพร้อมแท็บดังแสดงในรูปด้านล่าง

อินเตอร์เฟซ

อินเทอร์เฟซคือชุดของวิธีการของคลาสหรือส่วนประกอบ ระบุชุดของบริการที่อาจมีให้โดยคลาสหรือส่วนประกอบ

Notation- โดยทั่วไปอินเทอร์เฟซจะวาดเป็นวงกลมพร้อมกับชื่อ อินเทอร์เฟซมักจะเชื่อมต่อกับคลาสหรือส่วนประกอบที่ใช้งานได้ รูปต่อไปนี้ให้สัญกรณ์ของอินเทอร์เฟซ

แพ็คเกจ

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

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

ความสัมพันธ์

สัญกรณ์สำหรับความสัมพันธ์ประเภทต่างๆมีดังนี้ -

โดยปกติองค์ประกอบในความสัมพันธ์จะมีบทบาทเฉพาะในความสัมพันธ์ ชื่อบทบาทหมายถึงพฤติกรรมขององค์ประกอบที่เข้าร่วมในบริบทหนึ่ง ๆ

Example- ตัวเลขต่อไปนี้แสดงตัวอย่างของความสัมพันธ์ที่แตกต่างกันระหว่างคลาส รูปแรกแสดงความสัมพันธ์ระหว่างสองชั้นเรียนแผนกและพนักงานซึ่งแผนกหนึ่งอาจมีพนักงานจำนวนหนึ่งทำงานอยู่ คนงานคือชื่อบทบาท เครื่องหมาย '1' ข้างแผนกและ '*' ข้างพนักงานแสดงให้เห็นว่าอัตราส่วนคาร์ดินาลลิตี้คือหนึ่งต่อหลาย รูปที่สองแสดงให้เห็นถึงความสัมพันธ์ในการรวมตัวกันมหาวิทยาลัยคือหน่วยงานที่ "ทั้งหมด - ทั้งหมด"

แผนภาพโครงสร้าง UML แบ่งออกเป็นดังนี้: แผนภาพคลาสแผนภาพออบเจ็กต์แผนภาพส่วนประกอบและแผนภาพการปรับใช้

แผนภาพชั้นเรียน

แผนภาพคลาสจะจำลองมุมมองแบบคงที่ของระบบ ประกอบด้วยคลาสอินเทอร์เฟซและการทำงานร่วมกันของระบบ และความสัมพันธ์ระหว่างกัน

แผนภาพคลาสของระบบ

ให้เราพิจารณาระบบการธนาคารที่เรียบง่าย

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

รูปต่อไปนี้แสดงแผนภาพคลาสที่เกี่ยวข้อง

ชั้นเรียนในระบบ

ธนาคารสาขาบัญชีบัญชีออมทรัพย์บัญชีกระแสรายวันเงินกู้และลูกค้า

ความสัมพันธ์

  • A Bank “has–a” number of Branches - องค์ประกอบหนึ่งถึงหลายคน

  • A Branch with role Zonal Head Office supervises other Branches - การเชื่อมโยงแบบหนึ่งต่อหลายคน

  • A Branch “has–a” number of accounts - การรวมแบบหนึ่งถึงหลาย ๆ

จากบัญชีชั้นเรียนจะมีการสืบทอดสองชั้นคือบัญชีออมทรัพย์และบัญชีกระแสรายวัน

  • A Customer can have one Current Account - การเชื่อมโยงแบบหนึ่งต่อหนึ่ง

  • A Customer can have one Savings Account - การเชื่อมโยงแบบหนึ่งต่อหนึ่ง

  • A Branch “has–a” number of Loans - การรวมแบบหนึ่งถึงหลาย ๆ

  • A Customer can take many loans - สมาคมหนึ่งถึงหลายคน

แผนภาพวัตถุ

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

Example - รูปต่อไปนี้แสดงแผนภาพวัตถุของส่วนหนึ่งของแผนภาพคลาสของระบบธนาคาร

แผนภาพส่วนประกอบ

แผนภาพส่วนประกอบแสดงองค์กรและการอ้างอิงระหว่างกลุ่มของส่วนประกอบ

แผนภาพส่วนประกอบประกอบด้วย -

  • Components
  • Interfaces
  • Relationships
  • แพ็คเกจและระบบย่อย (ทางเลือก)

แผนภาพคอมโพเนนต์ใช้สำหรับ -

  • การสร้างระบบผ่านวิศวกรรมไปข้างหน้าและย้อนกลับ

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

  • เป็นตัวแทนของสกีมาในการสร้างแบบจำลองฐานข้อมูล

  • พฤติกรรมการสร้างแบบจำลองของระบบไดนามิก

Example

รูปต่อไปนี้แสดงแผนภาพส่วนประกอบเพื่อจำลองซอร์สโค้ดของระบบที่พัฒนาโดยใช้ C ++ มันแสดงไฟล์ซอร์สโค้ดสี่ไฟล์ ได้แก่ myheader.h, otherheader.h, priority.cpp และ other.cpp มีการแสดง myheader.h สองเวอร์ชันโดยติดตามจากเวอร์ชันล่าสุดไปยังบรรพบุรุษ ไฟล์ priority.cpp มีการพึ่งพาการคอมไพล์บน other.cpp ไฟล์ other.cpp มีการพึ่งพาการคอมไพล์บน otherheader.h

แผนภาพการปรับใช้

แผนภาพการปรับใช้ให้ความสำคัญกับการกำหนดค่าโหนดการประมวลผลรันไทม์และส่วนประกอบที่อาศัยอยู่ โดยทั่วไปประกอบด้วยโหนดและการอ้างอิงหรือการเชื่อมโยงระหว่างโหนด

ไดอะแกรมการปรับใช้ใช้เพื่อ -

  • อุปกรณ์จำลองในระบบฝังตัวที่โดยทั่วไปประกอบด้วยชุดฮาร์ดแวร์ที่ใช้ซอฟต์แวร์เป็นจำนวนมาก

  • แสดงถึงโทโพโลยีของระบบไคลเอนต์ / เซิร์ฟเวอร์

  • แบบจำลองระบบกระจายเต็มรูปแบบ

Example

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

แผนภาพพฤติกรรม UML แสดงภาพระบุสร้างและจัดทำเอกสารด้านไดนามิกของระบบ แผนภาพพฤติกรรมแบ่งออกเป็นดังนี้: ใช้แผนภาพกรณี, แผนภาพปฏิสัมพันธ์, แผนภาพแผนภูมิสถานะและแผนภาพกิจกรรม

ใช้ Case Model

ใช้กรณี

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

นักแสดงชาย

นักแสดงแสดงถึงบทบาทที่ผู้ใช้กรณีการใช้งานเล่น นักแสดงอาจเป็นบุคคล (เช่นนักเรียนลูกค้า) อุปกรณ์ (เช่นเวิร์กสเตชัน) หรือระบบอื่น (เช่นธนาคารสถาบัน)

รูปต่อไปนี้แสดงสัญกรณ์ของนักแสดงชื่อนักศึกษาและกรณีการใช้งานที่เรียกว่าสร้างรายงานประสิทธิภาพ

ใช้แผนภาพกรณี

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

แผนภาพกรณีใช้งานประกอบด้วย -

  • ใช้กรณี
  • Actors
  • ความสัมพันธ์เช่นการพึ่งพาการวางนัยทั่วไปและการเชื่อมโยง

ใช้ไดอะแกรมกรณีใช้ -

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

  • เพื่อจำลองข้อกำหนดของระบบจากมุมมองภายนอก

Example

ให้เราพิจารณาระบบซื้อขายบ้านอัตโนมัติ เราถือว่าคุณสมบัติของระบบดังต่อไปนี้ -

  • บ้านซื้อขายมีธุรกรรมกับลูกค้าสองประเภทลูกค้าบุคคลและลูกค้าองค์กร

  • เมื่อลูกค้าสั่งซื้อสินค้าจะถูกดำเนินการโดยฝ่ายขายและลูกค้าจะได้รับใบเรียกเก็บเงิน

  • ระบบช่วยให้ผู้จัดการสามารถจัดการบัญชีลูกค้าและตอบคำถามที่ลูกค้าโพสต์ไว้

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

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

  • แผนภาพลำดับ
  • แผนภาพการทำงานร่วมกัน

แผนภาพปฏิสัมพันธ์ใช้สำหรับการสร้างแบบจำลอง -

  • ขั้นตอนการควบคุมตามลำดับเวลาโดยใช้แผนภาพลำดับ

  • ขั้นตอนการควบคุมขององค์กรโดยใช้แผนภาพการทำงานร่วมกัน

แผนภาพลำดับ

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

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

Example - แผนภาพลำดับสำหรับระบบซื้อขายบ้านอัตโนมัติแสดงดังรูปต่อไปนี้

แผนภาพการทำงานร่วมกัน

แผนภาพการทำงานร่วมกันคือแผนภาพปฏิสัมพันธ์ที่แสดงโครงสร้างของวัตถุที่ส่งและรับข้อความ

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

Example - แผนภาพความร่วมมือสำหรับระบบซื้อขายบ้านอัตโนมัติแสดงอยู่ในรูปด้านล่าง

แผนภาพรัฐ - แผนภูมิ

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

State – Chart Diagram ประกอบด้วย -

  • รัฐ: ง่ายหรือผสม
  • การเปลี่ยนระหว่างรัฐ
  • เหตุการณ์ที่ทำให้เกิดการเปลี่ยนแปลง
  • การดำเนินการเนื่องจากเหตุการณ์

แผนภาพแผนภูมิสถานะใช้สำหรับการสร้างแบบจำลองวัตถุที่มีปฏิกิริยาในธรรมชาติ

Example

ในระบบ Automated Trading House ให้เราสร้างแบบจำลอง Order เป็นวัตถุและติดตามลำดับ รูปต่อไปนี้แสดงแผนผังสถานะที่สอดคล้องกัน

แผนภาพกิจกรรม

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

แผนภาพกิจกรรมประกอบด้วย -

  • สถานะกิจกรรมและสถานะการดำเนินการ
  • Transitions
  • Objects

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

  • เวิร์กโฟลว์ตามที่นักแสดงดูการโต้ตอบกับระบบ
  • รายละเอียดของการดำเนินการหรือการคำนวณโดยใช้ผังงาน

Example

รูปต่อไปนี้แสดงแผนภาพกิจกรรมของส่วนหนึ่งของระบบซื้อขายบ้านอัตโนมัติ

หลังจากขั้นตอนการวิเคราะห์โมเดลแนวความคิดจะถูกพัฒนาต่อไปเป็นโมเดลเชิงวัตถุโดยใช้การออกแบบเชิงวัตถุ (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 แทนการบรรยาย

การใช้การออกแบบเชิงวัตถุโดยทั่วไปเกี่ยวข้องกับการใช้ภาษาโปรแกรมเชิงวัตถุมาตรฐาน (OOPL) หรือการออกแบบวัตถุการแม็ปกับฐานข้อมูล ในกรณีส่วนใหญ่เกี่ยวข้องกับทั้งสองอย่าง

การใช้งานโดยใช้ภาษาโปรแกรม

โดยปกติงานในการเปลี่ยนการออกแบบวัตถุเป็นรหัสเป็นกระบวนการที่ตรงไปตรงมา ภาษาโปรแกรมเชิงวัตถุใด ๆ เช่น C ++, Java, Smalltalk, C # และ Python รวมถึงการจัดเตรียมสำหรับการแสดงคลาส ในบทนี้เรายกตัวอย่างแนวคิดโดยใช้ C ++

รูปต่อไปนี้แสดงการเป็นตัวแทนของคลาส Circle โดยใช้ C ++

การดำเนินการสมาคม

ภาษาโปรแกรมส่วนใหญ่ไม่ได้จัดเตรียมโครงสร้างเพื่อใช้การเชื่อมโยงโดยตรง ดังนั้นงานในการดำเนินการเชื่อมโยงจึงต้องใช้ความคิดอย่างรอบคอบ

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

สมาคมทิศทางเดียว

สำหรับการดำเนินการเชื่อมโยงทิศทางเดียวควรใช้ความระมัดระวังเพื่อให้คงความเป็นทิศทางเดียว การใช้งานสำหรับหลายหลากที่แตกต่างกันมีดังนี้ -

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

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

class Customer {
   private:
   // attributes
   Current_Account c; //an object of Current_Account as attribute
   
   public:  

   Customer() {
      c = NULL; 
   } // assign c as NULL

   Current_Account getCurrAc() {
      return c;
   }
   
   void setCurrAc( Current_Account myacc) {
      c = myacc;
   }

   void removeAcc() {  
      c = NULL;
   } 
};
  • One–to–one Associations- ที่นี่อินสแตนซ์หนึ่งของคลาสที่เกี่ยวข้องกับอินสแตนซ์หนึ่งของคลาสที่เกี่ยวข้อง ตัวอย่างเช่นแผนกและผู้จัดการมีการเชื่อมโยงแบบหนึ่งต่อหนึ่งดังแสดงในรูปด้านล่าง

สิ่งนี้ถูกนำไปใช้โดยรวมไว้ในแผนกซึ่งเป็นวัตถุของผู้จัดการที่ไม่ควรเป็นโมฆะ การใช้งานโดยใช้ C ++ -

class Department {
   private:
   // attributes
   Manager mgr; //an object of Manager as attribute
   
   public:  
   Department (/*parameters*/, Manager m) { //m is not NULL   
      // assign parameters to variables
      mgr = m;
   } 

   Manager getMgr() {  
      return mgr;  
   }    
};
  • One–to–many Associations- ที่นี่อินสแตนซ์หนึ่งของคลาสที่เกี่ยวข้องกับมากกว่าหนึ่งอินสแตนซ์ของคลาสที่เกี่ยวข้อง ตัวอย่างเช่นพิจารณาความสัมพันธ์ระหว่างพนักงานและผู้อยู่ในอุปการะในรูปต่อไปนี้

สิ่งนี้ดำเนินการโดยรวมรายชื่อผู้อยู่ในอุปการะในคลาสพนักงาน การใช้งานโดยใช้คอนเทนเนอร์รายการ C ++ STL -

class Employee {
   private:
   char * deptName;
   list <Dependent> dep; //a list of Dependents as attribute

   public:  
   void addDependent ( Dependent d) { 
      dep.push_back(d); 
   } // adds an employee to the department

   void removeDeoendent( Dependent d) { 
      int index = find ( d, dep );
      // find() function returns the index of d in list dep
      dep.erase(index);
   }               
};

สมาคมสองทิศทาง

ในการใช้การเชื่อมโยงแบบสองทิศทางจำเป็นต้องมีการบำรุงรักษาลิงก์ทั้งสองทิศทาง

  • Optional or one–to–one Associations - พิจารณาความสัมพันธ์ระหว่าง Project และ Project Manager ที่มีการเชื่อมโยงแบบสองทิศทางแบบหนึ่งต่อหนึ่งดังแสดงในรูปด้านล่าง

การใช้งานโดยใช้ C ++ -

Class Project {
   private:
   // attributes
   Project_Manager pmgr; 
   public:  
   void setManager ( Project_Manager pm);       
   Project_Manager changeManager();   
};

class Project_Manager {
   private:
   // attributes
   Project pj; 

   public:  
   void setProject(Project p);       
   Project removeProject();   
};
  • One–to–many Associations - พิจารณาความสัมพันธ์ระหว่างแผนกและพนักงานที่มีความสัมพันธ์แบบหนึ่งต่อหลายสมาคมดังแสดงในรูปด้านล่าง

การใช้งานโดยใช้คอนเทนเนอร์รายการ C ++ STL

class Department {
   private:
   char * deptName;
   list <Employee> emp; //a list of Employees as attribute

   public:  
   void addEmployee ( Employee e) { 
      emp.push_back(e); 
   } // adds an employee to the department

   void removeEmployee( Employee e) { 
      int index = find ( e, emp );
      // find function returns the index of e in list emp
      emp.erase(index);
   }               
};

class Employee {
   private:
   //attributes
   Department d;

   public:
   void addDept();
   void removeDept();
};

การนำสมาคมมาใช้เป็นชั้นเรียน

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

การใช้งาน WorksOn โดยใช้ C ++

class WorksOn {
   private:
   Employee e; 
   Project p;
   Hours h;
   char * date;

   public:
   // class methods
};

การดำเนินการตามข้อ จำกัด

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

Example

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

class Employee {
   private: char * name;
   int age;
   // other attributes

   public:
   Employee() {                 // default constructor   
      strcpy(name, "");
      age = 18;                // default value
   }
 
   class AgeError {};          // Exception class
   void changeAge( int a) {    // method that changes age

      if ( a < 18 || a > 60 )  // check for invalid condition
      throw AgeError();        // throw exception
      age = a;			
   }
};

การติดตั้ง State Charts

มีกลยุทธ์การใช้งานทางเลือกสองวิธีในการใช้สถานะในแผนภาพแผนภูมิของรัฐ

การแจงนับภายในคลาส

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

การจัดชั้นเรียนในลำดับชั้นทั่วไป

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

การแมปวัตถุกับระบบฐานข้อมูล

ความคงอยู่ของวัตถุ

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

ภาพรวมของ RDBMS

ฐานข้อมูลคือชุดข้อมูลที่เกี่ยวข้องตามลำดับ

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

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

แต่ละแถวจะถูกระบุโดยไม่ซ้ำกันโดยชุดแอตทริบิวต์ขั้นต่ำที่เลือกซึ่งเรียกว่า primary key.

foreign key เป็นแอตทริบิวต์ที่เป็นคีย์หลักของตารางที่เกี่ยวข้อง

การแสดงคลาสเป็นตารางใน RDBMS

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

ตัวอย่างเช่นคลาส Circle สามารถแปลงเป็นตารางได้ดังแสดงในรูปด้านล่าง

Schema for Circle Table: CIRCLE(CID, X_COORD, Y_COORD, RADIUS, COLOR)
Creating a Table Circle using SQL command:
CREATE TABLE CIRCLE (   
   CID	VARCHAR2(4) PRIMARY KEY,
   X_COORD INTEGER NOT NULL,
   Y_COORD INTEGER NOT NULL,
   Z_COORD INTEGER NOT NULL,
   COLOR 
);

การแมปความสัมพันธ์กับตารางฐานข้อมูล

สมาคมแบบหนึ่งต่อหนึ่ง

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

คำสั่ง SQL เพื่อสร้างตาราง

CREATE TABLE DEPARTMENT ( 
   DEPT_ID INTEGER PRIMARY KEY,
   DNAME VARCHAR2(30) NOT NULL,
   LOCATION VARCHAR2(20),
   EMPID INTEGER REFERENCES MANAGER 
);

CREATE TABLE MANAGER ( 
   EMPID INTEGER PRIMARY KEY,
   ENAME VARCHAR2(50) NOT NULL,
   ADDRESS VARCHAR2(70),
);

หนึ่งถึงหลายสมาคม

ในการใช้การเชื่อมโยง 1: N คีย์หลักของตารางในด้าน 1 ของการเชื่อมโยงจะถูกกำหนดให้เป็นคีย์ต่างประเทศของตารางที่ด้าน N ของการเชื่อมโยง ตัวอย่างเช่นพิจารณาความสัมพันธ์ระหว่างแผนกและพนักงาน -

คำสั่ง SQL เพื่อสร้างตาราง

CREATE TABLE DEPARTMENT ( 
   DEPT_ID INTEGER PRIMARY KEY,
   DNAME VARCHAR2(30) NOT NULL,
   LOCATION VARCHAR2(20),
);

CREATE TABLE EMPLOYEE ( 
   EMPID INTEGER PRIMARY KEY,
   ENAME VARCHAR2(50) NOT NULL,
   ADDRESS VARCHAR2(70),
   D_ID INTEGER REFERENCES DEPARTMENT
);

หลายต่อหลายสมาคม

ในการใช้การเชื่อมโยง M: N ความสัมพันธ์ใหม่จะถูกสร้างขึ้นซึ่งแสดงถึงการเชื่อมโยง ตัวอย่างเช่นพิจารณาความสัมพันธ์ต่อไปนี้ระหว่างพนักงานและโครงการ -

Schema for Works_On Table - WORKS_ON (EMPID, PID, HOURS, START_DATE)

SQL command to create Works_On association - สร้างตาราง WORKS_ON

( 
   EMPID INTEGER,
   PID INTEGER, 
   HOURS INTEGER,
   START_DATE DATE,
   PRIMARY KEY (EMPID, PID),
   FOREIGN KEY (EMPID) REFERENCES EMPLOYEE,
   FOREIGN KEY (PID) REFERENCES PROJECT 
);

การแมปมรดกกับตาราง

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

Example

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

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

การทดสอบระบบเชิงวัตถุ

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

การทดสอบหน่วย

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

การทดสอบระบบย่อย

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

การทดสอบระบบ

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

เทคนิคการทดสอบเชิงวัตถุ

การทดสอบกล่องสีเทา

กรณีทดสอบประเภทต่างๆที่สามารถออกแบบมาสำหรับการทดสอบโปรแกรมเชิงวัตถุเรียกว่ากรณีทดสอบกล่องสีเทา การทดสอบกล่องสีเทาที่สำคัญบางประเภท ได้แก่ -

  • State model based testing - ครอบคลุมถึงความครอบคลุมของรัฐการครอบคลุมการเปลี่ยนแปลงของรัฐและการครอบคลุมเส้นทางการเปลี่ยนสถานะ

  • Use case based testing - แต่ละสถานการณ์ในแต่ละกรณีการใช้งานได้รับการทดสอบ

  • Class diagram based testing - แต่ละคลาสคลาสที่ได้รับการเชื่อมโยงและการรวมจะถูกทดสอบ

  • Sequence diagram based testing - มีการทดสอบวิธีการในข้อความในแผนภาพลำดับ

เทคนิคการทดสอบระบบย่อย

สองแนวทางหลักของการทดสอบระบบย่อยคือ -

  • Thread based testing - คลาสทั้งหมดที่จำเป็นในการใช้งานกรณีเดียวในระบบย่อยจะรวมและทดสอบ

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

ประเภทของการทดสอบระบบ

  • Alpha testing - ดำเนินการโดยทีมทดสอบภายในองค์กรที่พัฒนาซอฟต์แวร์

  • Beta testing - ดำเนินการโดยกลุ่มลูกค้าร่วมปฏิบัติการที่เลือก

  • Acceptance testing - ลูกค้าจะต้องดำเนินการก่อนที่จะยอมรับการส่งมอบ

การประกันคุณภาพซอฟต์แวร์

คุณภาพซอฟต์แวร์

Schulmeyer และ McManus ได้กำหนดคุณภาพซอฟต์แวร์ว่าเป็น "ความเหมาะสมในการใช้ผลิตภัณฑ์ซอฟต์แวร์ทั้งหมด" ซอฟต์แวร์คุณภาพดีทำในสิ่งที่ควรทำและตีความในแง่ของความพึงพอใจของข้อกำหนดข้อกำหนดที่ผู้ใช้วางไว้

การประกันคุณภาพ

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

  • Auditing
  • การพัฒนามาตรฐานและแนวปฏิบัติ
  • การผลิตรายงาน
  • การทบทวนระบบคุณภาพ

ปัจจัยด้านคุณภาพ

  • Correctness - ความถูกต้องเป็นตัวกำหนดว่าตรงตามข้อกำหนดของซอฟต์แวร์หรือไม่

  • Usability - ความสามารถในการใช้งานเป็นตัวกำหนดว่าซอฟต์แวร์สามารถใช้กับผู้ใช้ประเภทต่างๆได้หรือไม่ (ผู้เริ่มต้นไม่ใช้เทคนิคและผู้เชี่ยวชาญ)

  • Portability - ความสามารถในการพกพาเป็นตัวกำหนดว่าซอฟต์แวร์สามารถทำงานในแพลตฟอร์มต่างๆด้วยอุปกรณ์ฮาร์ดแวร์ที่แตกต่างกันได้หรือไม่

  • Maintainability - การบำรุงรักษาเป็นตัวกำหนดความสะดวกในการแก้ไขข้อผิดพลาดและสามารถอัปเดตโมดูลได้

  • Reusability - ความสามารถในการนำกลับมาใช้ใหม่กำหนดว่าโมดูลและคลาสสามารถนำกลับมาใช้เพื่อพัฒนาผลิตภัณฑ์ซอฟต์แวร์อื่น ๆ ได้หรือไม่

เมตริกเชิงวัตถุ

เมตริกสามารถแบ่งออกเป็นสามประเภทอย่างกว้าง ๆ ได้แก่ เมตริกโครงการเมตริกผลิตภัณฑ์และเมตริกกระบวนการ

เมตริกโครงการ

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

  • จำนวนสคริปต์สถานการณ์
  • จำนวนคลาสที่สำคัญ
  • จำนวนคลาสการสนับสนุน
  • จำนวนระบบย่อย

เมตริกผลิตภัณฑ์

เมตริกผลิตภัณฑ์วัดคุณลักษณะของผลิตภัณฑ์ซอฟต์แวร์ที่ได้รับการพัฒนา เมตริกผลิตภัณฑ์ที่เหมาะสำหรับระบบเชิงวัตถุ ได้แก่ -

  • Methods per Class- กำหนดความซับซ้อนของคลาส หากสมมติว่าเมธอดทั้งหมดของคลาสมีความซับซ้อนเท่า ๆ กันคลาสที่มีเมธอดมากกว่านั้นจะซับซ้อนกว่าและทำให้เกิดข้อผิดพลาดได้ง่ายขึ้น

  • Inheritance Structure- ระบบที่มีโครงร่างการสืบทอดขนาดเล็กหลายแบบมีโครงสร้างที่ดีกว่าระบบที่มีช่องตาข่ายการสืบทอดขนาดใหญ่เพียงช่องเดียว ตามกฎทั่วไปต้นไม้มรดกไม่ควรมีจำนวนเลเวลมากกว่า 7 (± 2) และต้นไม้ควรมีความสมดุล

  • Coupling and Cohesion - โมดูลที่มีการเชื่อมต่อต่ำและการเชื่อมต่อกันสูงได้รับการพิจารณาว่าได้รับการออกแบบที่ดีกว่าเนื่องจากอนุญาตให้ใช้ซ้ำและบำรุงรักษาได้มากขึ้น

  • Response for a Class - วัดประสิทธิภาพของเมธอดที่เรียกใช้โดยอินสแตนซ์ของคลาส

เมตริกกระบวนการ

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

  • จำนวน KLOC (บรรทัดรหัสกิโล)
  • ประสิทธิภาพในการกำจัดข้อบกพร่อง
  • จำนวนความล้มเหลวโดยเฉลี่ยที่ตรวจพบระหว่างการทดสอบ
  • จำนวนข้อบกพร่องแฝงต่อ KLOC