Bird
Raised Fist0
C Sharp (C#)programming~5 mins

Init-only setters in C Sharp (C#) - Time & Space Complexity

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Time Complexity: Init-only setters
O(n)
Understanding Time Complexity

Let's explore how the time it takes to set properties using init-only setters changes as we create more objects.

We want to know how the cost grows when initializing many objects with these setters.

Scenario Under Consideration

Analyze the time complexity of the following code snippet.

public record Person
{
    public string Name { get; init; }
    public int Age { get; init; }
}

var people = new List();
for (int i = 0; i < n; i++)
{
    people.Add(new Person { Name = $"Person{i}", Age = i });
}

This code creates a list of Person objects, each initialized with a name and age using init-only setters.

Identify Repeating Operations

Identify the loops, recursion, array traversals that repeat.

  • Primary operation: Creating and initializing a Person object inside a loop.
  • How many times: The loop runs n times, once for each Person created.
How Execution Grows With Input

Each new object requires a fixed amount of work to set its properties.

Input Size (n)Approx. Operations
10About 10 object creations and initializations
100About 100 object creations and initializations
1000About 1000 object creations and initializations

Pattern observation: The work grows directly with the number of objects created.

Final Time Complexity

Time Complexity: O(n)

This means the time to initialize all objects grows linearly as you create more objects.

Common Mistake

[X] Wrong: "Init-only setters make object creation instant regardless of how many objects."

[OK] Correct: Each object still needs its properties set one by one, so more objects mean more work.

Interview Connect

Understanding how object initialization scales helps you write efficient code and explain your reasoning clearly in interviews.

Self-Check

"What if we replaced the init-only setters with regular setters and modified properties after creation? How would the time complexity change?"

Practice

(1/5)
1. What is the main purpose of init-only setters in C#?
easy
A. To prevent object creation
B. To allow setting properties only during object creation
C. To make methods run faster
D. To allow properties to be changed anytime

Solution

  1. Step 1: Understand init-only setters

    Init-only setters allow properties to be set only when the object is created, not after.
  2. Step 2: Compare options

    Only To allow setting properties only during object creation correctly describes this behavior; others are unrelated or incorrect.
  3. Final Answer:

    To allow setting properties only during object creation -> Option B
  4. Quick Check:

    Init-only setters = set only at creation [OK]
Hint: Init-only means set once during creation only [OK]
Common Mistakes:
  • Thinking init-only allows changes anytime
  • Confusing init-only with readonly fields
  • Assuming init-only affects methods
2. Which of the following is the correct syntax to declare an init-only property in C#?
easy
A. public string Name { get; init; }
B. public string Name { get; set; }
C. public string Name { get; readonly; }
D. public string Name { get; private set; }

Solution

  1. Step 1: Recall init-only syntax

    Init-only properties use init instead of set to allow setting only during initialization.
  2. Step 2: Check options

    public string Name { get; init; } uses { get; init; }, which is correct syntax. Others use set, readonly (invalid here), or private set.
  3. Final Answer:

    public string Name { get; init; } -> Option A
  4. Quick Check:

    Init-only syntax = get + init [OK]
Hint: Init-only uses 'init' keyword, not 'set' [OK]
Common Mistakes:
  • Using 'set' instead of 'init'
  • Trying to use 'readonly' in property accessor
  • Confusing 'private set' with init-only
3. What will happen when you run this code?
public class Person {
    public string Name { get; init; }
}

var p = new Person { Name = "Alice" };
p.Name = "Bob";
Console.WriteLine(p.Name);
medium
A. Prints 'Alice'
B. Runtime exception
C. Prints 'Bob'
D. Compile-time error

Solution

  1. Step 1: Understand init-only property behavior

    The property Name can only be set during object initialization (inside the braces). Setting it later causes a compile error.
  2. Step 2: Analyze the code

    After creating p with Name = "Alice", the code tries to assign p.Name = "Bob" outside initialization, which is invalid.
  3. Final Answer:

    Compile-time error -> Option D
  4. Quick Check:

    Changing init-only after creation = compile error [OK]
Hint: Init-only properties can't be changed after creation [OK]
Common Mistakes:
  • Assuming property can be changed anytime
  • Expecting runtime error instead of compile error
  • Confusing init-only with readonly fields
4. Identify the error in this code snippet:
public class Car {
    public string Model { get; init; }
}

var car = new Car();
car.Model = "Sedan";
medium
A. Missing constructor call
B. Property Model must have a setter, not init
C. Cannot assign init-only property outside object initializer
D. No error, code is correct

Solution

  1. Step 1: Check how init-only properties are set

    Init-only properties must be set during object creation using an initializer, not after.
  2. Step 2: Analyze the code

    The code creates car with default constructor, then tries to set Model property outside initialization, which is invalid.
  3. Final Answer:

    Cannot assign init-only property outside object initializer -> Option C
  4. Quick Check:

    Init-only set only in initializer, not later [OK]
Hint: Set init-only properties inside braces only [OK]
Common Mistakes:
  • Trying to set init-only property after creation
  • Thinking init-only means readonly
  • Ignoring object initializer syntax
5. Given this record declaration:
public record Book {
    public string Title { get; init; }
    public string Author { get; init; }
}

var book1 = new Book { Title = "C# Guide", Author = "Jane" };
var book2 = book1 with { Author = "John" };

Console.WriteLine(book2.Title + ", " + book2.Author);

What is the output?
hard
A. C# Guide, John
B. C# Guide, Jane
C. Compile-time error due to init-only setter
D. Runtime exception

Solution

  1. Step 1: Understand 'with' expression on records

    The 'with' expression creates a copy of book1 but allows changing init-only properties during creation of the new object.
  2. Step 2: Analyze the output

    book2 copies Title as "C# Guide" and sets Author to "John". Printing shows "C# Guide, John".
  3. Final Answer:

    C# Guide, John -> Option A
  4. Quick Check:

    'with' allows changing init-only during copy [OK]
Hint: 'with' can set init-only properties on new record copies [OK]
Common Mistakes:
  • Thinking 'with' cannot change init-only properties
  • Expecting compile error on 'with' usage
  • Confusing init-only with immutable fields