Do you start reading code?

Last updated by Chloe Lin [SSW] over 1 year ago.See history

Great code isn't just about making computers do stuff; it's about making sure humans can understand and work with it too. Good code is like a well-written story - it's clear, easy to read, and everything has a name that makes sense. There's no unnecessary stuff thrown in, and it's all neatly organized. It's not just a set of instructions; it's a roadmap that explains not only "how" things work but also "why" they work that way when you read through it.

“Aim for simplicity. I want to code to read like poetry”*

  • Terje Sandstrom

Good code characteristics

  • Is clear and easy to read
  • Has consistent and meaningful names for everything
  • Has no repeated or redundant code
  • Has neat formatting
  • Explains "why" when you read down, and "how" when you read left to right
public IEnumerable<Customer> GetSupplierCustomersWithMoreThanZeroOrders(int supplierId) {
    var supplier = repository.Suppliers.Single(s => s.Id == supplierId);

    if (supplier == null) {
        return Enumerable.Empty<Customer>();
    }

    var customers = supplier.Customers
        .Where(c => c.Orders > 0);

    return customers;
}

Figure: This code explains what it is doing as you read left to right, and why it is doing it when you read top to bottom

Tip: Read the book Clean Code: A Handbook of Agile Software Craftsmanship by Robert. C. Martin.

Good code is declarative

For example, I want to show all the products where the unit price less than 20, and also how many products are in each category.

Dictionary<string, ProductGroup> groups = new Dictionary<string, ProductGroup>();

foreach (var product in products) {
    if (product.UnitPrice >= 20)
    {
        if (!groups.ContainsKey(product.CategoryName))
        {
            ProductGroup productGroup = new ProductGroup();
            productGroup.CategoryName = product.CategoryName;
            productGroup.ProductCount = 0;
            groups[product.CategoryName] = productgroup;
        }
        groups[p.CategoryName].ProductCount++;
    }
}

var result = new List<ProductGroup>(groups.Values);

result.Sort(delegate(ProductGroup groupX, ProductGroup groupY) {
    return
        groupX.ProductCount > groupY.ProductCount ? -1 :
        groupX.ProductCount < groupY.ProductCount ? 1 :
        0;
});

Figure: Bad example - Not using LINQ

Tip: Resharper can automatically convert this code.

result = products
    .Where(product => product.UnitPrice >= 20)
    .GroupBy(product => product.CategoryName)
    .OrderByDescending(group => group.Count())
    .Select(group => new { CategoryName = group.Key, ProductCount = group.Count() });

Figure: Good example - using LINQ

Tip: For more information on why declarative programming (aka LINQ, SQL, HTML) is great, watch the TechDays 2010 Keynote by Anders Hejlsberg.Anders explains why it's better to have code "tell what, not how".

Clean HTML

Anyone who creates their own HTML pages today should aim to make their markup semantically correct. For more information on semantic markup, see HTML Semantic Elements.

For example, <p> is for a paragraph, not for defining a section.

Clean Front-End code

Clean code and consistent coding standards are not just for server-side code. It is important that you apply your coding standards to your front-end code as well e.g. JavaScript, TypeScript, React, Angular, Vue, CSS, etc.

You should use a linter and code formatter like Prettier to make development easier and more consistent.

Adam Cogan
Adam Stephensen
Damian Brady
We open source.Loving SSW Rules? Star us on GitHub. Star
Stand by... we're migrating this site to TinaCMS