Skip to content

synchronize missing mutators in SynchronizedDescriptiveStatistics#327

Open
dxbjavid wants to merge 1 commit into
apache:masterfrom
dxbjavid:sync-descriptivestats-mutators
Open

synchronize missing mutators in SynchronizedDescriptiveStatistics#327
dxbjavid wants to merge 1 commit into
apache:masterfrom
dxbjavid:sync-descriptivestats-mutators

Conversation

@dxbjavid

@dxbjavid dxbjavid commented Jul 1, 2026

Copy link
Copy Markdown
Contributor

SynchronizedDescriptiveStatistics promises that every state-touching method is atomic on the instance, but removeMostRecentValue and replaceMostRecentValue are not overridden, so they mutate the shared backing array with no lock held. A thread calling either of them while another thread is inside a synchronised method like addValue or clear can therefore corrupt the underlying ResizableDoubleArray or trip an ArrayIndexOutOfBoundsException. I have overridden both to delegate under the instance monitor as the sibling mutators already do, and added a test that the calls block while the lock is held (it fails on master).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant