-
Notifications
You must be signed in to change notification settings - Fork 1.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Simplify the API between factories and construction contexts by movin…
…g more logic into InternalContext. Instead of having factories manage a `ConstructionContext` object and call some subset of methods on it, we simplify things into a number of abstract operations on `InternalContext` - `tryStartConstruction`: called when we are starting construction - This is amortized O(1) work and only allocates when we are resizing the internal hash tables. - `finishConstruction`: called when construction is complete, clears the table - This is amortized O(1) work due to the hash search and some datastructure maintenance - `finishConstructionAndSetReference`: called by `ConstructorInjector` to support member injectors calling back into it - `clearCurrentReference`: called by `ConstructorInjector` after member injection is complete. This enables the following optimizations * When `disableCircularProxies` is set can get away with a single `int[]` to track the set of currently constructing factories and turn `finishConstructionAndSetReference` into a no-op * When circular proxies are enabled we can eliminate the `ConstructionContext` object and only allocate when we actually construct a proxy. * We can 'statically' allocate each factory a unique non-zero integer (a `circularFactoryId`). This allows us to create a open-addressed hashtable with integer keys that reduces allocation, hashing and GC overhead. - this does limit us to 2^32-1 circular factories before we get collisions, but that should be enough! pretty sure that other things will fail first. * The new `InternalContext` protocol enables some simplifications in the factories which allows to delete an implementation Previously we would insert `ConstructionContext` objects into the hash table and reuse them if the same factory was used multiple times. This was generally rare, and now we instead remove keys from the table after construction. In theory this means we always perform 2 hash table lookups per construction where the prior approach might only do one. This is true but in general all lookups missed so the prior approach also required 2 lookups (`get` and `put`). This is an optimization all on its own, but the new simpler protocol will enable more optimizations in a followup. PiperOrigin-RevId: 713781971
- Loading branch information
1 parent
dabffd4
commit 38005e0
Showing
22 changed files
with
976 additions
and
344 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
91 changes: 0 additions & 91 deletions
91
core/src/com/google/inject/internal/ConstructionContext.java
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.