Libraryless. Click here for Pure Java version (10127L/55K).
// synchronized except for iterator persistable sclass MRUAndAllTimeTop_optimized<A> { Map<A, Bool> mru = syncMRUCache(10); // most recently used new OptimizedMultiSet<A> allTimeTop; int allTimeMaxSize = 100; // increase a's score in all time top and move to front int MRU synchronized void add(A a) { mru.remove(a); // force re-insertion mru.put(a, true); allTimeTop.add(a); allTimeTop.truncate(allTimeMaxSize); } synchronized void addAll(Iterable<A> l) { fOr (A a : l) add(a); } // may count elements twice synchronized int size() { ret l(mru) + allTimeTop.uniqueSize(); } // interleave latest and most often accessed elements // iterator not synchronized synchronized ItIt<A> mixedIterator() { ret uniqueIterator(roundRobinCombinedIterator( reversedIterator(keysList(mru)), iterator(allTimeTop.highestFirst()))); } toString { ret shortClassName(this) + " (" + n2(size()) + ")"; } // MRU elements in last access order // (These aren't that optimized, really. Should replace // LinkedHashMap.) Cl<A> recent() { ret reversedKeysList(mru); } A mostRecent() { ret last(keys(mru)); } }
Began life as a copy of #1024856
download show line numbers debug dex old transpilations
Travelled to 4 computer(s): bhatertpkbcr, ekrmjmnbrukm, mqqgnosmbjvj, pyentgdyhuwx
No comments. add comment
| Snippet ID: | #1031875 |
| Snippet name: | MRUAndAllTimeTop_optimized - keep sorted top ten list |
| Eternal ID of this version: | #1031875/12 |
| Text MD5: | 36cde0f285098a16e614db74876b80de |
| Transpilation MD5: | b14d5f5e062dba2d25680f21bea61d0d |
| Author: | stefan |
| Category: | javax |
| Type: | JavaX fragment (include) |
| Public (visible to everyone): | Yes |
| Archived (hidden from active list): | No |
| Created/modified: | 2022-08-12 03:58:13 |
| Source code size: | 1238 bytes / 44 lines |
| Pitched / IR pitched: | No / No |
| Views / Downloads: | 477 / 756 |
| Version history: | 11 change(s) |
| Referenced in: | [show references] |