Download presentation
Presentation is loading. Please wait.
Published byMartin Thomas Modified over 9 years ago
1
JCMP: Linking Architecture with Component Building Guoqing Xu, Zongyuan Yang and Haitao Huang Software Engineering Lab, East China Normal University SACT-01, Pusan, Nov. 30th, 2004 A previous version has been presented at poster session of ACM SIGSOFT 04 FSE-12 conference.
2
Outline Introduction and Motivation Our Techniques --- Triple-C Model --- JCMPL language ---JCMP toolset Analysis SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
3
Problems and Motivation Two basic characteristic of components defined in the architecture: --- Conform to the architecture Follow the three criteria identified in [LV95] --- Support a great deal of flexibility A protocol or style is needed to support the independent building for the composite adaptation. These two issues are far from orthogonal although their concern is different. SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
4
Enforce the architectural conformance (current research) Three criteria identified in [LV95] ---Decomposition easy ---Interface conformance easy ---Communication Integrity hard SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
5
Enforce Communication Integrity (current research) Ask implementers to follow style guidelines (Rapide with C2 style [Luc96]) --- not enforced automatically Unify implementation and architecture in one language. (ArchJava [ACN02]) --- doesn ’ t support architecture design. Both don ’ t consider composite adaptation issues. --- there exists the direct client-server relationship between components. SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
6
Composite Adaptation (Current Research) Use Module Interconnection Languages (MILs) to describe use relationship. --- Jiazzi or Knit Use on-demand remodularization. --- pluggable composite adapter[MSL01] They don ’ t describe data and control flow between components and therefore cannot enforce communication Integrity. SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
7
Problem conclusions Current solutions to either of two issues don ’ t deal with another. How to support composite adaptation in the context of architectural constraints? SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
8
Outline Introduction and Motivation Our Approach --- Triple-C Model --- JCMPL language --- JCMP toolset Case study and Analysis SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
9
Triple-C Model Component-Communicate-through-Connector. It extends the three criteria in [LV95] in two aspects: --- A concrete connector in the implementation for each abstract connector in the architecture. --- Concrete connectors are used as wrappers to transfer the service flow between the components. SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
10
Model Overview Currently the connector Specify the communication permission in the arch. Used as wrapper or glue code to transfer the methods invocation. SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
11
Basic ideas of our approach Linking architecture with component building (composite adaptation). The key technique is to automatically generate the connector impl. from connector spec in the arch. We made a JCMP system: --- an ADL: JCMPL --- a toolset: JCMP JCMP/Compiler JCMP/Match JCMP/Checker JCMP/Kernel Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004 SEL, East China Normal University
12
JCMPL Language It uses the Java like grammar at an abstract level. It is not only an ADL, but also an IDL. It describes only abstractions, without any detailed type operations. Translated by JCMP/Compiler to the implementation skeleton. SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
13
JCMPL Language (Cond.) out in ScannerParser //Parser.jcmpl public PrimComponent Parser{ public port in{ RequireInterface r{ Token nextToken()throws ScanExceptions; }; } Public PrimComponent Scanner{ public port out{ ProvideInterface req{ Token next(); }; } A Compiler Model public AdvancedComponent Compiler{ public port in{ RequireInterface get{... InputStream getInputStream() }; } public port out{ ProvideInterface err{ Integer getErrCode();... }; } Scanner scanner = new Scanner(); Parser parser = new Parser(); connect sanner.out, parser.in; } SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
14
Generated Style A concrete connector is generated. The component only requests the services from the connector and publishes their provided services. The connector performs the dynamic matching and transfer the invocation. Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004 SEL, East China Normal University
15
Dynamic interface matching Searching for a pair of “ require-provide ” methods which match each other in semantic from two connected ports. Based on JML Spec. of each method. The matching strategy match_jcmp/match (P, R) = (Rpre => Ppre) ^ ( (Ppre^ Ppost) =>Rpost ) Run P and R with test cases to watch whether their behaviors are observably equal. SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
16
Checking conformance in impl. JCMP/Checker instruments methods with arguments of primitive types. It uses both architecture and implementations as input to check whether they conform to each other. If the impl. does not conform to the arch., JCMP/Checker reports errors; otherwise, it compiles the impl. Into the bytecode files (.class). SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
17
Why it works — enforce communication integrity in impl. All interface methods are generated as private. This enforces that all interface methods cannot be directly called. The only way to call an interface method is through connector, which uses reflection to suppress access checking. The connector is generated automatically from connector spec., and methods comm. In impl. is therefore enforced to conform to its spec. Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004 SEL, East China Normal University
18
Why it works — support composite adaptation Concrete connector serves as glue codes. When a component is being built, if it requires a service, only requesting this from the conn. Conn. uses JCMP/Match to find the suitable method, calls the method, and finally returns the value back when the system is integrated. SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
19
Outline Introduction and Motivation Our Techniques --- Triple-C Model --- JCMPL language ---JCMP toolset Analysis SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
20
Performance Issues The cost in running JCMP system has two components: --- the runtime cost of type reflection. --- the extra cost of invocation transfer through the connector. Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004 SEL, East China Normal University
21
Experiment Construct a linked list with a given array of integers. construct (int[] nodes) Retrieve a node from the given node ID after the list is constructed. retrieve (Integer index) SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
22
Comparisons SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
23
Analysis Summary We found out that encapsulating the parameters of primitive types into objects took tremendous amount of time. The cost of method invocation through connector was not obvious. Since JCMP uses reflection, we suggest objects be used as data to be transferred, rather than primitive values. SEL, East China Normal University Guoqing Xu, SACT-01, Pusan, Nov.30th, 2004
24
Future Work JCMPL is only used at the design level, without supporting the dynamic description of runtime architecture. Architectural styles should be considered. The performance should be optimized in the way of having some other techniques to replace the Java reflection.
25
Conclusions To link architecture with component building, we made: Triple-C model JCMP toolset --- an ADL JCMPL --- JCMP system
26
Thank you
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.