Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix side effect of Remove operation. #2961

Merged
merged 1 commit into from
Dec 14, 2023
Merged

Fix side effect of Remove operation. #2961

merged 1 commit into from
Dec 14, 2023

Conversation

skypexu
Copy link
Member

@skypexu skypexu commented Dec 13, 2023

In the original ARC paper, there was no explanation of how Remove should be handled when the cache is full. The Remove operation would have a side effect on subsequent Put operations when the cache is not full, which is still evicting items even though it's clear that there is no need to evict when the cache is not full.

Now, code has been added to check if the cache is full to avoid performance degradation.

Also fix c_, it should be max_count.
Also add unittest.

What problem does this PR solve?

Issue Number: #2962

Problem Summary:

What is changed and how it works?

What's Changed:

How it Works:

Side effects(Breaking backward compatibility? Performance regression?):

Check List

  • Relevant documentation/comments is changed or added
  • I acknowledge that all my contributions will be made under the project's license

@wuhongsong
Copy link
Contributor

cicheck

1 similar comment
@skypexu
Copy link
Member Author

skypexu commented Dec 14, 2023

cicheck

In the original ARC paper, there was no explanation of how Remove should be
handled when the cache is full. The Remove operation would have a side effect
on subsequent Put operations when the cache is not full, which is still
evicting items even though it's clear that there is no need to evict when
the cache is not full.

Now, code has been added to check if the cache is full to avoid performance
degradation.

- fix c_, it should be max_count.
- add unittest.
- use list::splice to avoid copying value
- add suffix to member fields list and map

Signed-off-by: Xu Yifeng <bsddiy2@163.com>
@skypexu
Copy link
Member Author

skypexu commented Dec 14, 2023

cicheck

1 similar comment
@skypexu
Copy link
Member Author

skypexu commented Dec 14, 2023

cicheck

@wuhongsong wuhongsong merged commit 0c24f4f into opencurve:master Dec 14, 2023
2 checks passed
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.

3 participants