Defensive programming

Defensive programming is a pessimistic approach to software development that assumes the worst-case scenario in every situation. It involves writing code that can handle invalid, unexpected, or malicious inputs, and prevents errors from cascading through the system, much like how Facebook's "move fast and break things" motto led to a bunch of privacy scandals and congressional hearings.

How to use it in a sentence

  • "I know you want to ship this feature quickly, but we need to do some defensive programming to make sure our app doesn't end up on the front page of Hacker News for all the wrong reasons."

  • "Sure, we could trust that the API will always return valid JSON, but let's add some defensive programming just in case, so we don't end up like that IoT pet feeder that starved thousands of cats when their server went down."

If you actually want to learn more...

  • The Basics of Web Application Security - This article highlights the importance of security in modern web development and emphasizes basic practices that every developer should follow, like using defensive programming techniques to validate inputs and prevent injection attacks.

  • Improve Your Programming Skills - This blog post offers practical advice for becoming a more effective software engineer, including studying code written by top engineers at your company to understand their defensive programming techniques and design decisions.

  • A Guide to Threat Modelling for Developers - This guide provides simple steps for adopting threat modeling, a risk-based approach to designing secure systems that goes hand-in-hand with defensive programming practices.

Note: the Developer Dictionary is in Beta. Please direct feedback to skye@statsig.com.

Join the #1 experimentation community

Connect with like-minded product leaders, data scientists, and engineers to share the latest in product experimentation.

Try Statsig Today

Get started for free. Add your whole team!

Why the best build with us

OpenAI OpenAI
Brex Brex
Notion Notion
SoundCloud SoundCloud
Ancestry Ancestry
At OpenAI, we want to iterate as fast as possible. Statsig enables us to grow, scale, and learn efficiently. Integrating experimentation with product analytics and feature flagging has been crucial for quickly understanding and addressing our users' top priorities.
OpenAI
Dave Cummings
Engineering Manager, ChatGPT
Brex's mission is to help businesses move fast. Statsig is now helping our engineers move fast. It has been a game changer to automate the manual lift typical to running experiments and has helped product teams ship the right features to their users quickly.
Brex
Karandeep Anand
President
At Notion, we're continuously learning what our users value and want every team to run experiments to learn more. It’s also critical to maintain speed as a habit. Statsig's experimentation platform enables both this speed and learning for us.
Notion
Mengying Li
Data Science Manager
We evaluated Optimizely, LaunchDarkly, Split, and Eppo, but ultimately selected Statsig due to its comprehensive end-to-end integration. We wanted a complete solution rather than a partial one, including everything from the stats engine to data ingestion.
SoundCloud
Don Browning
SVP, Data & Platform Engineering
We only had so many analysts. Statsig provided the necessary tools to remove the bottleneck. I know that we are able to impact our key business metrics in a positive way with Statsig. We are definitely heading in the right direction with Statsig.
Ancestry
Partha Sarathi
Director of Engineering
We use cookies to ensure you get the best experience on our website.
Privacy Policy