Version 3 (modified by meddle, 16 years ago) (diff) |
---|
Analysis
Overview
The goal of this group of tasks is to improve the performance of the ProLib.
This revision of the task is responsible for improving the performance of ProLists.
Task requirements
There are too many notifications for updates when using a ProList.
Currently, when an AutoProperty depends on a ProList, it gets recomputed every time anything about the ProList changes - its size, its elements, etc. In certain cases, though, an AutoProperty might depend only on the size of a given ProList and thus in doesn't need to get recomputed when some elements in the ProList change their value, because this operation doesn't change the size of the list.
Another case is when you deal with skins. Skins are basically maps between keys and values. At a certain time an AutoProperty might be interested to monitor only the list of all pairs of keys and values which have the key "meddle". So if this list remains the same while the whole ProList which contains it changes, this AutoProperty shouldn't get recomputed.
- Devise and implement a concept how to deal with such problems.
- Refactor ProList, BaseProList and ListEntry code to fix design issues from previous tasks.
- Refactor all client code to meet new implementation.
- Think of tests which measure new performance against the current.
Task result
- New functionality code
- Nice unit tests
Implementation idea
Introduce aspects.
Related
How to demo
- Show previous unit tests don't break
- Show performance improvement
Design
Implementation
(Describe and link the implementation results here (from the wiki or the repository).)
Testing
(Place the testing results here.)
Comments
(Write comments for this or later revisions here.)
Attachments
-
2009-05-09-15-29 patch
(24.0 KB) -
added by gogov 16 years ago.
latest patch. size aspect works!
-
2009-05-08-21-22 patch
(45.3 KB) -
added by gogov 16 years ago.
old patch