Mark As Completed Discussion

Before discussing the difference between mutable and immutable objects, it's important that we properly define what an Object is in Object-Oriented Programming (OOP). This will serve as one of the foundations/basic concepts to fully understand the topic.

So to start, an Object is a piece of data that contains its own:

  1. identity (unique name),
  2. states (characteristics or attributes) and,
  3. behaviors (methods).
Introduction

For example, assume that we are going to adopt a dog (or a cat!). After adoption, we would give that dog a name to call it (to uniquely identify it-- especially when we take it outside for a walk). Our dog has different attributes, including but not limited to, breed, color, and age. Finally, the dog may perform several functions like eating, sleeping, and barking.

Let’s have a look at another example of an object:

Introduction

The above figure illustrates a house having a unique house number plate. It also has certain features like roofColor and doorColor, along with certain functions like the doorOpens and doorShuts.

To extend our understanding, it's also crucial that we understand that an object is a specific "realization" of a class. You can describe a class as a logical entity which is responsible for creating individual objects. You may create multiple objects from a single class-- but it's imperative that a class always comes first whenever an object has to be created. It is a blueprint of sorts. Therefore, an object can also be defined as an instance of a class.

Keeping the above discussion in mind, let’s dive into the details of mutable and immutable objects.

Mutable Object and Immutable Object:

An object whose states and behaviors can be changed after its creation is called a mutable object.

On the other hand, an immutable object’s states and behaviors can never be changed once it is created. The idea behind creating an immutable object is to maintain its states and behaviors throughout the course of execution of the program. It's like a shield is there which keeps you from accessing these objects.

Mutable Object And Immutable Object

Consider the following piece of Java code to understand the basic differences between mutable and immutable objects. Since our objective is to gain understanding, we will keep our example simple.

We start with a Person class, which contains certain pieces of information about a person. It has the age attribute, a constructor that returns the name, and the methods to set and get the age of a person.

1package main
2
3import "fmt"
4
5type Person struct {
6	p_age int
7}
8
9func (p *Person) Person(name string) {
10	fmt.Println("Name of person is :", name)
11}
12
13func (p *Person) setAge(age int) {
14	p.p_age = age
15}
16
17func (p *Person) getAge() int {
18	fmt.Println("Age of person is :", p.p_age)
19	return p.p_age
20}
21
22func main() {
23	// Object creation
24	var myPerson Person
25	myPerson.Person("Arslan")
26
27	myPerson.setAge(25)
28
29	myPerson.getAge()
30}

On executing it, we get the following output:

Mutable Object And Immutable Object

Let's say we want to make this object immutable. Sadly, we can't accomplish this by simply adding a single keyword. First, we have to create an immutable class that must include specific keywords, include certain modifiers, and must exercise restraint in the code. A simple way of enforcing this constraint would be to not provide setters for your methods to avoid any change. Let's see how to make an immutable class.

How do we create an immutable class?

In order to make a class immutable,

  • our class must be declared as final. This will restrict other classes from inheriting our class and it is one of the most secure (and simplest) ways of making sure that our class can never be extended.

  • every attribute (data member) should be declared as private and final. Making an attribute final will ensure that it can never be reassigned from within the class. On the other hand, the keyword private will ensure that the attributes will not be accessed directly from outside the class. However, it is imperative to address this part in a bit of detail.

    We can even make our class immutable by declaring the attributes as public and final. Then why declare them as private? There are various reasons. The most important one is to ensure encapsulation. Doing so will reduce the unwanted risk of cross-coupling and it will restrict us from writing code that may depend on the immutable class.

  • provide getters but never provide setters so that the object’s states cannot be changed.

The main idea behind following all of the above-mentioned practices is to restrict your users from changing the states and behaviors of the object. As a result, the instances of immutable classes are unchangeable once they are created. Therefore, immutable objects, after instantiation, become read-only forever.

Let's test your knowledge. Fill in the missing part by typing it in.

Immutable classes have __ methods but not __ methods.

( Please provide your answer as comma separated strings )

Write the missing line below.

Try this exercise. Click the correct answer from the options.

A beginner Java programmer created an immutable object, but it is not functioning correctly. What is wrong with their code? (Choose from options below)

SNIPPET
1public class Car {
2private final String model;
3private String registrationNum;
4
5Car (final String model) {
6    this.model = model;
7}
8
9public final String printModel() {
10    System.out.println(this.model);
11}

Click the option that best answers the question.

  • Missing `final` keyword in class name
  • Some data members not declared as `final`
  • Missing `set` method
  • All of the above

How can we change Immutable Objects?

If you're required to update an immutable object, there really isn't a workaround. You first have to clone that object, and then modify that cloned object in order for it to reflect your changes. Otherwise, there is no way that you can directly manipulate the immutable object.

Advantages of Immutability Objects:

  • Immutables are very useful in concurrent programming to ensure thread-safety (where an object is shared by multiple threads at a single time). You can freely share your immutable objects with various threads, without having to worry about any sort of inconsistency.

  • Immutables are very important in cases where we deal with key-value pairs which never change. For example, consider maps. We locate everything on maps using coordinates (longitude and latitudes) which always remain the same, making immutable objects as the best option here.

  • They are really useful in ATM machine-like systems where if a system failure occurs before the completion of the transaction, the user may face critical loss. With an immutable class, your account balance will only change once you have received the cash from the ATM. Otherwise, you may throw an error message and prevent losing that amount.

Let's test your knowledge. Click the correct answer from the options.

Which of the following is a default immutable class provided by Java?

Click the option that best answers the question.

  • String
  • Long
  • Byte
  • None of the above
  • All of the above

Which is better?

Both of these concepts have their own benefits. Redux is used in React for state management of the application, and it heavily incorporates this concept of immutability to facilitate the data handling. Mutable objects allow you to make changes without having to create another copy, thus saving the memory that would have been allocated to the newly created object.

Build your intuition. Fill in the missing part by typing it in.

The following code block shows a/an ___ object.

SNIPPET
1public final class myClass {
2private final String name;
3
4myClass (final String name) {
5    this.name = name;
6}
7
8public final String getName() {
9    return name;
10}
11
12public static void main(String[] args) {
13    myClass myName = new myClass("Jake");
14    System.out.println(obj.getName());
15}

Write the missing line below.

One Pager Cheat Sheet

  • We must start by understanding Objects, which are pieces of data that have unique identities, states, and behaviors, to properly discuss the difference between mutable and immutable objects.
  • An immutable object's states and behaviors cannot be changed once it is created, while a mutable object's states and behaviors can be changed after its creation.
  • Instances of immutable classes are unchangeable once they are created due to their restricted access and lack of set methods.
  • The constructor has an unassigned final variable and the printModel() method should be public and return the model String.
  • We have to clone the immutable object, and modify it, as there is no way to directly manipulate it.
  • Immutable objects are useful for concurrent programming, mapping, and critical systems, providing consistency and safety.
  • Java provides default immutable classes, such as String, Boolean, and Integer, which are useful for ensuring that their values remain unaltered in complex programming scenarios.
  • Both Redux and mutable objects offer benefits and are used for different purposes, with Redux leveraging the concept of immutability to manage state and mutable objects allowing changes to be made without having to create a new copy.
  • The class myClass is immutable - its values are set during its initialization and cannot be modified afterwards.