4 Keys to Building Generic Solutions in Code
Building and maintaining a library of custom code procedures is an investment that provides compounding benefits over time.
data:image/s3,"s3://crabby-images/96d5b/96d5b59c7aea277f1095b899828f6867c73c4ac0" alt="4 Keys to Building Generic Solutions in Code"
There are a few keys to ensure you are investing your time wisely:
- Avoid premature generalization by sticking to the Rule of Thrice
- Make sure any additional time spent building a generic solution is worth it
- Build only what you need at first; don't try to anticipate future use cases
- Maintain backward compatibility as you add features
Rule of Thrice
The Rule of Thrice goes like this,
Once is a fluke. Twice is a coincidence. Thrice is a pattern.
To follow the Rule of Thrice, you don't spend any time generalizing a solution until the problem has appeared at least three times.
data:image/s3,"s3://crabby-images/b3956/b395689c17324514bb541c03a9cac507aabcb1a5" alt=""
Invest Your Time Wisely
How often will the situation come up? How much time will the generic solution save? How much additional time will it take you to build a generic solution versus the solution you have to build anyway?
Once you have those three values, use this handy chart from XKCD.com to decide whether a generic solution is worth doing:
data:image/s3,"s3://crabby-images/66bd6/66bd6122d7e9e97a7d42bd446c7c7f824251cbb6" alt=""
Just-In-Time Development
Add features to your generic solution only as you need them.
Don't try to anticipate future use cases; you'll likely guess wrong. Instead, add new features only when the need arises. This has several benefits:
- Initial development will be faster
- You'll avoid creating (and having to maintain) unused features
- You'll have real-world situations to guide your development
Maintain Backward Compatibility
When you do add features to your solution, make sure you add them in a backward-compatible way. There are several techniques you can use to do that:
- Add optional parameters to generic procedures
- Add methods or properties to a generic class
- For major refactoring, create interfaces that act as a middleman to an existing class
data:image/s3,"s3://crabby-images/2c2ba/2c2baa483697928270fd1776a495be8c2987fbc7" alt=""
data:image/s3,"s3://crabby-images/c7638/c763898d86de27d3cb8dfab09a03f455adbb0002" alt=""
Cover image created with Microsoft Designer