Buffers trong Node.js, Buffers được sử dụng như thế nào?

Buffers trong Node.js, Buffers được sử dụng như thế nào?

Tin ngắn hàng ngày dành cho bạn
  • Manus đã chính thức mở cửa cho tất cả người dùng rồi đấy mọi người. Cho những ai chưa biết thì đây là một công cụ viết báo cáo (làm mưa làm gió) giống như Deep Research của OpenAI á. Mỗi ngày được miễn phí 300 Credits để nghiên cứu. Mỗi lượt nghiên cứu tiêu tốn tuỳ thuộc vào độ phức tạp của yêu cầu. À với cả họ đang có chương trình tặng miễn phí Credits hay sao á. Như mình thì vào thấy được hẳn 2000.

    Mình dùng thử, so sánh với cùng một lệnh giống như đợt trước dùng bên Deep Research thì nội dung khác biệt nhau hoàn toàn. Manus báo cáo như kiểu viết văn hơn so với OpenAI là các gạch đầu dòng và bảng biểu.

    À lúc đăng ký xong có bắt nhập số điện thoại để xác minh, nếu lỗi thì các bạn đợi qua ngày thử lại xem có được không nhé.

    » Xem thêm
  • Mọi người chắc nghe nhiều về xu hướng tìm kiếm thông tin bằng AI chứ không cần công cụ tìm kiếm như Google nữa rồi đúng không? Không đâu xa ánh xạ vào bản thân thì thấy đúng thật, thi thoảng mới tìm kiếm thôi chứ còn đâu toàn hỏi tụi AI.

    Ngay từ đầu viết blog, thứ mà mình hướng đến là chia sẻ kinh nghiệm chứ không phải là những bài mang nặng tính kỹ thuật, máy móc, hướng dẫn từ đầu... Vì thời điểm đó đã có quá nhiều người làm nội dung này rồi và họ làm rất tốt, tại sao mình phải cố phát minh lại bánh xe? Một điều nữa là tin tưởng độc giả của mình có khả năng tìm hiểu vấn đề. Nếu bạn đọc đủ nhiều các bài viết trên blog thì thấy mình luôn cố gắng chèn thêm các liên kết tham khảo ngoài bài viết, nêu ra vấn đề mở và rất ít khi kết luận chắc chắn một điều gì đó.

    Mình đã cố gắng rèn luyện kỹ năng viết, kỹ năng trình bày và cả cách tương tác với độc giả để mang lại giá trị cho họ. Nhiều lúc ngồi lật lại các con số thống kê thấy lượng đọc bài viết tăng lên lại cảm thấy vui. Nhưng khi nguồn truy cập đến từ Google thì lại thấy buồn, vì điều đó chứng tỏ họ biết đến mình chỉ khi đang cố đi tìm giải pháp, có thể họ chỉ đọc chớp nhoáng, may ra tìm được cách giải quyết và thế là đóng cửa sổ trình duyệt rồi đi như một cơn gió.

    Chừng vài tháng đổ lại đây, một điều khiến mình rất vui đó là lượng người truy cập thẳng vào trang chủ mà không thông qua công cụ tìm kiếm đang tăng dần lên, có nhiều hôm lượng truy cập tự nhiên còn cao hơn cả đến từ Google. Điều đó chứng tỏ độc giả đã có thói quen quay lại trang của mình nhiều hơn và họ tìm thấy được giá trị từ blog mang lại. Vui mừng khôn xiết 🤩

    Bên cạnh đó thì lượng truy cập vào chuyên mục Threads - tức là mục mình đang viết bài này đang cao hơn bao giờ hết. Điều đó chứng tỏ xu hướng đi theo tin nhanh là đúng đắn. Mình có thể ngồi cả ngày để viết tin ngắn cho bạn đọc vì nó rất nhanh mà tiện, không tốn công đi tìm tài liệu để viết, không tốn cả thời gian viết nữa, còn mình thì có rất nhiều thứ để chia sẻ 😅. Nhưng không vì thế mà bỏ bê các bài viết dài, vì dài thì có nhiều thông tin để chia sẻ hơn.

    Vài lời tâm sự thế thôi chứ hơn một tháng nay mình chưa viết bài viết mới nào vì công việc bận quá. Xong lâu dần cứ trì hoãn lại thành lười. À với cả tháng 5 này rất thích hợp để đọc các cuốn sách về cách mạng á. Có hôm đọc đến 2 giờ sáng mới đi ngủ 🥱

    » Xem thêm
  • Mình mới nhìn thấy một trang web khá thú vị nói về các cột mốc đáng nhớ trong lịch sử phát triển Internet toàn cầu: Internet Artifacts

    Chỉ từ 1977 - khi Internet còn nằm trong hộp thí nghiệm thì nhìn xem - giờ đây Internet đã khiến mọi thứ phát triển đến mức nào 🫣

    » Xem thêm

