آشنایی با UML 2
مقدمه
شايد براي شما هم اين سؤال پيش آمده باشد كه چه تغيير مهمي در UML رخ داده است كه پس از UML 2.0، UML 1.5 عرضه شد؟ آيا اضافه شدن دياگرامهاي جديد (مثل Timing Diagram) يا بهبود دياگرامهاي موجود (مانند افزودن امكانات بيشتر به Sequence Diagram ) موجب اين ارتقاء قابل توجه شده است؟ حقيقت اين است كه آنچه كه موجب اين ارتقاء نسخه قابل توجه از 1 به 2 شده است، فراتر از اين جزئيات است. آنچه كه توليد مدلگرا (ModelDriven Development) ناميده ميشود، كه بر پايه سطح تجرد بالاتر و استفادة بيشتري از توليد خودكار كد نسبت به روشهاي سنتي قرار دارد، اثر قابل توجه خود در بهبود كيفيت نرمافزار و بهرهوري توليد نشان داده است. از آنجاييكه نقش زبان مدلسازي براي موفقيت MDD بسيار مهم است، يك تجديد نظر عمده در زبان استاندارد UML انجام شده است كه منجر به عرضه UML 2.0 گرديده است. درعين حال كه چندين قابليت جديد مدلسازي اضافه شده است – مانند قابليت بيان دقيقتر معماري نرمافزار - خصوصيت غالب اين بازبيني عمده، زياد كرد دقچت قابليت تعريف زبان است كه سطح بالاتري از خودكارسازي را فراهم ميكند. در ادامه شرح خواهيم داد كه UML2.0 چگونه به اين موارد دست يافته است و ساير جنبههاي مهم آنرا نيز بيان خواهيم كرد. همانگونه كه ميدانيد UML بوسيله توليدكنندگان بزرگ ابزارهاي مدلسازي پذيرفته و پشتيباني ميشود، و بصورت يك بخش ضروري از دانش مهندسي نرمافزار درآمده است و در دانشگاهها نيز تدريس ميشود. همچنين نقش مهمي در مدلسازي نرمافزارهاي پيچيده ايفا ميكند. اما با وجود همه اين مزايا همچنان مقاومتهايي در برابر استفاده از UML وجود دارد. دلايل زيادي براي اين وضعيت وجود دارد، لكن يكي از مهمترين آنها اين است كه مدلهاي نرمافزار ممكن است در بعضي موارد بسيار نادقيق باشند و ارزش كاربردي هر مدلي با ميزان دقت و صحت آن تناسب مستقيم دارد. چنانچه شما نتوانيد به يك مدل از يك سيستم نرمافزار اعتماد كنيد، بدتر از حالتي است كه مدلي وجود نداشته باشد، زيرا ممكن است منجر به تصميمگيري غلط شما شود. بنابراين بهترين راهحل افزايش ارزش مدلهاي نرمافزاري كم كردن فاصلة ميان آنها و سيستمي است كه آنرا مدل كردهاند. جالب است بدانيد - همانطور كه در ادامه بيان خواهيم كرد- در مهندسي نرمافزار بيش از ساير رشتههاي مهندسي اين كاهش فاصله امكانپذير است.
Model-Driven Development
راهحل اين معما اتصال دقيق يك مدل به معادل پيادهسازي نرمافزاري آن با استفاده از يك يا چند تبديل مدل خودكار است. شايد بهترين مثال يك كامپايلر باشد، كه يك برنامه كه به زبان سطح بالا نوشته شده است را به متناظر سطح ماشين آن برنامه تبديل ميكند. مدل، در اين حالت، نقش آن زبان سطح بالا را ايفا ميكند كه جزئيات غير ضروري را نمايش ميدهد. جالب است توجه كنيد در هيچ يك از رشتههاي مهندسي ديگر نميتوانند اين ارتباط قوي بين مدل و فرآوردة مهندسي آن ايجاد كنند. زيرا فرآوردهاي كه شما آنرا مدل ميكنيد نرمافزار است و نه سختافزار. يك مدل از هر نوع از فرآوردههاي فيزيكي (بعنوان مثال، يك اتومبيل، ساختمان، پل و موارد ديگر) هنگام مدلكردن نياز به يكسري حذف جزئيات و مجردسازي است كه بصورت غير دقيق انجام ميشود و هنگام ساخت يك فرآورده مهندسي از روي مدل مجرد نيز لازم است يك سري تبديلهاي غير دقيق انجام شود. ماهيت اين تبديلها به دليل عدم دقتي كه دارند ممكن است مدلها را به يك موجوديت ناكارا يا حتي مزاحم تبديل كنند. حال آنكه در نرمافزار اين تبديلها، بطور كلي، ميتوانند بصورت كاملا دقيق و قاعدهمند انجام شوند. پتانسيلي كه در وراي اين تركيب قدرتمند تجرد و خودكارسازي وجود دارد منجر به ظهور تكنولوژي مدلسازي جديدي به همراه روشهاي توليد متناظر با آن شده است كه با عنوان توليد مدلگر (model-driven development) شناخته ميشود. ويژگي اصلي MDD اين است كه مدلها به فرآوردة اصلي طراحي نرمافزار بدل گشتهاند، كه منجر به انتقال تمركز بيشتر از كد برنامه به مدل ميشود. با دقيقتر شدن مدلها (كه UML 2.0 اين قابليت را فراهم ميآورد) سطح خودكارسازي توليد كد از روي مدل افزايش پيدا ميكند و مزاياي MDD بيشتر نمايان ميشوند. لازم به ذكر است كه پيش از اين هم در عمل MDD مورد استفاده قرار گرفته است، لكن در حال حاضر به دليل رشد و افزايش قابليت تكنيكها و استانداردها (مانند UML 2) اين امكان بيشتر فراهم شده است و MDD بيشتر مورد توجه قرار گرفته است.
اهمِ موارد جديد در UML 2.0
توسعههاي جديدي كه در UML 2.0 انجام شده است را ميتوان در اين پنج دسته عمده گروهبندي كرد كه در ادامه به ترتيب اهميت بيان شدهاند.
افزايش قابل توجه ميزان دقت در تعاريف زبان
كه نتيجه نياز به پشتيباني از خودكارسازي سطح بالاتري است كه براي MDD لازم است. لازمة خود كارسازي رفع ابهام و عدم دقت از مدلها (و در نتيجه از زبان مدلسازي) است تا برنامههاي كامپيوتر ي بتوانند مدلهاي را تبديل به كد كنند. يكي از اقداماتي كه به منظور كمينه كردن ابهامات و افزايش دقت مدل انجام شده است استفاده از metamodel است. اين مدل خصوصيات هر عنصر مدلسازي UML و ارتباط آن با ساير مفاهيم مدلسازي را تعريف ميكند. اين metamodel با استفاده از يك زيرمجموعه از عناصر UML - كه بيشتر مفاهيم Class Diagram هستند و اصطلاحا Meta-Object Facility (MOF) ناميده ميشوند - تعريف شده است و بوسيله يك مجموعه از محدوديتهاي رسمي كه به زبان Object Constraint Language (OCL) نوشته شده است پشتيباني ميشود. بطور خلاصه ميزان دقت تعاريف زبان UML 2.0 با روشهاي زير بطور قابل توجهي افزايش يافته است :
- يك سازماندهي مجدد عمده در فراساختار metamodel
- توصيفهاي معنايي توسعه يافته و دقيقتر
- يك چارچوب معنايي پويا و شفاف به منظور پركردن خلاءهايي كه در اين زمينه وجود داشت
شكل 1 - چارچوب معنايي UML 2.0
بهبود سازماندهي زبان
با پيمانهاي (Modular) كردن زبان، علاوه بر اينكه براي كاربران جديد امكان شناخت و استفاده سادهتر خواهد بود، همكاري ميان ابزارها را نيز تسهيل ميكند. در واقع معماري بهتري براي زبان ايجاد شده است. با توجه به افزايش دقت UML 2.0، تعاريف زبان بزرگتر شدهاند و در نتيجه چنانچه از همان ساختار و معماري UML 1 براي آن استفاده ميشد، فهم و استفاده از آن را بسيار مشكل ميساخت. به منظور مقابله با مشكل پيچيدگي زبان، UML 2.0 بصورت پيمانهاي درآمده است تا امكان استفادة انتخابي از پيمانههاي زبان فراهم شود. شكل كلي اين ساختار در شكل 2 نمايش داده شده است. همانطور كه مشاهده ميشود از يك پايه كه شامل عناصر به اشتراك گذاشته شده است (مانند كلاسها و روابط association)، كه بر روي آن مجموعهاي از زير-زبانها يا عناصر زبان وجود دارد. هر كدام از اين زير-زبانها براي مدلسازي يك قالب يا جنبة بخصوص مناسب هستند. اين عناصر در Error! Reference source not found. نمايش دادهشده اند. اين عناصر افقي زبان بطور معمول از يكديگر مستقل هستند و بنابراين شما ميتوانيد آنها را بصورت مستقل استفاده كنيد (برخلاف UML 1 كه بعنوان مثال activity diagram بطور كامل بر روي state diagram قرار گرفته بود).
شكل 2- معماري زبان UML 2.0
علاوهبر اين عناصر افقي زبان بصورت سلسلهمراتبي در سه سطح سازماندهي شدهاند كه سطح بالاتر قابليتهاي بيشتري نسبت به سطح پايينتر دارد. به اين ترتيب زبان از يك بعد ديگر نيز پيمانهاي است و شما را قادر ميسازد كه حتي در يك واحد زبان هم يك زيرمجموعة بخصوص را انتخاب كنيد. اين ساختار معماري زبان شما را قادر ميسازد كه تنها يك زير مجموعه از UML را بياموزيد و بكار ببريد كه مناسب كار شما است و به مرور زمان و كسب تجارب بيشتر ميتوانيد با عناصر قدرتمندتر زبان آشنا شويد و در هنگام نياز از آنها استفاده كنيد.
جدول 1- عناصر زبان UML 2.0
Purpose
Language Unit
(Foundation) modeling of fine-grained actions
Actions
Data and control flow behavior modeling
Activities
(Foundation) modeling of basic structures
Classes
Complex structure modeling for componenttechnologies
Components
Deployment modeling
Deployments
(Foundation) common behavioral semantic base and timemodeling
General Behaviors
Abstract data flow modeling
Information Flows
Inter-object behavior modeling
Interactions
Model organization
Models
Language customization
Profiles
Event-driven behavior modeling
State Machines
Complex structure modeling
Structures
Pattern modeling
Templates
Informal behavioral requirements modeling
Use Cases
بهبود قابل توجه در توانايي براي مدل كردن سيستمهاي نرمافزاري بزرگ
برخي از نرمافزارهاي كاربردي مدرن تجميع برنامههاي كاربردي مستقل را در قالب سيستمي از سيستمها نمايان ميسازند و اين روندي است ادامه دار كه منجر به پيچيدهتر شدن سيستمها خواهد شد. براي پشتيباني از چنين روندهايي، قابليتهاي جديد انعطافپذيرِ سلسلهمراتبي به زبان اضافه شده است تا از مدلسازي نرمافزار در سطوح دلخواه پيچيدگي پشتيباني كند. بطور كلي تعداد قابليتهاي جديد اضافه شده به UML 2.0 كم است تا از بزرگ شدن زياد زبان جلوگيري شود و بخش عمدهاي از اين قابليتهاي جديد مدلسازي، گسترشي بر استفاده از قابليتهاي جديد است كه به شما امكان مدلسازي سيستمهاي نرمافزاري بزرگ را ميدهد. علاوهبراين، اين گسترشها با استفاده از يك راهكار پايهاي يكسان بدست آمدهاند : استفادة بازگشتي از مجموعة يكساني از مفاهيم در سطوح مختلف تجرد. بدين معني كه شما ميتوانيد عناصر مدلسازي مربوط به يك گونه بخصوص را با يكديگر تركيب كنيد تا واحدهايي ايجاد شود كه بعنوان بلوكهاي سازنده در سطح بعدي تجرد مورد استفاده قرار گيرند. اين وضعيت قابل مقايسه با روشي است كه در برنامهنويسي procedure ها ميتوانند تا چندين سطح در داخل يكديگر فراخواني شوند(NestedProcedure Call). بطور مشخص، قابليتهاي مدلسازي زير بدين روش توسعه يافتهاند : - ساختارهاي پيچيده (Complex Structures)
- فعاليتها (Activities)
- تعاملها (Interactions)
- ماشينهاي حالت (State machines)
سه تاي اول از ليست بالا 90% قابليتهاي جديد UML 2.0 را شكل ميدهند.
ساختارهاي پيچيده (Complex Structures)
به اين منظور عناصر پايهاي ساختاري كه part ناميده ميشوند ممكن است يك يا چند درگاه (port) داشته باشند كه با استفاده از كانالهاي ارتباطي كه اتصالدهنده (connector) ناميده ميشوند (همانگونه كه درشكل 3 نمايش داده شده است) به يكديگر متصل شدهاند. اين ساختار تجمعي ميتواند در داخل عناصر سطح بالاتر كپسوله شود كه port هاي خود را دارند و ميتوانند با عناصر سطحبالاتري متصل شوند و به همين ترتيب عناصر سطح بالاتري ميتوانند ساخته شوند.
شكل 3- مفاهيم مدلسازي ساختارهاي پيچيده
فعاليتها (Avtivities)
Activity ها در UML براي مدلكردن انواع مختلفي از جريان مورد استفاده قرار ميگيرد : جريان signal يا data، و نيز جريانهاي algorithmic يا procedural. در UML 1 يك محدوديت عمده براي Activity ها وجود داشت و آن هم اين بود كه آنها بر پايه ماشين حالت قرار گرفته بودند و بنابراين در حوزة معنايي ماشينهاي حالت محدود شده بودند. در UML 2.0 پاية ماشين حالت با يك چارچوب معنايي عمومي ديگر كه تمام اين محدوديتها را حذف كرده است جايگزين شده است. (در واقع، پاية معنايي با استفاده از petri net colored هاي عموميشده جايگزين شده است). علاوه بر اين از برخي استانداردهاي صنعتي براي مدلسازي فرآيندهاي كسب و كار مانند BPEL4WS الهام گرفته است.
تعاملها (Interactions)
تعاملهاي ميان اشياء در UML 1 يا با استفاده از collaboration diagram و يا با استفاده از sequence diagram نمايش داده ميشدند. لكن متأسفانه دو قابليت اساسي جا افتاده بودند :
1. امكان استفادة مجدد از تواليها كه ممكن بود در متن دنبالههاي ديگر تكرار شوند. بعنوان مثال، يك دنباله كه هويتشناسي كاربر را انجام ميدهد ممكن است در چندين جاي مختلف يك برنامة كاربردي رخ دهد. بدون امكان بستهبندي اين دنبالههاي تكرار شونده در عناصر جداگانه، لازم بود كه آنها را چندين مرتبه بيان كنيد كه علاوه بر افزودن سربار اضافي، نگهداري مدل را نيز مشكلتر ميكرد.
2. امكانات كافي براي مدلكردن جريانهاي پيچيده مختلف كه در بازنمايي تعاملات سيستمهاي پيچيده رايج هستند. اين قابليتها شامل تكراركردن يك زيردنباله، مسيرهاي اجرايي آلترناتيو، اجراهاي همروند و مستقل از ترتيب، حلقه، شرط و موارد مشابه ميشود.
مهمترين نوآوري در اين زمينه معرفي تعاملها (Interaction) بصورت يك واحد مدلسازي جداگانه نامگذاري شده است كه امكان پارامتري كردن آنها نيز وجود دارد و بنابراين ميتوان هر سطح پيچيدگي دلخواهي از تعاملهاي ميان اشياء را در يك نمودار تعامل مدل كرد.
شكل 4 - مثالي از يك مدل تعاملي پيچيده
همانگونه كه در شكل 4 نشان داده شده است شما ميتوانيد اين تعاملات بستهبندي شده را در تعاملات سطح بالاتر بصورت بازگشتي فراخواني كنيد.
ماشينهاي حالت (State Machine)
مهمترين قابليتي كه ماشينهاي حالت در UML 2.0 اضافه شده است كاملا مشابه موارد قبلي است. ايدة اصلي اين است كه شما ميتوانيد يك ماشين حالت پيچيده را كاملا بصورت پيمانهاي مدل كنيد كه داراي نقاط مشخصي براي ورود و خروج است. به اين ترتيب شما ميتوانيد تجزيه داخلي يك ماشين حالت را بوسيله يك مجموعه از ماشينهاي حالت جداگانه و قابل استفاده انجام دهيد. به اين ترتيب توصيف يك الگوي رفتاري مشترك در چند حوزة مختلف به سادگي انجام ميپذيرد.
شكل 5- نمونهاي از نمودار حالت در UML 2.0
بهبود پشتيباني براي سفارشي سازي براي يك حوزه بخصوص
تجارب عملي استفاده از UML ارزش مكانيزمهاي توسعه (Extension) آنرا نمايان ساخته است. در UML 1.x فقط از مكانيزمهاي توسعة stereotype و profile استفاده ميشد، لكن در UML 2.0 مكانيزم توسعة جديد metamodel اضافه شده است كه امكانات توسعة سطح بالاتري را فراهم ميكند.
تقويت، تطابق با اصول، روشني و وضوح بيشتر براي مفاهيم مختلف مدلسازي
زبان سادهتر و سازگارتر شده است. اقدامات جديد شامل تقويت و تثبيت مفايهم و – در بعضي موارد – حذف مفاهيم تكراري، پالايش چندين تعريف و افزودن توضيحات متني و مثال بوده است.