programming

All About High Cohesion

In the realm of software development, the concept of cohesion plays a pivotal role in creating code that is not only functional but also maintainable and scalable. In this article, we will delve into the significance of cohesion in TypeScript.

What is Cohesion?

Cohesion refers to the degree to which the elements within a module, class, or component are related to each other. In simpler terms, it measures how closely the various parts of a software unit work together to achieve a common goal. High cohesion implies that the code within a module is focused and has a single, well-defined responsibility.

Types of Cohesion

Functional Cohesion

This type of cohesion occurs when the elements within a module are grouped together because they all contribute to a single, specific task or functionality. This is often considered the most desirable form of cohesion.

// Example of Functional Cohesion
class ShoppingCart {
  private items: CartItem[] = [];

  addItem(item: CartItem): void {
    this.items.push(item);
  }

  calculateTotal(): number {
    return this.items.reduce((total, item) => total + item.price, 0);
  }
}

Sequential Cohesion

Elements within a module are grouped together because they are executed in a specific sequence. This form of cohesion is common but should be used cautiously to avoid creating overly complex and tightly coupled code.

// Example of Sequential Cohesion
class OrderProcessor {
  processOrder(order: Order): void {
    this.validateOrder(order);
    this.calculateTotal(order);
    this.createInvoice(order);
  }

  private validateOrder(order: Order): void {
    // Validate the order
  }

  private calculateTotal(order: Order): void {
    // Calculate the total
  }

  private createInvoice(order: Order): void {
    // Create the invoice
  }
}

Communicational Cohesion

Elements within a module are grouped together because they operate on the same input data or produce similar output. This form of cohesion is more flexible than sequential cohesion but still requires careful consideration.

// Example of Communicational Cohesion
class EmailService {
  sendOrderConfirmation(order: Order): void {
    // Send order confirmation email
  }

  sendShippingNotification(order: Order): void {
    // Send shipping notification email
  }
}

Procedural Cohesion

Elements within a module are grouped together because they are part of a common procedural step. While this type of cohesion is better than no cohesion, it may lead to less maintainable code.

// Example of Procedural Cohesion
class AuthenticationModule {
  authenticateUser(credentials: Credentials): void {
    // Authenticate the user
    this.logAuthenticationAttempt(credentials);
    this.updateUserActivityLog(credentials.userId);
  }

  private logAuthenticationAttempt(credentials: Credentials): void {
    // Log authentication attempt
  }

  private updateUserActivityLog(userId: string): void {
    // Update user activity log
  }
}

Benefits of High Cohesion in TypeScript

Maintainability

Code with high cohesion is easier to understand and maintain since each module has a clear and specific purpose.

Reusability

Well-cohesive modules can be reused in different parts of an application or even in other projects, promoting a more efficient development process.

Scalability

High cohesion supports the scalability of a codebase, allowing developers to add new features or make changes without affecting unrelated parts of the code.

Readability

Code readability is enhanced when each module has a focused responsibility, making it easier for developers to comprehend and contribute to the codebase.

Strategies for Achieving High Cohesion

Single Responsibility Principle (SRP)

Ensure that each class or module has only one reason to change. This principle, advocated by SOLID principles, helps in achieving high cohesion.

Separation of Concerns (SoC)

Divide your application into distinct sections, with each section addressing a specific concern. This aids in maintaining a clear and cohesive structure.

Abstraction

Use abstraction to encapsulate complex functionality into well-defined and focused interfaces or classes, promoting modular and cohesive design.

Conclusion

Understanding and implementing cohesion in TypeScript is crucial for developing code that is not only functional but also maintainable and scalable. By adhering to principles such as SRP and SoC, and employing strategies like abstraction, developers can ensure that their TypeScript codebases exhibit high cohesion, leading to more robust and adaptable applications. In the ever-evolving landscape of software development, cohesion remains a cornerstone for building resilient and efficient systems.

Author avatar
About Authorpolubis

👋 Hi there! My name is Adrian, and I've been programming for almost 7 years 💻. I love TDD, monorepo, AI, design patterns, architectural patterns, and all aspects related to creating modern and scalable solutions 🧠.