Buffer là gì?

Buffer là một vùng bộ nhớ, nó đại diện cho một đoạn bộ nhớ có kích thước cố định (không thể thay đổi) được phân bổ ở bên ngoài V8 JavaScript Engine.

Bạn có thể coi Buffer giống như một mảng các số nguyên, mỗi số đại diện cho một byte dữ liệu.

Nó được triển khai bởi class Buffer.

Tại sao chúng ta cần Buffer?

Buffer được giới thiệu để giúp các nhà phát triển xử lý dữ liệu nhị phân, trong một hệ sinh thái mà theo truyền thống chỉ xử lý các chuỗi thay vì xử lý nhị phân.

Buffer được liên kết sâu sắc với streams. Khi một quá trình streams nhận dữ liệu nhanh hơn mức nó có thể xử lý, nó sẽ đưa dữ liệu vào buffer.

Hình dung đơn giản về buffer là khi bạn đang xem video trên YouTube và sẽ có 2 đường màu đỏ và màu trắng. Khi đường màu trắng dài hơn tức là trình duyệt đang tải dữ liệu xuống nhanh hơn so với khi đang xem, và trình duyệt sẽ lưu dữ liệu đó vào buffer.

Video buffering

Tạo một Buffer

Một Buffer được tạo ra bằng cách sử dụng Buffer.from(), Buffer.alloc() hoặc Buffer.allocUnsafe():

const buf = Buffer.from('Hey!');
Buffer.from(array);
Buffer.from(arrayBuffer[, byteOffset[, length]]);
Buffer.from(buffer);
Buffer.from(string[, encoding]);

Bạn cũng có thể khởi tạo một buffer theo kích thước. Ví dụ dưới đây sẽ tạo ra một Buffer có kích thước 1KB:

const buf = Buffer.alloc(1024);
// hoặc
const buf = Buffer.allocUnsafe(1024);

Cả hai phương thức allocallocUnsafe phân bổ một Buffer có kích thước được chỉ định theo byte, Buffer được tạo bởi alloc sẽ được khởi tạo bằng 0 và Buffer được tạo bởi allocUnsafe sẽ không được khởi tạo. Điều này có nghĩa là mặc dù allocUnsafe sẽ khá nhanh hơn so với alloc, nhưng phân đoạn bộ nhớ được cấp phát có khả năng có thể chứa dữ liệu cũ.

Dữ liệu cũ nếu có trong bộ nhớ, có thể bị truy cập hoặc bị rò rỉ khi Buffer bộ nhớ được đọc. Đây là điều thực sự làm cho allocUnsafe không an toàn và cần phải cẩn thận hơn trong khi sử dụng nó.

Sử dụng Buffer

Truy cập nội dung của buffer

Buffer là một mảng byte, có thể được truy cập giống như một mảng:

const buf = Buffer.from('Hey!');
console.log(buf[0]); // 72
console.log(buf[1]); // 101
console.log(buf[2]); // 121

Những con số đó là mã Unicode xác định ký tự ở vị trí của buffer (H => 72, e => 101, y => 121).

Bạn có thể in toàn bộ nội dung của buffer bằng phương thức toString()

