شيوه‌های استخراج جنبه و معرفی پژوهشگران مشهور

نويسنده: مهندس سیدمصطفی مفیدیان

تکنيک‌های اوليه‌ی استخراج جنبه. در گذشته، اصلي‌ترين مساله در توسعه‌ی نرم‌افزارهاي جنبه‌گرا، مرحله‌ی پياده‌سازی نرم‌افزار بود. در تحقيقات اوليه‌ای که روي جنبه‌ها صورت پذيرفت سعي بر اين بود تا جنبه‌ها نيز مانند نيازمندي‌ها و تحليل دامنه يا طراحي معماري در مراحل اوليه‌ی چرخه‌ی توليد نرم‌افزار ظاهر شوند. تشخيص و مديريت تکنیک‌های اولیه ی جنبه، هيچ تاثيري در بهبود پيمانه‌بندي نيازمندي‌ها و طراحي معماري ندارد، زيرا در اين حالت، نتيجه‌اي همانند پياده‌سازی جنبه‌ها حاصل می‌شود. در سيستم‌های قديمي که داراي نيازمندي‌ها و مستندات معماري منسوخ شده يا غيرقابل دسترس هستند، تکنيک‌های استخراج جنبه امکان ظهور و تمرکز روي کد را ندارند.
کاوشگرهاي اختصاصي . به دسته‌اي از کاوشگرهاي خاص اطلاق می‌شود که در آن توليد کننده، براي کشف دغدغه‌های تداخلي، کد سيستم را به صورت دستي جهت‌يابي يا کنترل می‌نمايد. هدف اين شيوه‌ها استخراج جنبه‌ها نبوده بلکه هدف اوليه‌ی آن بررسي اختصاصي مستندات و کشف دغدغه‌های تداخلي است که اين کار نيز به نگهداري و تکامل سيستم ترجيح داده می‌شود. از کاوشگرهاي اختصاصي می‌توان براي شناسايي جنبه‌ها در سيستم استفاده کرد.
معمولاً کاربر در کد با دغدغه‌هايي روبرو می‌شود که کشف آن برعهده‌ی کاوشگرهاي اختصاصي است. در چنين کاوشگرهايي، کاربر کانون بحران‌هايی خواهد شد که به دغدغه ترجيح داده می‌شوند، يا اين که کاربر خود با زبان پرس‌وجو دغدغه را به صورت دستي پيدا می‌کند. می‌توان براي مثال شيوه‌هايي مانند گراف‌های دغدغه [1]، ديدهاي Intensional [2]، کاوشگر جنبه [3]، ابزار جنبه‌کاوي (توسعه يافته) [4]، Prism [5]، JQuery و غيره را نام برد.
شناسايي (شبه-) خودکار کانديدهاي جنبه. براي تکميل کاوشگرهاي اختصاصي، تکنيک‌هايي وجود دارد که به عنوان هدف براي فرآيند خودکار شناسايي جنبه‌ها بکار می‌آيند و کاربر به آنها يک يا چند کانديد جنبه را پيشنهاد می‌کند. در نهايت، اين تکنيک‌ها کد سيستم يا داده را استدلال کرده تا با اجرا يا دستکاري کد، جنبه بدست آيد. به نظر می‌رسد براي نشان دادن دغدغه‌های تداخلي، دست‌کم تمام تکنيک‌ها با هم اشتراک دارند. درواقع، تکنيک‌های داده‌کاوي و تحليل داده شبيه تحليل مفهوم رسمي و تحليل خوشه‌بندي، يا تکنيک‌های تحليل کد شبيه برش برنامه، اندازه‌گيري نرم افزار، تشخيص هم نوع، تکنيک‌های تطبيق الگو، تحليل پويا و غيره را بکار می‌برند.
در ادامه نگرشي کلي از کار پژوهشگراني که روي تکنيک‌های استخراج خودکار جنبه تحقيق کرده‌اند، ارائه می‌گردد:
سيلويا بروو و جنز کرينک از تحليل ايستا و پويا براي تشخيص الگوهاي فراخواني تکراري و استخراج دغدغه‌های تداخلي استفاده کردند [6].
ماجيل برونتينک و تام توروو بررسي نمودند که دغدغه‌های تداخلي چطور می‌تواند از مهندسي معکوس برنامه‌های کاربردي صنعتي بزرگ حاصل شود و چگونه تکنيک‌های توسعه‌ی نرم‌افزار جنبه‌گرا می‌توانند کيفيت چنين برنامه‌های کاربردي را بهبود بخشند.
ماريانو سککاتو و پائولو تونللا تکنيک‌های تحليل پويا و تحليل مفهوم رسمي را براي استخراج کد با جنبه‌ها ترکيب نمودند[7].
کريس گيبلز و اندي کللنز تکنيک‌های استخراج جنبه‌ی مبتني بر سلسله مراتب را کشف کردند که از طريق آن به تکنيک برنامه‌نويسي منطق استقرايي خودکار نقاط برش در نرم‌افزار پي بردند.
ماريوس مارين ، لئون مونن و اريه وان درسن تکنيک تحليل ظرفيت ورودي به شناسايي شبه خودکار جنبه‌ها در کد جاوا را مطالعه نمودند که به صورت جنبه‌گرا نوشته نشده است[10].
مارتين روبيللارد و گيل مورفي به استخراج دغدغه با استفاده از وابستگي عضو کلاس پرداختند. در اين روش، دغدغه‌های پيمانه‌بندي شده با تعريف سيستم يا اعضاي کلاس ادغام می‌شوند[12].
کيم منز و تام توروو تکنيک تحليل مفهوم رسمي در کد Smalltalk يا جاوا را براي کشف جنبه‌ها و دغدغه‌های تداخلي، مبتني بر مشابهت در شناسايي متدها و کلاس‌ها ارائه کردند[8].
ديويد شفرد چارچوبي براي ترکيب تحليل استخراج جنبه ارائه داد. هم چنين تشخيص همنوعي کد را جهت شناسايي جنبه‌ها مورد استفاده قرار داد[9].
اندي زايدمن از الگوريتم‌های داده‌کاوي براي کشف کلاس‌های مهم در معماري سيستم استفاده کرد که کانديدهاي درجه يک براي جنبه‌ها هستند[11].

