原文:http://jroller.com/page/rickard/20050605#the_three_kinds_of_aspect
As I look through our aspect configuration I notice that there is a distinct pattern throughout. The configuration, some of which is XML and some of which is provided by Java source code, can be divided into three kinds.
The first kind is the configuration about a single aspect. It defines the aspect, be it an advice or introduction, and declares its relationship with the world. Its dependencies and what it provides. What goes in and what comes out.
The second kind is the configuration that declares how different aspects should relate in a specific system. It imports aspects, declares precedence between them, and how they should be grouped depending on annotations and what interfaces specific objects implement. What goes in and what comes out. But on a higher level.
The third kind is the configuration that describes specific classes, or "sets of objects". It defines the introductions applied to particular classes, which in a cascading fashion will also determine to some degree what advice will be added. Introductions can be added on a very granular basis, i.e. to a specific class, or to sets of classes, like a package.
The first kind forms the atoms of an AOP application. The smallest lego blocks available. The second kind determines the rules for how the atoms form together into molecules; the natural laws so to speak. These become the building blocks of real structures, and depending on how they are formulated you get different orders of stability, flexibility and/or chaos. The third kind is the actual application, as it is perceived by clients of it, and hence it can be extremely varied.
In terms of reusability the first kind of configuration is extremely reusable as each individual aspect make minimal assumptions about how they are used, even though "minimal" can be quite substantial in some cases. The second kind is less reusable since it imposes assumptions about what set of aspects need to be available for its "laws" to function properly. This is because the second kind is what it responsible for describing how aspects interact, and if some of them cannot be used for some reason the laws suddenly don't behave as they were intended. The third kind is even less reusable as it makes a lot of assumptions about what is available, and the configuration is rather specific in terms of what the end result is supposed to do.
The resulting components adhere to a strictly defined behaviour (depending on the quality of the second kind of configuration, of course), which can be used by other components, and even individual aspects. In this sense, even though everything is separate, they are also inherently intertwined in a symbiotic fashion where it is difficult to separate one from the other.
By acknowledging that there are different kinds of configuration it is possible to introduce a degree of order into an AOP application. Everything is not equal, everything is not the same, which is what gives the developer a possibility to ensure that any new aspect (s)he creates fits into an existing system in a non-disruptive manner.
Harmony follows and everyone is happy.
The End.
分享到:
相关推荐
The Myth of The First of Three Years
The pessimistic diagnosability of three kinds of graphs
英文名称:ROMANCE OF THE THREE KINGDOMS XIV 游戏类型:策略类(SLG)游戏 游戏制作:KOEI TECMO GAMES CO., LTD. 游戏发行:KOEI TECMO GAMES CO., LTD. 游戏平台:PC 发售时间:2020年1月16日 官方网站:...
带有$h-e-$蕴涵的三类函数方程,刘华文,,最近,作者引入了一类新型模糊蕴涵称之为$h-e-$蕴涵。本文研究带有这类新型蕴涵的三类函数方程,即输入法则、收缩律和新型蕴涵关于三�
The cooling system of an injection mould is very important to the productivity of the injection moulding process and the quality of the moulded part. Despite the various research efforts that have ...
In this book, the application of the compensation technique and circuits to three different systems is proposed: a highprecision digital-to-analog converter, a SOI (silicon on insulator) 1T DRAM...
Research on Three-dimensional Reconstruction of the Liver CT Images.pdf
arlier this month, Michelle Obama and twenty-three schoolchildren helped prepare the ground for an organic vegetable garden on the South Lawn of the White House.
After a summary of the basic structure of a field-oriented controlled three-phase AC drive as well as of a grid voltage orientated controlled wind power plant the inverter control by space vector ...
1)Select one number q and then divide the sequence S into three sub-suquences: S1 in which all of elements are less than q, S2 in which all of elements are equal to q, and S3 in which all of elements ...
Comparison of the three CPU schedulers in Xen Xen调度
On the Solution of Lambert's Orbital Boundary-Value Problem During the past 30 years there has been a resurgence of interest in the classical orbital boundary value problem of Lambert, largely ...
Abstract—This paper presents an overview of the field of recommender systems and describes the current generation of recommendation methods that are usually classified into the following three main...
An efficient algorithm that make use of the evolution cone of GC maxima to detect the instant of GC is presented together with three erformance measurements regarding the accuracy of location, false ...
ECS, the construction of the Three-Gorges Dam (TGD) was begun in 1994 about 2000 km upstream from the mouth of the Changjiang River, with the first filling stage of the reservoir completed in June ...
Kinematics Analysis and Optimization of Three Degree of Freedom Mobile Platform,Azouz Radhia,赵刚,A study of the kinematics characteristics of three degree of freedom (DOF) parallel mechanism is ...
mathematically rigorous exposition of a broad and vital area in computer vision: the problems and techniques related to three-dimensional (stereo) vision and motion. The emphasis is on using geometry...