Bird
Raised Fist0
Node.jsframework~10 mins

Buffer concatenation in Node.js - Interactive Code Practice

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
Practice - 5 Tasks
Answer the questions below
1fill in blank
easy

Complete the code to create a Buffer from a string.

Node.js
const buf = Buffer.[1]('hello');
Drag options to blanks, or click blank then click option'
Afrom
Balloc
Cconcat
Dslice
Attempts:
3 left
💡 Hint
Common Mistakes
Using Buffer.alloc instead of Buffer.from
Trying to use Buffer.concat to create a single buffer
2fill in blank
medium

Complete the code to concatenate two Buffers.

Node.js
const combined = Buffer.[1]([buf1, buf2]);
Drag options to blanks, or click blank then click option'
Aconcat
Bcopy
Calloc
Dfrom
Attempts:
3 left
💡 Hint
Common Mistakes
Using Buffer.from instead of Buffer.concat
Trying to use Buffer.alloc to join buffers
3fill in blank
hard

Fix the error in the code to concatenate buffers with a total length.

Node.js
const combined = Buffer.concat([bufA, bufB], [1]);
Drag options to blanks, or click blank then click option'
AbufA + bufB
BbufA.length + bufB.length
CbufA.size + bufB.size
DbufA.length * bufB.length
Attempts:
3 left
💡 Hint
Common Mistakes
Using bufA + bufB which concatenates objects incorrectly
Using bufA.size which is undefined
4fill in blank
hard

Fill both blanks to create two buffers and concatenate them.

Node.js
const buf1 = Buffer.[1]('Node');
const buf2 = Buffer.[2]('JS');
const result = Buffer.concat([buf1, buf2]);
Drag options to blanks, or click blank then click option'
Afrom
Balloc
DallocUnsafe
Attempts:
3 left
💡 Hint
Common Mistakes
Using Buffer.alloc which creates empty buffers
Mixing different buffer creation methods
5fill in blank
hard

Fill all three blanks to create buffers, concatenate, and convert to string.

Node.js
const bufA = Buffer.[1]('Hello, ');
const bufB = Buffer.[2]('World!');
const combined = Buffer.[3]([bufA, bufB]);
console.log(combined.toString());
Drag options to blanks, or click blank then click option'
Afrom
Cconcat
Dalloc
Attempts:
3 left
💡 Hint
Common Mistakes
Using Buffer.alloc which creates empty buffers
Trying to call toString() on buffers before concatenation

Practice

(1/5)
1. What does Buffer.concat do in Node.js?
easy
A. Creates a new empty Buffer
B. Splits a Buffer into smaller chunks
C. Joins multiple Buffer objects into one larger Buffer
D. Converts a Buffer to a string

Solution

  1. Step 1: Understand Buffer.concat purpose

    Buffer.concat is designed to combine multiple Buffer objects into a single Buffer.
  2. Step 2: Compare options with Buffer.concat behavior

    Only Joins multiple Buffer objects into one larger Buffer describes joining buffers, which matches Buffer.concat functionality.
  3. Final Answer:

    Joins multiple Buffer objects into one larger Buffer -> Option C
  4. Quick Check:

    Buffer.concat joins buffers = D [OK]
Hint: Remember concat means join, not split or convert [OK]
Common Mistakes:
  • Confusing concat with split or slice
  • Thinking it converts buffers to strings
  • Assuming it creates empty buffers
2. Which of the following is the correct syntax to concatenate two buffers buf1 and buf2?
easy
A. Buffer.concat([buf1, buf2])
B. Buffer.concat(buf1, buf2)
C. Buffer.concat(buf1 + buf2)
D. Buffer.concat({buf1, buf2})

Solution

  1. Step 1: Check Buffer.concat parameter type

    Buffer.concat expects an array of Buffer objects as its first argument.
  2. Step 2: Match options with correct syntax

    Only Buffer.concat([buf1, buf2]) passes an array [buf1, buf2], which is correct syntax.
  3. Final Answer:

    Buffer.concat([buf1, buf2]) -> Option A
  4. Quick Check:

    Buffer.concat takes array of buffers = A [OK]
Hint: Always pass buffers inside an array to Buffer.concat [OK]
Common Mistakes:
  • Passing buffers as separate arguments
  • Using plus operator to add buffers
  • Passing an object instead of array
3. What will be the output length of the following code?
const buf1 = Buffer.from('Hi');
const buf2 = Buffer.from('!');
const result = Buffer.concat([buf1, buf2]);
console.log(result.length);
medium
A. 4
B. 2
C. 1
D. 3

Solution

  1. Step 1: Calculate length of each buffer

    buf1 contains 'Hi' which is 2 bytes, buf2 contains '!' which is 1 byte.
  2. Step 2: Sum lengths after concatenation

    Total length = 2 + 1 = 3 bytes.
  3. Final Answer:

    3 -> Option D
  4. Quick Check:

    Length of 'Hi' + '!' = 3 [OK]
Hint: Add lengths of all buffers to get result length [OK]
Common Mistakes:
  • Counting characters instead of bytes
  • Forgetting to add all buffer lengths
  • Assuming length stays same as first buffer
4. Identify the error in this code snippet:
const buf1 = Buffer.from('A');
const buf2 = Buffer.from('B');
const combined = Buffer.concat(buf1, buf2);
console.log(combined.toString());
medium
A. Buffer.concat expects an array of buffers, not separate arguments
B. Buffer.from cannot create buffers from strings
C. toString() is not a method on Buffer objects
D. Buffers cannot be concatenated

Solution

  1. Step 1: Check Buffer.concat argument type

    The code passes two buffers as separate arguments, but Buffer.concat requires a single array argument.
  2. Step 2: Verify other parts of code

    Buffer.from correctly creates buffers from strings, and toString() is valid on buffers.
  3. Final Answer:

    Buffer.concat expects an array of buffers, not separate arguments -> Option A
  4. Quick Check:

    Buffer.concat needs array argument = C [OK]
Hint: Pass buffers inside an array to Buffer.concat [OK]
Common Mistakes:
  • Passing buffers as separate arguments
  • Misunderstanding Buffer.from usage
  • Thinking toString() is invalid on buffers
5. You have three buffers: buf1 with length 5, buf2 with length 3, and buf3 with length 7. You want to concatenate them efficiently. Which is the best way to use Buffer.concat for performance?
hard
A. Buffer.concat([buf1, buf2, buf3])
B. Buffer.concat([buf1, buf2, buf3], 15)
C. Buffer.concat([buf1, buf2, buf3], 10)
D. Buffer.concat([buf1, buf2, buf3], 20)

Solution

  1. Step 1: Calculate total length of buffers

    Total length = 5 + 3 + 7 = 15 bytes.
  2. Step 2: Use Buffer.concat with total length for efficiency

    Passing the exact total length as the second argument improves performance by preallocating the buffer.
  3. Step 3: Compare options

    Buffer.concat([buf1, buf2, buf3], 15) correctly passes the array and the exact total length 15.
  4. Final Answer:

    Buffer.concat([buf1, buf2, buf3], 15) -> Option B
  5. Quick Check:

    Pass total length for better performance = B [OK]
Hint: Provide exact total length as second argument for speed [OK]
Common Mistakes:
  • Not passing total length at all
  • Passing incorrect total length
  • Passing length smaller or larger than sum