วิชา COMP342 วิศวกรรมซอฟต์แวร์ (Software Engineering)

Slides:



Advertisements
งานนำเสนอที่คล้ายกัน
บทที่ 5 แบบจำลองระบบ System Model.
Advertisements

การติดตามและ ประเมินผลโครงการ
System Requirement Collection (2)
บทที่ 3 การบริหารพนักงานขาย
ระบบสารสนเทศทางธุรกิจ (Business Information Systems)
การประเมินผลโครงการ บทที่ 9 ผศ.ญาลดา พรประเสริฐ yalada.
แบบจำลองฐานข้อมูล คือ เครื่องมือในเชิงแนวคิดที่ใช้ในการอธิบาย ข้อมูล
 เครือข่ายคอมพิวเตอร์  การที่ระบบเครือข่ายมีบทบาทและ ความสำคัญเพิ่มขึ้น เพราะไมโครคอมพิวเตอร์ได้รับ การใช้งานอย่างแพร่หลาย จึงเกิดความต้องการที่จะ.
คอมพิวเตอร์ช่วยสอน (CAI)
System Database Semester 1, 2009 Worrakit Sanpote 1.
Entity-Relationship Model E-R Model
ซอฟต์แวร์ระบบที่รู้จักกันดี คือซอฟต์แวร์ควบคุมการปฏิบัติการ ของคอมพิวเตอร์ที่เรียกว่า ระบบปฏิบัติการ ระบบปฏิบัติการเป็นชุดคำสั่งที่ใช้ควบคุมระบบฮาร์ดแวร์และ.
หน่วยการเรียนรู้ที่ 2 หลักการแก้ปัญหาด้วยคอมพิวเตอร์
Software Development and Management
บทที่ 1 หลักการทำโครงงาน
กระบวนการของการอธิบาย
ซอฟต์แวร์และการเลือกใช้
เรื่อง หลักการเขียนโปรแกรม เบื้องต้น จัดทำโดย นางสาวชาดา ศักดิ์บุญญารัตน์
Adaptive Software Development. วงจรชีวิตของการพัฒนาซอฟแวร์ หรือ Software Development Life Cycle (SDLC) เป็นโครง ร่างหรือแนวทางวิธีการ เพื่อใช้ทำความเข้าใจและเพื่อ.
การพัฒนาบทเรียนคอมพิวเตอร์ช่วยสอน เรื่อง หลักการทำงานของคอมพิวเตอร์ วิชาคอมพิวเตอร์พื้นฐาน สำหรับนักเรียนชั้นมัธยมศึกษาปีที่ 1 โรงเรียนเฉลิมราชประชาอุทิศ.
หลักการแก้ปัญหา อย่างมีขั้นตอน การแก้ปัญหาด้วย กระบวนการทาง เทคโนโลยี สารสนเทศ หลักการ แก้ปัญหา การใช้หลักการใน การแก้ปัญหา.
บทที่ 3 นักวิเคราะห์ระบบและการ วิเคราะห์ระบบ. 1. นักวิเคราะห์ระบบ (System Analysis) 1.1 ความหมายของนักวิเคราะห์ระบบ นักวิเคราะห์ระบบ (System Analysis:
ปรานอม ประทีปทวี 25/09/591 หน้าที่ของครูผู้นิเทศ สพม.5.
ประเภทของ CRM. OPERATIONAL CRM เป็น CRM ที่ให้การสนับสนุนแก่กระบวนการธุรกิจ ที่เป็น “FRONT OFFICE” ต่างๆ อาทิ การขาย การตลาด และการ ให้บริการ SALES FORCE.
การจัดกิจกรรมการ เรียนรู้แบบการทำ โครงงานคอมพิวเตอร์ การจัดกิจกรรมการ เรียนรู้แบบการทำ โครงงานคอมพิวเตอร์ ครูชาญณรงค์ ปานเลิศ โรงเรียนพระบางวิทยา ครูชาญณรงค์
ซอร์ฟแวร์ ( Software ). Microsoft excel Microsoft excel Microsoft power point.. Link Link.
Project Management by Gantt Chart & PERT Diagram
ระบบมาตรฐานการพัฒนาชุมชน ผอ.กลุ่มงานมาตรฐานการพัฒนาชุมชน
เรื่อง กระบวนการเทคโนโลยีสารสนเทศ
การตรวจสอบคุณภาพเครื่องมือ
หน่วยที่ 1 ข้อมูลทางการตลาด. สาระการเรียนรู้ 1. ความหมายของข้อมูลทางการตลาด 2. ความสำคัญของข้อมูลทางการตลาด 3. ประโยชน์ของข้อมูลทางการตลาด 4. ข้อจำกัดในการหาข้อมูลทาง.
stack #2 ผู้สอน อาจารย์ ยืนยง กันทะเนตร
IP-Addressing and Subneting
The Unified Modeling Language
IP-Addressing and Subneting
กระบวนการพัฒนาซอฟต์แวร์
บทที่ 1 สถาปัตยกรรมของระบบฐานข้อมูล (Database Architecture)
บทที่ 3 การวิเคราะห์ Analysis.
บทที่ 7 การวิเคราะห์และพัฒนาระบบ
การพัฒนาการใช้งานในระบบเว็บ
ระบบการจัดการฐานข้อมูล บทที่ 3 การวิเคราะห์ (Analysis)
บทที่ 1 ระบบสารสนเทศ (Information System)
One Point Lesson (OPL).....บทเรียนประเด็นเดียว
บทที่ 3 แฟ้มข้อมูลและฐานข้อมูล
วิธีการกรอกแบบเสนอโครงการในไฟล์ Power point นี้
บัตรยิ้ม สร้างเสริมกำลังใจ
ณ ห้องประชุม พธ.ทร.(๒) วันที่ ๑๗ สิงหาคม ๒๕๕๘ เวลา ๐๙๓๐
ความรู้เบื้องต้นเกี่ยวกับคอมพิวเตอร์และเทคโนโลยีสารสนเทศ
ระบบการจัดการคลินิกครบวงจร
บทที่ 7 การวิเคราะห์และพัฒนาระบบ
การบริหารโครงการซอฟต์แวร์
พื้นฐานการออกแบบ กราฟิก หมายถึง ศิลปะแขนงหนึ่งซึ่งใช้การสื่อความหมาย ด้วยเส้น สัญลักษณ์ รูปวาด ภาพถ่าย กราฟ แผนภูมิ การ์ตูน ฯลฯ เพื่อให้สามารถสื่อความหมายของข้อมูลได้ถูกต้องตรง.
การสร้างโมเดลจำลองความสัมพันธ์ ระหว่างข้อมูล E-R Model
Object-Oriented Programming การเขียนโปรแกรมเชิงอ็อบเจ็กต์
การประชุมเชิงปฏิบัติการพัฒนาศักยภาพบุคลากรทางการศึกษาด้านการสอบด้วยคอมพิวเตอร์ (Computer-based Assessment) การรู้เรื่องการอ่าน ด้านคณิตศาสตร์และด้านวิทยาศาสตร์
บทที่ 6 แนวคิดเทคโนโลยีเสมือนจริง
SMS News Distribute Service
วัฏจักรหิน วัฏจักรหิน : วัดวาอาราม หินงามบ้านเรา
บทที่ 5 การจำลองข้อมูลเชิงวัตถุ (Object-Oriented Modeling)
สถาปัตยกรรมของฐานข้อมูล
งานนำเสนอสำหรับโครงการ นิทรรศการวิทยาศาสตร์
ตัวแบบมาร์คอฟ (Markov Model)
บทที่ 2 การพัฒนาระบบสารสนเทศ
บทที่ 4 การจำลองข้อมูลและกระบวนการ (Data and Process Modeling)
การประเมินผลโครงการ บทที่ 9 ผศ.ญาลดา พรประเสริฐ yalada.
การเขียนโปรแกรมด้วยภาษาไพทอน การเขียนโปรแกรมแบบทางเลือก
Class Diagram.
กระดาษทำการ (หลักการและภาคปฏิบัติ)
การใช้ระบบสารสนเทศในการวิเคราะห์ข่าว
Sequence Diagram.
ใบสำเนางานนำเสนอ:

วิชา COMP342 วิศวกรรมซอฟต์แวร์ (Software Engineering) อาจารย์ผู้สอน อ. รติวัฒน์ ปารีศรี วท.ม. (เทคโนโลยีสารสนเทศ) สถาบันเทคโนโลยีพระจอมเกล้าเจ้าคุณทหารลาดกระบัง วท.บ. (คอมพิวเตอร์ศาสตร์) ม.รามคำแหง Web site : http://research.psru.ac.th/~learning/ http://elearning.psru.ac.th

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

Water Fall Model Water Fall Model หมายถึง โมเดลน้ำตก แสดงถึงการมีขั้นตอนการทำงานที่สามารถจะวนหรือย้อนกลับไปแก้ไขใน ขั้นตอนก่อนหน้าได้

The Spiral Process Model

The Spiral Process Model (ต่อ) Spiral Model เป็นโมเดลที่มีหลักการทำงานเป็นลักษณะรอบ วงกลม วนเป็นก้นหอย ซึ่งจะวนตามเข็มนาฬิกาด้วยการวนไปเรื่อยๆ จากวงในไปสู่วงนอก

The Spiral Process Model (ต่อ) โดยแต่ละรอบวงจะประกอบด้วยขั้นตอนย่อยที่สำคัญดังนี้ คือ การวิเคราะห์ความต้องการ (Requirement Analysis) การวิเคราะห์ความเสี่ยง (Risk Analysis) การออกแบบต้นแบบ (Design Prototype) การพัฒนาต้นแบบและการนำมาประกอบรวมกัน (Develop and Integrate Prototype)

แบบจำลองการวิเคราะห์ (Analysis Model) ประเภท แบบจำลองตามแนวทางเชิงโครงสร้าง (Structured Analysis) – Process Model(DFD) + Data Model (ER) แบบจำลองตามแนวทางเชิงวัตถุ (Object Oriented Analysis) – UML (Unified Modeling Language)

แบบจำลองเชิงโครงสร้าง (Structured Analysis) พิจารณาข้อมูล (Data) และกระบวนการ (Process) ที่เปลี่ยนรูปข้อมูล วัตถุข้อมูล ถูกจำลองในลักษณะที่กำหนด แอตทริบิวส์และความสัมพันธ์ กระบวนการที่ จัดการกับข้อมูลถูกจำลองในลักษณะที่แสดงว่าสามารถเปลี่ยนข้อมูลที่เป็นเป็น วัตถข้อมูลผ่านระบบได้อย่างไร แบ่งออกเป็น 2 ชนิด คือ แบบจำลองกระบวนการ (Process Model) จำลองขั้นตอนการทำงานของระบบ - DFD แบบจำลองข้อมูล (Data Model) จำลองโครงสร้างข้อมูลทั้งหมดในระบบ - ERD

แบบจำลองกระบวนการ (Process Model) แผนภาพกระแสข้อมูล (Data Flow Diagram) แผนภาพที่แสดงถึงทิศทางการไหลของข้อมูลที่มีอยู่ในระบบ จากกระบวนการทำงาน หนึ่งไปอีกกระบวนการหนึ่ง หรือไปยังส่วนอื่นที่เกี่ยวข้อง เช่น แหล่งจัดเก็บข้อมูล (Data Store) ผู้ที่เกี่ยวข้องที่อยู่นอกระบบ (External Agent) ประเภทของแผนภาพกระแสข้อมูล - แผนภาพกระแสข้อมูล เชิงตรรกะ (Logical DFD) – แสดงกระบวนการของระบบใน ระดับแนวคิด (Conceptual) เท่านั้น - แผนภาพกระแสข้อมูล เชิงกายภาพ (Physical DFD) – แสดงรายละเอียดภายใน กระบวนการ เช่น ชื่อกระบวนการ วิธีการทำงาน แหล่งกำเนิด และปลายทาง เป็นต้น

Context Diagram แผนภาพกระแสข้อมูล ระดับบนสุดที่แสดง ภาพรวมการทำงานของ ระบบที่มีความสัมพันธ์กับ สภาพแวดล้อมนอกระบบ

ตัวอย่าง DFD

ตัวอย่าง DFD

แบบจำลองข้อมูล (Data Model) แผนภาพแสดงความสัมพันธ์ของข้อมูล (Entity Relationship Diagram : ERD) เป็นแผนภาพสำหรับจำลองข้อมูล ซึ่งจะประกอบด้วย Entity และ ความสัมพันธ์ของข้อมูล (Relationship) ที่เกิดขึ้นทั้งหมดในระบบ

แบบจำลองเชิงวัตถุ (Object Oriented Analysis) มุ่งที่นิยามของคลาสและลักษณะที่คลาสทำงานร่วมกัน แทนที่เราจะมอง ปัญหาในลักษณะอินพุต โพรเซส เอาท์พุตแบบดั้งเดิม ซึ่งเป็นลักษณะของ กระแสข้อมูล เราจะมองปัญหาในแง่ของโครงสร้างข้อมูลตามลำดับชั้น แบบจำลองเชิงวัตถุ UML (Unified Modeling Language) มี 9 แผนภาพ

UML - Unified Modeling Language UML คือ โมเดลมาตรฐานที่ใช้หลักการออกแบบ OOP(Object oriented programming) รูปแบบของภาษา UML จะมี Notation ซึ่งเป็นสัญลักษณ์ที่ นำไปใช้ใน Model ต่างๆ UMLจะมีข้อกำหนดกฏระเบียบต่างๆ ในการโปรแกรม โดย กฎระเบียบต่างๆ จะมีความหมายต่อการเขียนโปรแกรม (Coding) ดังนั้นการใช้ UML จะต้องทราบความหมายของ Notation ต่างๆ เช่น Generalize, association dependency class และ package สิ่งเหล่านี้มีความ จำเป็นอย่างยิ่งต่อการตีความของการออกแบบและ Design ระบบ ก่อนนำไป Implement ระบบงานจริง ในปัจจุบันมีเครื่องมือมากมายที่สามารถแปลง Model UML เป็น Code ภาษาต่างๆ ยกตัวอย่าง เช่น ภาษา Java, Power builder และ VB เป็นต้น

เครื่อมือในการเขียน UML UML อาจใช้โปรแกรมสำหรับการวาดรูปต่างๆ เช่น Paint, Photoshop, Power point, Visio หรือ โปรแกรมอะไรก็ตามที่สามารถวาดรูปได้ นอกจากการใช้โปรแกรมแล้วการวาดรูป ลงบน กระดาษ ก็สามารถใช้ได้เช่นเดียวกัน อย่างไรก็ตามวิธีการต่างๆ เหล่านี้ จะไม่มีเครื่องอำนวยความ สะดวก ในการทำงานให้ ดังนั้น จึงมีผู้ผลิต Software หลายค่ายได้ทำการสร้างเครื่องมือสำหรับ การทำงานกับ UML โดยเฉพาะ อาทิ Rational Rose, Borland Together , Visual UML โดยเครื่องมือเหล่านี้จะสามารถทำการออกแบบ UML Diagram ต่างๆ และทำการ Generate Code หรือ เอกสารสำหรับออกรายงาน หรือ ส่งลูกค้าได้ นอกจากนี้เครื่องมือเหล่านี้ยังสามารถทำ การ import code กลับเข้ามาเพื่อให้อยู่ในรูป Model ได้ เรียกการ generate code และ การ import กลับเข้ามาอยู่ใน Model UML ว่า round trip engineer กระบวนการนี้มีประโยชน์มาก ในการ update model และ code ให้ตรงกันเสมอ ซึ่งจะต้องมีการควบคุมให้ดี เนื่องจากจะเป็น การทำงานร่วมกันระหว่างนักออกแบบระบบ (UML) และ Developer(Coding)

Rational Rose Screen Short

Together Screen Short

Visual Modeling Uml เป็น Visual Modeling ซึ่งจะทำหน้าที่ในการแสดงโครงสร้าง การทำงานของ Software ให้ออกมาใน model ที่สามารถมองเห็น ได้ โดยการสื่อให้ออกมาในรูปของ Diagram รูปภาพ ด้วยวิธีการ แบบนี้จะทำให้ Model, Implement, Coding มีความสอดคล้อง เป็นไปในแนวทางเดียวกัน

Software Performance UML ถูกนำมาใช้ในการพัฒนา software อย่างกว้างขวาง และทำให้การทำงานมี คุณภาพ กล่าว คือ 1. ช่วยลดระยะเวลาในการพัฒนาระบบงาน (Shortest Development life cycle) 2. ช่วยเพิ่มความสามารถในการทำงาน (Increase productivity) 3. ช่วยเพิ่มคุณภาพของระบบงาน (Improve software quality) 4. รองรับระบบงานเดิม (Support legacy system) 5. ช่วยในการสื่อสารระหว่างทีมผู้พัฒนาระบบงาน (Improve team connectivity)

Brief history of UML เนื่องจากมีแนวความคิดเกี่ยวกับการสร้าง Model แสดงการทำงาน และ โครงสร้างของการพัฒนา Software แบบ Object-Oriented Programming จำนวนมาก แต่ละวิธีก็มีข้อดี ข้อเสียแตกต่างกัน ยุคแรกๆ ของการใช้ Model สำหรับการออกแบบระบบงาน จะมี Model และ Diagram ต่างๆ เกิดขึ้นจำนวนมาก และความสับสนในการใช้งานขึ้น (Model war) ภายหลังจึงมีแนวความคิดในการนำเอาวิธีการสร้าง Model ต่างๆ ที่มีชื่อเสียง และเป็นที่ยอมรับ มากำหนดเป็น Model ใหม่ ขึ้นมา การนำเอาหลายๆ แนวคิดมารวมกันจึงเรียกว่า Unified Modeling Language โดยกลุ่มผู้เริ่มต้นร่วมกันกำหนด UML ขึ้นมา Grady Booch และ Jame Rumbaugh ร่วมกันทำงานที่ Rational Software Corporation เพื่อสร้าง UMLขึ้นมา โดยเริ่มต้นพัฒนาเมื่อปี 1994

UML History

Why UML 1. UML สามารถแสดงส่วนประกอบในการสร้างโปรเจคในรูปของ OOP 2. เชื่อมแนวคิดกับการออกแบบระบบโดยใช้ Object Oriented Code 3. ง่ายต่อการทำความเข้าใจและสามารถแปลงเป็น Code program ได้

Use case Driven กระบวนการการพัฒนาโครงการใดๆ นั้นมีวัตถุประสงค์เพื่อทำการสนับสนุนการทำงานของ User เป็นหลัก หรือ สนับสนุนความต้องการของผู้ใช้ ทั้งนี้ User ไม่ได้หมายถึงคน เพียงอย่างเดียว อาจจะหมายถึง ระบบอื่นที่อยู่ภายนอกระบบก็ได้ (Some one or something such as other system out side the system) User จะมีการกระทำกิจกรรมใดๆ ต่อ ระบบ เช่น การสอดบัตรพลาสติกลงในเครื่องอ่าน บัตร การกดปุ่มตอบสนองต่อหน้าจอที่ปรากฏต่อผู้ใช้ การใช้งานเครื่อง Automatic Teller Machine (ATM) และ การรับเงินที่เครื่องส่งออกมา โดย ATM หรือ ระบบจะมีการสร้างลำดับของงานขึ้นมาก่อน จากนั้นจึงส่งผลลัพธ์ให้ User หรือผู้ใช้

Iterative and Incremental Development ในโลกแห่งความเป็นจริงการทำงานไม่สามารถทำให้เสร็จสมบูรณ์ได้ในขั้นตอนเดียว และ วิธีการทำงานโดย Water fall model ซึ่งเป็นวิธีการทำงานแบบดั้งเดิมจะต้อง ทำงานให้เสร็จในรอบเดียว นับว่าเป็นความเสี่ยงอย่างยิ่งต่อความล้มเหลวของโครงการ เนื่องจากการทำงานในยุคปัจจุบันมักมีการเปลี่ยนแปลง Environment ต่างๆ เกิดขึ้น เสมอ เช่น Requirement change, Technology change เป็นต้น

Use case Analysis Model วัตถุประสงค์ของ Analysis model 1. ต้องการแยกการวิเคราะห์ระบบ 2. ต้องการภาพรวมของระบบ (Integrated part) 3. ต้องการทราบวิธีการอื่น(ถ้ามี) (Alternative Solution) 4. ศึกษาเพื่อสร้างระบบที่เกี่ยวข้องกับระบบ หรือสิ่งที่มีอยู่แล้ว (Legacy system)

Object Definition 1. สิ่งต่างๆ ที่มีอยู่ในโลกแห่งความเป็นจริง 2. สิ่งต่างๆ ที่สัมผัสได้ เช่น รถของนาย ก 3. กระบวนการต่างๆ เช่น การจองห้องพัก การทดสอบรถยนต์ 4. ความสัมพันธ์ต่างๆ เช่น สัญญาฉบับหนึ่ง 5. คำนามต่างๆ ซึ่งสามารถกำหนดนิยามได้ 6. Cyberspace (Electronic money, cash etc.)

องค์ประกอบของ Object ชื่อของ Object ข้อมูล Static structure เช่น ยี่ห้อ รุ่น พฤติกรรมของวัตถุ

Class Definition กลุ่มของ Object ซึ่งมีข้อมูล และมีพฤติกรรมเหมือนกัน เช่น Class ของรถยนต์ ประกอบด้วยรุ่น ยี่ห้อ เป็นต้น

Object Orientation แนวความคิดพื้นฐานในการสร้างระบบ หรือ Software โดย พิจารณาปัญหาในโลกแห่งความเป็นจริง ว่าประกอบไปด้วยวัตถุ (Object) ต่างๆ มาทำงานร่วมกัน การเข้าถึงข้อมูลของ Object ใดๆ จะต้องกระทำผ่านทาง พฤติกรรมของ Object นั้นเท่านั้น การกำหนดประเภทพฤติกรรม/ข้อมูลของObject จะทำให้ สามารถควบคุมการเข้าถึงข้อมูลจากภายนอก Object ได้

Symbol in Analysis model Boundary Class (ส่วนติดต่อผู้ใช้) Control class(ส่วนควบคุม) Entity Class(ใช้เก็บข้อมูล)

Building Blocks of the UML UML สามารถแบ่งองค์ประกอบออกเป็น 3 กลุ่ม 1. Things คือ สัญลักษณ์หรือสิ่งต่างๆ ที่นำมาใช้สร้าง Diagram UML แบ่ง ออกเป็น 4 หมวด คือ 1.1. Structural Things หรือ หมวดโครงสร้าง เป็นคำนามใช้สำหรับ uml ส่วนใหญ่จะเป็นส่วน static ของ ได้ แก่ Use case , Interface , Class ,Collaboration , ...Component , Node

Building Blocks of the UML (ต่อ) 1.2. Behavioral Things หรือ หมวดพฤติกรรม ได้แก่ส่วนที่เป็น dynamic แสดงถึงพฤติกรรมของระบบ ประกอบด้วย 2 ส่วนใหญ่ๆ คือ - Interaction - state machine 1.3. Grouping Things หรือ หมวดการจัดกลุ่มหมู่ ได้แก่ package - package 1.4. Annotation Things หรือ หมวดคำอธิบาย ได้แก่ note - note

Building Blocks of the UML (ต่อ) 2. Relationships ความสัมพันธ์ใน UML ประกอบไปด้วย 2.1. Dependency หรือ ความขึ้นอยู่ต่อกันจะให้ความหมายว่าเมื่อ เกิดการ เปลี่ยนแปลงที่ส่วนหนึ่งแล้วจะส่งผลกระทบถึงอีกส่วนหนึ่งที่ ลากเส้นมาสัมพันธ์ กัน เช่น การเปลี่ยนแปลงของโรงเรียนจะมีผลกระทบ ของนักเรียนเป็นต้น

Building Blocks of the UML (ต่อ) 2.2. Association หรือ ความสัมพันธ์จะแสดงถึง ความสัมพันธ์ระหว่าง Object ความ สัมพันธ์ยัง สามารถแยกออกเป็นความสัมพันธ์แบบธรรมดา ความสัมพันธ์แบบ Aggregation, Composite,ทิศทางความสัมพันธ์ นอกจาก นั้นยังสามารถกำหนด multiplicity ให้กับ ความสัมพันธ์ได้อีกด้วย

Building Blocks of the UML (ต่อ) 2.3. Generalization หรือ การสืบทอดคุณสมบัติ หรือ Inheritance

Building Blocks of the UML (ต่อ) 2.4. Realization หรือ การทำให้ทำงานได้จริง เช่น Interface ถูก Realize โดย Class, Use case ถูก Realize โดย Collaboration

Building Blocks of the UML (ต่อ) 3.Diagrams Diagram ของ UML แบ่งออกได้เป็น 9 Diagram หลัก ดังนี้ คือ 1. Use case Diagram ในการพัฒนาระบบงานใดๆ นั้น การเก็บรวบรวมความต้องการของผู้ใช้มีความสำคัญมาก และจะทำใน ระยะแรกๆ ของการพัฒนาระบบงานเสมอ Use case diagram เป็น Diagram ที่ทำหน้าที่ Capture requirement 1.1 เป็นเทคนิคในการสร้างแบบจำลองเพื่อใช้อธิบายหน้าที่ของระบบใหม่ หรือระบบปัจจุบัน 1.2 กระบวนการสร้าง Use case เป็นแบบ Iteration 1.3 ความต้องการของระบบจะได้จาก ลูกค้า/ผู้ใช้ + ผู้พัฒนาระบบ 1.4 องค์ประกอบจะมี Use case, Actor, Use case Relation และ System

ตัวอย่าง Use case diagram ที่สร้างจาก visual uml

use case และ ความสัมพันธ์

2. Sequence Diagram จะบอกลำดับการทำงานของระบบ โดยมี Object และ เวลาเป็นตัวกำหนด ลำดับของงาน ตัวอย่าง Sequence Diagram ในขั้นตอนของการ Analysis

ตัวอย่าง Sequence Diagram ในขั้นตอนของการ Design

Sequence diagram เป็น Diagram ซึ่งแสดงปฏิสัมพันธ์ (Interaction) ระหว่าง Object ตามลำดับของเหตุการณ์ที่ เกิดขึ้น ณ เวลาที่กำหนด message ที่เกิดขึ้นระหว่าง class จะสามารถนำไปสู่การสร้าง method ใน class ที่เกี่ยวข้องได้ จากตัวอย่าง Sequence ข้างต้นจะทำการ Design สำหรับการทำรายการ บัญชีการเงินของธนาคาร โดยจะเริ่มจากหน้าจอ JSP ซึ่งถือเป็น User Interface(UI) ประเภทหนึ่ง จะทำหน้าที่ติดต่อกับผู้ใช้ เพื่อรับข้อมูลจากการใช้งานโดย User จากนั้น เมื่อกดปุ่มส่งคำสั่งใดๆ ผ่านหน้าจอ JSP ก็จะทำการเรียกใช้ Servlet โดยเรียกผ่าน Method doPost ของ Account Servlet และทำการส่งค่าและเรียกใช้ Class ต่างๆ ที่เกี่ยวข้องเพื่อทำการประมวลผลตาม business process ต่อไป Servlet และ Class ที่ทำการประมวลผลต่างๆ จึงเป็นตัวควบคุมการทำงาน หรือ Controller นั่นเอง ส่วน Class ที่ทำหน้าที่เก็บข้อมูลต่างๆ จะเรียกว่า Entity Class

3. Collaboration Diagram ทำหน้าที่เช่นเดียวกับ Sequence diagram แต่รูปแบบและลักษณะ การเขียนจะต่างกัน หรือ อาจกล่าวได้ว่า Collaboration diagram ก็คือรูปอีกรูปแบบหนึ่งของ Sequence diagram เมื่อได้ sequence diagram แล้ว tool บางชนิดสามารถ generate collaboration diagram ให้ได้เลย หรือ ในทางกลับกันเมื่อสร้าง Collaboration diagram เสร็จแล้ว ก็จะสามารถ generate sequence diagram ได้ โดยอัตโนมัติ ซึ่งถือว่าทั้ง 2 diagram สะท้อนภาพกันและกันอยู่นั่นเอง

ตัวอย่าง Collaboration diagram ที่สร้างจาก visual uml

4. State Diagram ประกอบด้วย State ต่างๆ ของ Object และเหตุการณ์ต่างๆ ที่ทำให้ สถานะของ Object เปลี่ยนและการกระทำที่เกิดขึ้นเมื่อสถานะของระบบ เปลี่ยนไป สามารถบอกสถานะของ Object ได้ โดยจะให้ความสนใจว่า ณ เวลาใดๆ Object นั้นมี status เป็นแบบใด

ตัวอย่าง State diagram ที่สร้างจาก visual uml

5. Activities Diagram แสดงลำดับ กิจกรรมของการทำงาน(flow) สามารถแสดงทางเลือกที่เกิดขึ้น ได้ Activity diagram จะแสดงขั้นตอนการทำงานในการปฏิบัติการ โดย ประกอบไปด้วยสถานะต่างๆ ที่เกิดขึ้นระหว่างการทำงาน และผลจากการ ทำงานในขั้นตอนต่างๆ

ตัวอย่าง Activity diagram ที่สร้างจาก visual uml

6. Class Diagram ประกอยด้วย Class และความสัมพันธ์ต่างๆ ระหว่าง Class เช่น Dependency, generalization, association เป็นต้น Class Diagram ยังสามารถทำการแสดงรายละเอียดภายใน Class แต่ละ Class ได้ว่ามี Method อะไรบ้าง Field และ Attribute เป็นอย่างไร

จากแผนภาพตัวอย่างข้างต้นหมายความว่า Class Process Control ทำการ Extends หรือ Generalize มาจาก Class API ซึ่งจะมีผลทำให้ Class ProcessControl มีคุณสมบัติของ Class API นั่นคือมี Attribute และ method ของ Class API อยู่ใน Class ProcessControl สามารถเรียกใช้งานได้ทันที โดยไม่ต้องเขียน attribute และ method เพิ่มใน class ProcessControl ซ้ำอีก

ตัวอย่าง Class diagram ที่สร้างจาก visual uml

7. Object Diagram ประกอบด้วย Object และ Relation ระหว่าง Object โดยแต่ละ Object จะแสดง Instance oของแต่ละ class ที่มีในระบบ และ ความสัมพันธ์ต่างๆ ระหว่าง Class เช่น Dependency, generalization, association จะมีลักษณะเช่นเดียวกับใน Class diagram จะเห็นว่า Object diagram จะเป็น Instance ของ Class ซึ่งจะมีชื่อและ ข้อมูลเก็บอยู่ในขณะที่ Class จะเป็นเพียงตัวแบบที่ยังไม่มีการสร้าง Object หรือ Instance

8. Component Diagram เป็น Diagram ซึ่งแสดงโครงสร้างทางกายภาพของ Software โดยจะ ประกอบด้วยองค์ประกอบซึ่งอยู่ในรูปต่างๆ เช่น Binary, text และ executable ภายใน Component Diagram ก็จะมีความสัมพันธ์ แสดงอยู่เช่นเดียวกับ Class diagram, Object diagram

9. Deployment Diagram เป็นสิ่งที่สามารถทำการแสดงระบบสถาปัตยกรรมของ Hardware/Software ตลอดจนความสัมพันธ์ระหว่าง hardware/software

สรุป UML Software สำหรับระบบงาน ที่ได้จากการพัฒนาระบบแบบเดิม มีจำนวน หลายแสนบรรทัด อีกทั้งชุดคำสั่งในการกำหนดโครงสร้างข้อมูล กับชุดคำสั่ง ประมวลผลข้อมูลนั้นแยกกันอยู่ ทำให้เวลาในการบำรุงรักษา Software หรือ การปรับปรุงเปลี่ยนแปลงข้อมูลไปตามการดำเนินงานจริงนั้นทำได้ยาก มาก ใช้เวลาและค่าใช้จ่ายค่อนข้างสูง จึงได้มีแนวคิดในการนำ “Object Orientation” มาปรับใช้กับการเขียนโปรแกรมเพื่อลดปัญหาดังกล่าวลง

สรุป UML (ต่อ) Object Orientation หมายถึง การใช้วัตถุ หรือแนวคิดเกี่ยวกับวัตถุ เป็นแนวทางในการพิจารณาความเป็นจริงต่างๆ ที่เกิดขึ้นในโลก ( Real World ) เราสามารถปรับใช้แนวคิด Object Orientation ให้เข้า กับกระบวนการพัฒนาระบบในแต่ละขั้นตอนได้ โดยปรับใช้กับขั้นตอนการ วิเคราะห์ ออกแบบ และพัฒนาโปรแกรม จะเรียกว่า “Object- Oriented Analysis” , “Object-Oriented Design” และ “Object-Oriented Programming” ตามลำดับ

สรุป UML (ต่อ) สำหรับแนวทางที่ใช้ในการพัฒนาระบบเชิงวัตถุ หากเป็นองค์กร หรือระบบงานที่มีขนาดเล็ก ก็สามารถนำแนวทาง SDLC แบบ Waterfalls หรือรูปแบบอื่นๆ มาปรับใช้ได้ แต่หาก เป็นองค์กรหรือระบบงานที่มีขนาดใหญ่ และเลือกใช้แนวทางแบบ SDLC อยู่แล้ว รูปแบบ ของวงจรที่เหมาะสม ควรจะเป็นแบบ “Iterative & Incremental Development” คือ การวนรอบทำซ้ำ และทำเพิ่มในแต่ละรอบด้วย เนื่องจากรูปแบบ ดังกล่าวมีการวนรอบ กลับมาดำเนินกิจกรรมต่างๆ ซ้ำ และเพิ่มเติมฟังก์ชันงานที่ผู้ใช้ ต้องการในแต่ละรอบได้ จึงนับว่าเป็นแนวทางที่สามารถรองรับกับความต้องการที่ เปลี่ยนแปลงอยู่เสมอ ของผู้ใช้ระบบได้ สามารถใช้งานระบบจริง ได้เร็วกว่าแบบ Waterfalls ทำให้ไม่เสียเปรียบคู่แข่งขัน อีกทั้งยังช่วยลดความเสี่ยง ต่อความล้มเหลว ของโครงการได้

สรุป UML (ต่อ) Methodology ที่จะนำมาใช้ในการพัฒนาระบบเชิงวัตถุนั้นมีหลาย ทฤษฎีที่แตกต่างกันออกไป ไม่ว่าจะเป็น Methodology ของ Grady Booch ที่มีการแบ่งกระบวนการพัฒนาระบบออกเป็นสองระดับ คือ Macro และ Micro Development ส่วน Methodology ของ James Rumbaugh นั้นเป็น Methodology ที่มีความชัดเจนใน เรื่องของการจำลองระบบงาน โดยใช้เทคนิคที่มีชื่อว่า OMT ( Object Model Technique ) ด้วยการแบ่งแบบจำลองออกเป็น 3 กลุ่ม คือ Object Model, Dynamic Model, Functional Model ที่ สามารถแสดงให้เห็นโครงสร้าง Object ของระบบได้เป็นอย่างดี

สรุป UML (ต่อ) ส่วน Methodology ของ Ivar Jacobson นั้นก็มีชื่อเสียง และนิยม นำไปใช้ในวงการพัฒนาและจำหน่ายซอฟต์แวร์ นั่นคือ Object- Oriented Software Enginerring ( OOSE ) หรือที่รู้จักกันดี ในนาม Objectory เป็นการนำวิธีการ Use Case Driven เป็นตัว หลักในการสร้างแบบจำลอง ในขั้นตอนอื่นของกระบวนการพัฒนาระบบ และ Methodology ที่นับว่าเหมาะสม สำหรับการพัฒนาระบบเชิงวัตถุ ในยุคปัจจุบัน นั่นคือ RUP Methodology ที่มีวงจรการพัฒนาวงจร เป็นแบบ Iterative & Incremental Development ซึ่งในแต่ละ รอบ ทีมงานต้องดำเนินกิจกรรมตาม Workflow ไปด้วย

สรุป UML (ต่อ) โดยวงจรการพัฒนาระบบของ RUP จะแบ่งออกเป็น 4 ระยะ ได้แก่ ระยะเริ่มต้น (Inception Phase) ระยะวางแผน (Elaboration Phase) ระยสร้างระบบ (Construction Phase) และระยะส่งมอบ (Transition Phase) ทางด้านเทคนิคที่ นำมาใช้ในการพัฒนาระบบเชิงวัตถุ ก็คือ Object Orientation และแน่นอนว่า เทคนิคดังกล่าวนี้เป็นตัวกำหนดการเลือกใช้เครื่องมือ รวมทั้งกำหนดชนิดของแบบจำลอง ด้วย ว่าต้องใช้แบบจำลองเชิงวัตถุ (Object Model ) ที่ปัจจุบันภาษารูปภาพ ได้รับความนิยม ในการสร้างแบบจำลองเชิงวัตถุก็คือ UML ( Unified Modeling Language )