Skip to Content
Clean Code Cookbook
book

Clean Code Cookbook

by Maximiliano Contieri
September 2023
Intermediate to advanced
430 pages
8h 6m
English
O'Reilly Media, Inc.
Book available
Content preview from Clean Code Cookbook

Chapter 18. Globals

Write shy code—modules that don’t reveal anything unnecessary to other modules and that don’t rely on other modules’ implementations.

David Thomas and Andrew Hunt, The Pragmatic Programmer: Your Journey to Mastery

18.0 Introduction

Most modern languages support global functions, classes, and attributes. There’s a hidden cost when you use any of these artifacts. Even when you are creating an object using new(), you will introduce a tight coupling to a global class unless you apply some of the following recipes.

18.1 Reifying Global Functions

Problem

You have global functions that you can call from anywhere. 

Solution

Global functions bring a lot of coupling. Narrow their scope.

Discussion

Discouraged by object-oriented programming, many mixed languages support global functions. They create coupling and hurt readability since they are difficult to trace. As coupling grows, maintainability and testability become more problematic. You can start by wrapping the function in a context object. For example, you can find external resource access, database access, singletons (see Recipe 17.2, “Replacing Singletons”), global classes, time, and operating system resources.

This example calls a method from a global database:

class Employee {
    function taxesPayedUntilToday() {
        return database()->select(
            "SELECT TAXES FROM EMPLOYEE".
            " WHERE ID = " . $this->id() .
            " AND DATE < " . currentDate());
    }
}

By making persistence contextual, you can decouple the database ...

Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Start your free trial

You might also like

GitOps Cookbook

GitOps Cookbook

Natale Vinto, Alex Soto Bueno
Data-Oriented Programming

Data-Oriented Programming

Yehonathan Sharvit

Publisher Resources

ISBN: 9781098144715Errata PageSupplemental Content