Commit 711cfb3
committed
fix: return new BitList instance from emptyList() to prevent shared mutable state
BitList.emptyList() previously returned a shared static singleton instance.
Since BitList is mutable, modifications to one caller's "empty" list would
contaminate all other callers. This caused cross-interface invoker leakage
in AbstractDirectory, leading to NoSuchMethodError when traffic was routed
to instances of a previous interface.
The fix returns a new BitList instance on each call, consistent with how
mutable collections should behave.
Fixes #161311 parent 63fe8c3 commit 711cfb3
2 files changed
Lines changed: 49 additions & 3 deletions
File tree
- dubbo-cluster/src
- main/java/org/apache/dubbo/rpc/cluster/router/state
- test/java/org/apache/dubbo/rpc/cluster/router/state
Lines changed: 1 addition & 3 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
55 | 55 | | |
56 | 56 | | |
57 | 57 | | |
58 | | - | |
59 | 58 | | |
60 | 59 | | |
61 | 60 | | |
| |||
174 | 173 | | |
175 | 174 | | |
176 | 175 | | |
177 | | - | |
178 | 176 | | |
179 | | - | |
| 177 | + | |
180 | 178 | | |
181 | 179 | | |
182 | 180 | | |
| |||
Lines changed: 48 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
579 | 579 | | |
580 | 580 | | |
581 | 581 | | |
| 582 | + | |
| 583 | + | |
| 584 | + | |
| 585 | + | |
| 586 | + | |
| 587 | + | |
| 588 | + | |
| 589 | + | |
| 590 | + | |
| 591 | + | |
| 592 | + | |
| 593 | + | |
| 594 | + | |
| 595 | + | |
| 596 | + | |
| 597 | + | |
| 598 | + | |
| 599 | + | |
| 600 | + | |
| 601 | + | |
| 602 | + | |
| 603 | + | |
| 604 | + | |
| 605 | + | |
| 606 | + | |
| 607 | + | |
| 608 | + | |
| 609 | + | |
| 610 | + | |
| 611 | + | |
| 612 | + | |
| 613 | + | |
| 614 | + | |
| 615 | + | |
| 616 | + | |
| 617 | + | |
| 618 | + | |
| 619 | + | |
| 620 | + | |
| 621 | + | |
| 622 | + | |
| 623 | + | |
| 624 | + | |
| 625 | + | |
| 626 | + | |
| 627 | + | |
| 628 | + | |
| 629 | + | |
582 | 630 | | |
583 | 631 | | |
584 | 632 | | |
| |||
0 commit comments