cover-img

Code Smell 49 - Caches

Caches are sexy. They are a one-night stand. We need to avoid them in a long-term relationship.

6 February, 2023

2

2

0

Caches are sexy. They are a one-night stand. We need to avoid them in a long-term relationship.

Problems

  • Coupling
  • Testability
  • Cache invalidation.
  • Maintainability
  • Premature Optimization
  • Erratic Behavior
  • Lack of transparency
  • Non-Deterministic behavior

Solutions

  1. If you have a conclusive benchmark and are willing to pay for some coupling: Put an object in the middle.
  1. Unit test all your invalidation scenarios. Experience shows we face them in an incremental way.
  1. Look for a real-world cache metaphor and model it.

Sample Code

Wrong

[Gist Url]: # (https://gist.github.com/mcsee/c429e71f6b0239b83e7e307feb5927fe)

<?

final class Book {

private $cachedBooks;

public function getBooksFromDatabaseByTitle(string $title) {

if (isset($cachedBooks[$title])) {
return $cachedBooks[$title];
} else {
return $this->doGetBooksFromDatabaseByTitle($title);
}
}

private function doGetBooksFromDatabaseByTitle(string $title) {
globalDatabase()->selectFrom('Books', 'WHERE TITLE = ' . $title);
}
}

Right

<?

final class Book {
// Just Book related Stuff
}

interface BookRetriever {
public function bookByTitle(string $title);
}

final class DatabaseLibrarian implements BookRetriever {
public function bookByTitle(string $title) {
// Go to the database (not global hopefully)
}
}

final class HotSpotLibrarian implements BookRetriever {
// We always look for real life metaphors
private $inbox;
private $realRetriever;

public function bookByTitle(string $title) {
if ($this->inbox->includesTitle($title)) {
// We are lucky. Someone has just returned the book copy.
return $this->inbox->retrieveAndRemove($title);
} else {
return $this->realRetriever->bookByTitle($title);
}
}
}

Detection

This is a design smell.

It will be difficult to enforce by policy.

Tags

  • Premature Optimization

Conclusion

Caches should be functional and intelligent

In this way we can manage invalidation.

General purpose caches are suitable only for low level objects like operating systems, files and streams.

We shouldn't cache domain objects.

This page is hosted on a cached website.

Relations

Code Smell 20 - Premature Optimization

More Info

https://dev.vamsirao.com/what-is-cache-and-common-ways-of-using-it

https://frankel.hashnode.dev/a-hitchhikers-guide-to-caching-patterns

Credits

Photo by Aimee Vogelsang on Unsplash

There are only two hard things in Computer Science: cache invalidation and naming things.

Phil Karlton

Software Engineering Great Quotes

This article is part of the CodeSmell Series.

How to Find the Stinky Parts of your Code

2

2

0

Maxi Contieri

Buenos Aires, Argentina

🎓Learn something new every day.📆 💻CS software engineer 👷coding👨🏽‍🏫teaching ✍🏾writing 🎨Software Design 🏢SOLID 🌉TDD 👴Legacy 💩Code Smells

More Articles

Showwcase is a professional tech network with over 0 users from over 150 countries. We assist tech professionals in showcasing their unique skills through dedicated profiles and connect them with top global companies for career opportunities.

© Copyright 2025. Showcase Creators Inc. All rights reserved.