منبع:

1. M. P. Robillard and G. C. Murphy, “Concern graphs: Finding and describing concerns using structural program dependencies”, Proceedings of the 24th International Conference on Software Engineering (ICSE 2002), Orlando, Florida, 2002.
2. K. Mens, B. Poll and S. Gonz´alez, “Using intentional source-code views to aid software maintenance”, International Conference on Software Maintenance (ICSM’03), IEEE Computer Society Press, 2003.
3. W. Griswold, Y. Kato and J. Yuan, “Aspect browser: Tool support for managing dispersed aspects”, Workshop on Multi-Dimensional Separation of Concerns in Object-oriented Systems, 1999.
4. C. Zhang and H. Jacobsen, “Extended aspect mining tool”, http://www.eecg.utoronto.ca/_czhang/amtex, 2002.
5. C. Zhang and H. Jacobsen, “Prism is research in aspect mining”, OOPSLA, ACM, 2004.
6. J. Krinke and S. Breu, “Control-flow-graph-based aspect mining”, Proceedings of the First Workshop on Aspect Reverse Engineering at Working onference on Reverse Engineering (WCRE 2004), Delft, 2004.
7. P. Tonella and M. Ceccato, “Aspect mining through the formal concept analysis of execution traces”, Working Conference on Reverse Engineering (WCRE), 2004.
8. K. Mens and T. Tourw´e, “Delving source-code with formal concept analysis”, Elsevier Journal on Computer Languages, Systems & Structures, 2005.
9. D. Shepherd, T. Tourw´e and L. Pollock, “Using language clues to discover crosscutting concerns”, Workshop on the Modeling and Analysis of Concerns, 2005.
10. M. Marin, A. van Deursen and L. Moonen, “Identifying aspects using fan-in analysis”, Working Conference on Reverse Engineering (WCRE), IEEE Computer Society, 2004.
11. A. Zaidman, T. Calders, S. Demeyer, and J. Paredaens, “Applying web mining techniques to execution traces to support the program comprehension process”, 8th European Conference on Software Maintenance and Reengineering (CSMR), pages 329–338. IEEE Computing Society, 2005.
12. M. P. Robillard and G. C. Murphy, “Concern graphs: Finding and describing concerns using structural program dependencies”, Proceedings of the 24th International Conference on Software Engineering (ICSE 2002), Orlando, Florida, 2002.

منبع:www.articles.ir