language-icon Old Web
English
Sign In

How to Handle Interacting Concerns

2000 
Concerns in software applications can range from general-purpose concerns such as tracing, synchronization or error handling, to more specific ones such as scheduling in simulation domains or time constraints in real-time systems. An appropriate separation of concerns is supposed to reduce software complexity and improve software evolution, by keeping track of different decomposition criteria (software dimensions) at the same time. Usually relevant concerns vary over time, are not orthogonal and conflicting among them, and become very domain-specific. Reasoning about a flexible way of handling aspects involving interaction of concerns still remains as an open challenge. In this context, we present an example based on the simulation of a thermic control system, showing how aspects related to mathematical models, concurrency, scheduling and optimizations, are scattered across the system, and how these interacting concerns are separated from the core functionality but coupled among them. A reflective approach is used to support these aspects within an object-oriented language. This work hopes to contribute to discuss how interacting (and often conflicting) concerns work in practice, and encourage developers towards a more systematic approach for an effective separation of concerns.
    • Correction
    • Cite
    • Save
    • Machine Reading By IdeaReader
    13
    References
    4
    Citations
    NaN
    KQI
    []