480 likes | 777 Views
ניתוח ועיצוב מערכות מידע תעשיה וניהול, שנה ב סמסטר אביב 2009 קורס 310211 הרצאה 4 : אפיון מערכות מוכוון עצמים ד"ר דיצה ביימל Email: dizzab@ruppin.ac.il. סיכום השיעורים הקודמים. שלב הניתוח כולל: שלב הייזום, איסוף נתונים וחקר מצב קיים, הגדרת דרישות וחקר ישימות. EPC
E N D
ניתוח ועיצוב מערכות מידע תעשיה וניהול, שנה בסמסטר אביב 2009קורס 310211 הרצאה 4: אפיון מערכות מוכוון עצמים ד"ר דיצה ביימלEmail: dizzab@ruppin.ac.il
סיכום השיעורים הקודמים • שלב הניתוח כולל: • שלב הייזום, • איסוף נתונים וחקר מצב קיים, • הגדרת דרישות וחקר ישימות. • EPC • מודל המשמש לניתוח ותיעוד מצב קיים.
סילבוס על פני ציר הזמן מבוא UML עקרונות ב OO OPM שלב הניתוח 1 2 3 4 5 6 7 8 9 10 11 12 13 14
תוכן ההרצאה • מבוא ל UML • אפיון מונחה עצמים • מושגים בסיסיים • עקרונות בסיסיים • קשרים • סיכום
מוטיבציה דוח מבקר המדינה לשנת 2001 – 13% מכלל פרויקטי התוכנה מסתיימים בהצלחה • בעיות בפיתוח מערכות: • אין מספיק שימוש חוזר בקוד • מציאת בגים • ריבוי שיטות סימון • המערכות גדלות ונעשות מורכבות
ניתוח מוכוון עצמים • גישת האובייקטים עוסקת ישירות בעולם האמיתי. • מהו אובייקט? • עולמו של הלקוח בנוי מאובייקטים • חלקם פיזיים - כמו.. • חלקם לוגיים - כמו... • פיתוח מ"מ בגישה מונחית עצמים: זיהוי וארגון המחלקות לפי מושגי עולם הבעיה ולא לפי מושגי עולם המימוש • בשנת 1983 הוכרזה שפת התכנות c++ . • בשנת 1997 יצאה הגרסה הראשונה של UML- Unified Modeling Language לא עוד תהליכים! אמור מעתה עצמים או אובייקטים
UML UML היא שפת מודל שבאמצעותה נוכל לאפיין ולעצב מערכות במתודולוגיה מוכוונת עצמים בצורה אחידה המקובלת בעולם היום.
מטרות UML • אחידות • מסגרת • פשוט ופרקטי • מחזור חיי מערכת • פרויקטים בסדר גודל ענק • חוסר תלות בטכנולוגיה • שפה המתאימה לכולם • הפרדה בין שלבי פיתוח המערכת
מרכיבי UML • Use case diagram • Class diagram • Sequence Diagram • Collaboration diagram • State chart diagram • Activity diagram • Deployment diagram • Component diagram • Object diagram TOTAL 9 DIAGRAMS
תוכן ההרצאה • מבוא ל UML • אפיון מונחה עצמים - OOA • מושגים בסיסיים • עקרונות בסיסיים • קשרים • סיכום
מושגים בסיסיים של מודל העצם • עצם (Object) • מחלקה (Class) • מופע (Instance) • תכונה (Attribute), מצב (State) • שיטה (Method/Service),
מחלקה • מחלקה(Class) – תבנית ממנה ניתן לייצר אובייקטים. • מחלקה אינה קיימת באמת. היא רק הוראות הכנה לפעילות מסוימת. • קבוצת עצמים בעלי מאפיינים משותפים (תכונות, פעולות, יחסים, התנהגות) שייכים לאותה מחלקה. • מחלקה היא הפשטה של אובייקט ממשי. • למחלקה יש שם, תכונות, ושיטות. • למחלקה מוחשית יש מופעיםשהם האובייקטים.
תכונות ושיטות • תכונות(Attribute/Property) - אוסף נתונים ("שדות") המתארים את העצם. • שיטות(Service/Operation/Method) - אוסף ה"פונקציות" של המחלקה/העצם. Student Class Name Name DateofBirth Address Phone Grades Courses Attributes Student(name) Calc-average() Register-for (course) …….. Methods
מופע של מחלקה: אובייקט • מופע(Instance) של מחלקה - עצם בודד של מחלקה. • לכל עצם יש: • מצב (State) - אוסף התכונות (השדות וערכיהם, קשר עם עצמים אחרים) בנקודת זמן מסוימת. • התנהגות (Behavior) - אוסף פעולותיו המייצגות כיצד העצם פועל ומגיב. • זהות (Identity) - ייחודיות. אין שני עצמים זהים.
מחלקה אובייקט (מופע של מחלקה) Student Student Name:: moshe cohen DateofBirth: 1.1.79 Address: Haifa Phone:04-8888888 ………. Name DateofBirth Address Phone Grades Courses Student(name) Calc-average() Register-for (course) Student(name) Calc-average() Register-for (course) ……..
תרגיל כיתה: Bicycle נרצה לתאר מחלקה של אופניים. לאופניים יש שלוש תכונות: • cadence, gear, speed לאופניים יש 4 שיטות: • setCadence, setGear, applyBrake, speedUp
Bicycle Class Bicycle cadence gear Speed setCadence (newValue) setGear (newValue) applyBrakes (decrement) speedUp (increment)
Bicycle Code class Bicycle { //3 fields int cadence = 0; int speed = 0; int gear = 1; //4 methods void setCadence(int newValue) { cadence = newValue; } void setGear(int newValue) { gear = newValue; } void speedUp(int increment) { speed = speed + increment; } void applyBrakes(int decrement) { speed = speed - decrement; } }
Create and use objects class BicycleDemo { public static void main(String[] args) { // Create two different Bicycle objects Bicycle bike1 = new Bicycle(); Bicycle bike2 = new Bicycle(); // change values and invoke methods on those objects bike1.speed = 20; bike2.gear = 2; bike1.setCadence(20); bike1.speedUp(10); bike2.setGear(3); bike2.speedUp(12); } }
תוכן ההרצאה • מבוא ל UML • אפיון ועיצוב מונחה עצמים • מושגים בסיסיים • עקרונות בסיסיים • קשרים
עקרונות בסיסיים של מודל העצם • הפשטת נתונים (Data Abstraction) • הכמסה (Information Hiding/Encapsulation) • ממשק המחלקה (Interface) • מודולאריות (Modularity) • היררכיה/ ירושה (Inheritance/Hierarchy) • פולימורפיזם (Polymorphism) • שימוש חוזר (Reusability) • מחלקה מופשטת (Abstract class )
1. הפשטת נתונים - Data Abstraction • התפיסה לפיה מתרכזים במאפייניו הרלוונטיים של העצם. • מאפיינים: • הצגת רק מה שחיוני למתבונן מבחוץ • ממשקים מוגדרים היטב לעצם • דוגמאות: • בדוגמת האופניים בחרנו בשלושה מאפיינים והתעלמנו ממאפיינים אחרים כמו: צבע, משקל, ומחיר האופניים Bus yearOfProdction Capacity color
2. הכמסה - Encapsulation/Information Hiding • התפיסה לפיה אובייקט מאחד בתוכו את מבני הנתונים המכילים את תכונותיו ואת השיטות שאותן הוא מפעיל. • הסתרת פרטי המימוש מהמשתמש באובייקט. • הפרדה בין הממשק (= אוסף השירותים) ובין המימוש (מנגנון פנימי): • כדי להשתמש באובייקט מספיק להכיר את הממשק שלו. אין צורך להכיר / להבין מבנה ומנגנון פעולה פנימיים.
דוגמא בקוד public class Bicycle { // the Bicycle class has three fields public int cadence; protected int gear; private int speed; // the Bicycle class has four methods public void setCadence(int newValue) { cadence = newValue; } public void setGear(int newValue) { gear = newValue; } protected void applyBrake(int decrement) { speed -= decrement; } private void speedUp(int increment) { speed += increment; } }
Create and use objects: public/private class BicycleDemo { public static void main(String[] args) { // Create two different Bicycle objects Bicycle bike1 = new Bicycle(); Bicycle bike2 = new Bicycle(); // change values and invoke methods on those objects bike1.spead = 5; bike2.gear = 4; bike1.setCadence(50); bike1.speedUp(10); bike2.setGear(5); bike2.speedUp(10); } }
4. מודולאריות – Modularity • "כפיית" מבניות. • מודול - "חלק" הניתן להפרדה לוגית. • מאפיינים: • כל עצם (מחלקה) עוסק בפונקציונאליות מוגדרת ושונה מהשאר • כל עצם (מחלקה) מעוצב ומיושם באופן עצמאי (עד כמה שניתן) • יש לשאוף שעצם (מחלקה) יהיה בר שימוש חוזר (Reusable)
5. היררכיה/ירושה -Inheritance/Hierarchy • קשר (מדרגי/רשתי) בין קבוצות המבטא “העתקת” מבנה ו/או תכונות ו/או התנהגות מקבוצה אחת (קבוצת-על) לקבוצה אחרת (תת-מחלקה). • תת-מחלקה יורשת יכולה להוסיף מאפיינים המיוחדים לה. • יתרונות: • חסכון בהגדרות ובקוד • תיקון ועדכון קלים יותר
א' ב' תכונות תכונות פעולות פעולות היררכיה/ירושה • מחלקה ב' יורשת את מחלקה א': • ב' מכילה את כל התכונות של א' • ב' מכילה את כל הפעולות של א' • ב' מכילה את כל הקשרים של א' • בנוסף, ב' מכילה תכונות ופעולות משל עצמה • ב' היא תת-מחלקה (sub-class)של א' • סימון ב-UML: חץ חלול המסתיים במחלקת העל.
היררכיה/ירושה – דוגמא א' Person Faculty Member Administrator Student
היררכיה/ירושה – דוגמא ב' חשבון בנק הלוואה מט"ח עו"ש עסקי פרטי חיילים צעירים בוגרים
המשך דוגמא: אופני הרים - סוג של אופניים נרצה לתאר מחלקה של אופני הרים שיורשת ממחלקת אופניים. לאופני הרים יש תכונה נוספת: • seatHeight לאופני הרים יש שיטה נוספת: • setSeatHeight
MountainBike Class MountainBike Bicycle seatHeight ......... ......... setSeatHeight (newValue)
הורשה בקוד public class MountainBike extends Bicycle { // the MountainBike subclass has one field public intseatHeight; // the MountainBike subclass has one method public void setHeight(intnewValue) { seatHeight = newValue; } }
שימוש ב protected public class B extends A{ public int z; public int newY; public int newX; public int getZ () { z = y; z = getX(); A a= new A(); newY = a.y; newX = a.getX(); return z;} } public class A { private int x; protected int y; private getY () { return y;} protected getX () {return x;} }
6. פולימורפיזם (רב-צורתיות) –Polymorphism • מחלקה יורשת יכולה לרמוס שיטות שהוגדרו אצל האב. • רמיסה מלאה • רמיסה חלקית • הרמיסה גורמת לריבוי צורות בעץ ההורשה עבור מימוש של אותה שגרה. Shape Circle line Color X1 Y1 Radius Length draw() draw()
7. שימוש חוזר - Reuse • שילוב רכיבי תוכנה במערכת שנוצרו מחוץ למערכת. • סוגי רכיבים לשילוב: • פותחו עבור מערכת אחרת • פותחו כרכיבים גנריים המיועדים מראש לשימוש חוזר • ציבוריים • רכיבים מסחריים "מן המדף" • קוד פתוח (Source Code) • אופני שימוש חוזר: • שיתוף (Sharing) – שימוש חוזר באותה רוטינת קוד • שכפול (Copying/Cloning) – העתקת קטע קוד מתכנית אחרת • התאמה (Adjusting) – שימוש באבטיפוס ושילוב רכיבים שהם Reusable
8. מחלקה מופשטת • אינה מאפשרת ליצור ממנה מופעים. • משרתת את המכניזם של ההורשה Animal<<abstract>> Cat Dog
תוכן ההרצאה • מבוא ל UML • אפיון ועיצוב מונחה עצמים • מושגים בסיסיים • עקרונות בסיסיים • קשרים • סיכום
קשרים • קשר הקשר -Association • מחלקת קשר • קשר הכלה • קשר הכלה חזקה • קשר אסוציאטיבי עצמאי
1. קשר הקשר -Association • הקשר הפשוט ביותר. • מבטא יחס מסוים בין אובייקטים: הכרה, ידיעה, שימוש. • מסומן ע"י קו בין מחלקות • כיוון • קרדינאליות • מידת ריבוי • שם Cat Food
2. מחלקת קשר • מחלקת קשר מתארת את הקשר עצמו. Reader Book Borrow
3. קשר הכלה • הרחבה של קשר אסוציאטיבי. • מבטא את העובדה שמחלקה אחת היא הכלה של מחלקה אחרת 1 wheel Car *
4. קשר הכלה חזקה • מבטא את העובדה שמחלקה אחת היא הרכבה של מחלקה אחרת • האובייקט החלש חי בזכות האובייקט החזק wheel Car
5. קשר אסוציאטיבי עצמאי • ניתן לתאר קשר של מחלקה אל עצמה, לצורך פישוט התרשים * employee employee 1 manager
תוכן ההרצאה • מבוא ל UML • אפיון ועיצוב מונחה עצמים • מושגים בסיסיים • עקרונות בסיסיים • קשרים • סיכום
סיכום לא עוד תהליכים! אמור מעתה עצמים או אובייקטים ונעבור ל: Use Case diagram