160 likes | 451 Views
SCE - 3b הרכבה: היבטים וקשרים דר’ יעקב אקסמן תשס"ו. הנדסת מרכיבי תוכנה. דרישות תוכנה. דגם הייררכי. דגם פיזיקלי. מרכיבים. קוד להרצה = exe. מדידות. מרכיבים סיווג. Produces output?. YES. NO. Transceives Data?. Specific function?. YES. NO. YES. NO. ?. Remote?. YES. YES.
E N D
SCE-3b הרכבה: היבטים וקשרים דר’ יעקב אקסמן תשס"ו
הנדסת מרכיבי תוכנה דרישות תוכנה דגםהייררכי דגםפיזיקלי מרכיבים קוד להרצה = exe מדידות
מרכיבים סיווג Produces output? YES NO Transceives Data? Specific function? YES NO YES NO ? Remote? YES YES NO Object Aspect Connector Gluon
הרכבה? היבטים וקשרים קשרים Connectors היבטים Aspects מחלקות Classes ArchJava AspectJ Java, C++ archj ajc javac קוד להרצה exe קוד להרצה exe קוד להרצה exe
קשרים Connectors היבטים Aspects מחלקות Classes Java, C++ ArchJava AspectJ כלי הרכבה קוד להרצה exe הרכבה היבטים וקשרים
הרכבה ספרות [WCOP-2004] T.Cottenier & T. Elrad “Validation of Context-Dependent Aspect-Oriented Adaptations to Components” Workshop on Component Oriented Programming Oslo – Norway – June 2004.
הרכבה מניעים קשר מרכיב • קשר בין מרכיבים • היבט לרוחב מרכיב (פנימי) • היבט לרוחב מרכיבים
הרכבה אתגרים • היבטים • קוד מקור – פועלים ברמת קוד מקור • בקרת הזרימה – הורסים את מקומיות בזמן ריצה (!?) • כימוס – שוברים כימוס המרכיבים • החזרת הכימוס • חיזוי תוצאת ההרכבה • בדיקתיות המרכיבים
הרכבה ספרות [AOSD-2003] Suvee, Vanderperren & Jonckers “JAsCo – An aspect-oriented approach tailored for Component-Based Software Development” Proc. 2nd Int. Conf. AOSD - Boston – March 2003.
שפות היבטים מגרעות AspectJ JasCo Compost ASC בעיית הכימוס מגבלות התבטאות (expressiveness) בשפה מגבלות התבטאות ועקבות (obliviousness) עקבות ברמה גבוהה בהייררכיה
היבטים JAsCo ASPECT BEAN Q • methody() • fires eventx HookA HookA(m1,m2) • before • after HookB HookB(m3) • replace COMP X • method1() • method2() • method3(int) • fires event1 CONNECTOR HookA.m1 X.method2 COMP Y HookA.m2 Y.event2 HookB.m3 Y.method1 HookB.m3 Y.method1 • method1(str) • method2() • fires event1 • fires event2
הרכבה עיתויים Deployment-time עת-התקנה מהלך עבודה, טראנזאקציה, התמדה = ניהול משאבים Composition-time עת-הרכבה Run-time זמן-ריצה
הרכבה עת הרכבה מרכיב = עצמים + היבטים = * =
הרכבה מחלקות והיבטים “weaving” אריגה
היבטים שפות/כלים אחרים • HyperJ– IBM (Ossher) פרושות (slices)- פחות עשירה ב- JoinPoints מ-AspectJ למעשה: כלי תוכנה • JBoss – (J2EE platform) EJB והיבטים • Demeter • Ceasar • JAC
היבטים HyperJ = רב-מימדיות Feature Hyper/J creates a hyperslice for each feature (each row) name() Position() pay() Employee name() Position() pay() name() Position() pay() name() Position() pay() Research Sales Secretary Payroll Employee Research Sales Secretary Personnel name() check() print() name() check() print() name() check() print() name() check() print() Class Employee Research Sales Secretary