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

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

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

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

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