Compare commits
4 commits
dfdd65cd27
...
cf6e1b8d14
Author | SHA1 | Date | |
---|---|---|---|
Bruno BELANYI | cf6e1b8d14 | ||
Bruno BELANYI | 3e416d0a39 | ||
Bruno BELANYI | 28e886ecd3 | ||
Bruno BELANYI | 8a8de126c1 |
|
@ -16,7 +16,7 @@ favorite: false
|
|||
The flyweight is a well-known
|
||||
[GoF](https://en.wikipedia.org/wiki/Design_Patterns) design pattern.
|
||||
|
||||
It's intent is to minimize memory usage by reducing the number of instantiations
|
||||
Its intent is to minimize memory usage by reducing the number of instantiations
|
||||
of a given object.
|
||||
|
||||
I will show you how to implement a robust flyweight in C++, as well as a way to
|
||||
|
|
|
@ -68,7 +68,7 @@ public:
|
|||
const std::type_index lhs_i(lhs);
|
||||
const std::type_index rhs_i(rhs);
|
||||
if (lhs_i != rhs_i)
|
||||
returh lhs_i < rhs_i;
|
||||
return lhs_i < rhs_i;
|
||||
// We are now assured that both classes have the same type
|
||||
return less_than(rhs);
|
||||
}
|
||||
|
|
|
@ -94,7 +94,7 @@ def find(self, elem: int) -> int:
|
|||
|
||||
However, going back up the chain of parents each time we want to find the root
|
||||
node (an `O(n)` operation) would make for disastrous performance. Instead we can
|
||||
do a small optimization called _path splitting.
|
||||
do a small optimization called _path splitting_.
|
||||
|
||||
```python
|
||||
def find(self, elem: int) -> int:
|
||||
|
|
|
@ -1 +1 @@
|
|||
Subproject commit 5da913dc46d2dadcaf6548256238c58c504476de
|
||||
Subproject commit d545effed9949bf834eaed09ad423ec3e030794f
|
Loading…
Reference in a new issue