console.log(buf.toString()); // Hey!  

Lưu ý, nếu bạn khởi tạo buffer với kích thước xác định thì vùng nhớ khởi tạo trước đó sẽ chứa dữ liệu ngẫu nhiên, không phải là một buffer trống!

Độ dài của một Buffer

Sử dụng thuộc tính length.

const buf = Buffer.from('Hey!');
console.log(buf.length); // 4

Lặp nội dung của Buffer

const buf = Buffer.from('Hey!');
for (const item of buf) {
  console.log(item); // 72 101 121 33
}

Thay đổi nội dung của Buffer

Bạn có thể thay đổi toàn bộ nội dung của một Buffer bằng cách sử dụng write().

const buf = Buffer.alloc(4);
buf.write('Hey!');
console.log(buf); // Hey!  

Hoặc bạn cũng có thể thay đổi nội dung bằng cú pháp giống như khi sử dụng một mảng.

const buf = Buffer.from('Hey!');
buf[1] = 111; // o
console.log(buf.toString()); // Hoy!  

Sao chép Buffer

Có thể sao chép Buffer bằng phương thức copy().

const buf = Buffer.from('Hey!');
let bufcopy = Buffer.alloc(4);
buf.copy(bufcopy);
console.log(bufcopy); // Hey!  

Theo mặc định, copy() sao chép toàn bộ Buffer. Bạn có thể cung cấp 3 tham số theo thứ tự cho phép bạn xác định vị trí bắt đầu, vị trí kết thúc và độ dài Buffer mới:

const buf = Buffer.from('Hey!');
let bufcopy = Buffer.alloc(2); // cấp phát 2 byte bộ nhớ
buf.copy(bufcopy, 0, 0, 2);
console.log(bufcopy.toString()); // 'He'

Slice Buffer

Một slice của Buffer vẫn tham chiếu đến nó, tức là khi Buffer thay đổi, slice đó cũng sẽ thay đổi.

Sử dụng slice() để tạo một "lát cắt". Tham số đầu tiên là vị trí bắt đầu và bạn có thể chỉ định tham số thứ hai là vị trí kết thúc:

const buf = Buffer.from('Hey!');
buf.slice(0).toString() // Hey!  
const slice = buf.slice(0, 2);
console.log(slice.toString()); // He
buf[1] = 111; // o
console.log(slice.toString()); // Ho

Tổng kết

Buffer là một dạng dữ liệu nhị phân có kích thước cố định. Các nhà phát triển JavaScript thường sẽ không làm việc thường xuyên với kiểu dữ liệu này so với các nhà phát triển C, C++ hoặc Go (hoặc bất kỳ lập trình viên nào sử dụng những ngôn ngữ lập trình hệ thống), tương tác với bộ nhớ hàng ngày. Buffer thường được thấy trong việc xử lý Streams - là một cách để xử lý việc đọc/ghi tệp, truyền dữ liệu trực tiếp hoặc bất kỳ loại trao đổi thông tin từ các thiết bị đầu cuối một cách hiệu quả. Ở bài viết sau chúng ta sẽ cùng nhau tìm hiểu về Streams là gì!

Cao cấp
Hello

5 bài học sâu sắc

Mỗi sản phẩm đi kèm với những câu chuyện. Thành công của người khác là nguồn cảm hứng cho nhiều người theo sau. 5 bài học rút ra được đã thay đổi con người tôi mãi mãi. Còn bạn? Hãy bấm vào ngay!

Mỗi sản phẩm đi kèm với những câu chuyện. Thành công của người khác là nguồn cảm hứng cho nhiều người theo sau. 5 bài học rút ra được đã thay đổi con người tôi mãi mãi. Còn bạn? Hãy bấm vào ngay!

Xem tất cả

Đăng ký nhận thông báo bài viết mới

hoặc
* Bản tin tổng hợp được gửi mỗi 1-2 tuần, huỷ bất cứ lúc nào.

Bình luận (0)

Nội dung bình luận...