Bird
Raised Fist0
Node.jsframework~20 mins

Reading and writing buffer data in Node.js - Mini Project: Build & Apply

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
Reading and Writing Buffer Data in Node.js
📖 Scenario: You are building a simple Node.js program that reads and writes data using buffers. Buffers are used to handle raw binary data, like when working with files or network streams.Imagine you want to store a short message in a buffer, then read it back and modify it.
🎯 Goal: Build a Node.js script that creates a buffer with a message, reads the buffer content, modifies part of it, and writes the updated content back to a new buffer.
📋 What You'll Learn
Create a buffer with the exact string 'Hello Node.js!'
Create a variable to hold the length of the buffer
Use buffer methods to read the content as a string
Modify the buffer content by replacing 'Node.js' with 'World'
Create a new buffer with the modified content
💡 Why This Matters
🌍 Real World
Buffers are essential in Node.js for handling raw data streams, such as reading files, working with network sockets, or processing binary data.
💼 Career
Understanding buffers helps in backend development, especially when dealing with file systems, APIs, or performance-critical data processing.
Progress0 / 4 steps
1
Create a buffer with the message
Create a buffer called buffer containing the exact string 'Hello Node.js!' using Buffer.from().
Node.js
Hint

Use Buffer.from('Hello Node.js!') to create the buffer.

2
Get the buffer length
Create a variable called length and set it to the length of buffer using buffer.length.
Node.js
Hint

Use buffer.length to get the size of the buffer.

3
Read buffer content as string
Create a variable called content and set it to the string read from buffer using buffer.toString().
Node.js
Hint

Use buffer.toString() to convert buffer data to a string.

4
Modify and write new buffer data
Create a new buffer called newBuffer by replacing 'Node.js' with 'World' in content and using Buffer.from() on the new string.
Node.js
Hint

Use content.replace('Node.js', 'World') and then Buffer.from() to create the new buffer.

Practice

(1/5)
1. What is the primary purpose of a Buffer in Node.js?
easy
A. To manage HTTP requests automatically
B. To store JavaScript objects in memory
C. To hold raw binary data for reading and writing
D. To format strings for display in the console

Solution

  1. Step 1: Understand what Buffer stores

    A Buffer is designed to hold raw binary data, not objects or formatted strings.
  2. Step 2: Identify Buffer's main use

    Buffers allow reading and writing bytes directly, useful for binary data handling.
  3. Final Answer:

    To hold raw binary data for reading and writing -> Option C
  4. Quick Check:

    Buffer = raw binary data [OK]
Hint: Buffers store raw bytes, not objects or formatted text [OK]
Common Mistakes:
  • Thinking Buffer stores JavaScript objects
  • Confusing Buffer with string formatting tools
  • Assuming Buffer manages HTTP requests
2. Which of the following is the correct way to create a Buffer of size 5 bytes filled with zeros?
easy
A. Buffer.new(5)
B. Buffer.alloc(5)
C. new Buffer(5, 0)
D. Buffer.create(5)

Solution

  1. Step 1: Recall Buffer creation methods

    In modern Node.js, Buffer.alloc(size) creates a zero-filled buffer.
  2. Step 2: Check other options

    Buffer.new and Buffer.create do not exist; new Buffer() is deprecated and unsafe.
  3. Final Answer:

    Buffer.alloc(5) -> Option B
  4. Quick Check:

    Use Buffer.alloc for safe zero-filled buffers [OK]
Hint: Use Buffer.alloc(size) for zero-filled buffers [OK]
Common Mistakes:
  • Using deprecated new Buffer() constructor
  • Trying non-existent Buffer.new or Buffer.create methods
  • Not initializing buffer contents
3. What will be the output of this code?
const buf = Buffer.from('abc');
console.log(buf[1]);
medium
A. 98
B. b
C. 1
D. undefined

Solution

  1. Step 1: Understand Buffer.from and indexing

    Buffer.from('abc') creates a buffer with ASCII codes of 'a', 'b', 'c'. Index 1 is 'b'.
  2. Step 2: Check what buf[1] returns

    Buffer indexes return the byte value (number), not the character. 'b' ASCII code is 98.
  3. Final Answer:

    98 -> Option A
  4. Quick Check:

    Buffer index returns byte code, not character [OK]
Hint: Buffer indexes return byte numbers, not characters [OK]
Common Mistakes:
  • Expecting character instead of ASCII code
  • Confusing index with string position
  • Assuming buf[1] returns a string
4. Identify the error in this code snippet:
const buf = Buffer.alloc(3);
buf.write('hello');
console.log(buf.toString());
medium
A. Buffer size is too small for the string 'hello'
B. Buffer.alloc cannot be used with write method
C. toString() cannot be called on a Buffer
D. write method requires encoding argument

Solution

  1. Step 1: Check buffer size vs string length

    Buffer.alloc(3) creates 3 bytes, but 'hello' needs 5 bytes to store fully.
  2. Step 2: Understand write behavior

    write writes as many bytes as fit; here it truncates 'hello' to 'hel'.
  3. Final Answer:

    Buffer size is too small for the string 'hello' -> Option A
  4. Quick Check:

    Buffer too small truncates written string [OK]
Hint: Buffer must be large enough to hold full string [OK]
Common Mistakes:
  • Thinking write needs encoding argument always
  • Assuming toString() is invalid on Buffer
  • Believing Buffer.alloc disallows write
5. You want to copy the first 4 bytes from one buffer src to another buffer dest starting at index 2 in dest. Which code correctly does this?
hard
A. dest.copy(src, 2, 0, 4);
B. dest.copy(src, 0, 2, 6);
C. src.copy(dest, 0, 2, 6);
D. src.copy(dest, 2, 0, 4);

Solution

  1. Step 1: Understand Buffer.copy parameters

    The method is source.copy(target, targetStart, sourceStart, sourceEnd).
  2. Step 2: Match parameters to requirement

    Copy from src starting at 0 to 4 bytes, into dest starting at index 2.
  3. Final Answer:

    src.copy(dest, 2, 0, 4); -> Option D
  4. Quick Check:

    source.copy(target, targetStart, sourceStart, sourceEnd) [OK]
Hint: source.copy(target, targetStart, sourceStart, sourceEnd) [OK]
Common Mistakes:
  • Swapping source and target buffers
  • Mixing up start and end indexes
  • Using copy on wrong buffer object