ホームページ > ウェブフロントエンド > jsチュートリアル > Node.js のバッファーを詳しく見る

Node.js のバッファーを詳しく見る

青灯夜游
リリース: 2022-02-17 10:42:33
転載
2364 人が閲覧しました

この記事では、Node.jsのBuffer(バッファ)について深く理解し、Bufferクラスの作成方法やバッファへの書き込み方法などを紹介します。皆さんのお役に立てれば幸いです。

Node.js のバッファーを詳しく見る

#JavaScript 言語自体には文字列データ型のみがあり、バイナリ データ型はありません。

ただし、TCP やファイル ストリームなどのストリームを処理する場合は、バイナリ データを使用する必要があります。そのため、Node.js では、バイナリ データを格納するための専用のバッファ領域を作成するために使用される Buffer クラスが定義されています。

Node.js では、Buffer クラスは Node カーネルとともにリリースされるコア ライブラリです。バッファ ライブラリは、生データを Node.js に保存する方法を提供し、Node.js でバイナリ データを処理できるようにします。Node.js で I/O 操作中に移動されたデータを処理する必要があるときはいつでも、バッファ ライブラリを使用できます。

元のデータは Buffer クラスのインスタンスに保存されます。

バッファは整数配列に似ていますが、V8 ヒープ メモリの外側にある元のメモリの一部に対応します。

Buffer クラスの作成

Node Buffer クラスはさまざまな方法で作成できます。

方法 1

長さ 10 バイトのバッファ インスタンスを作成します:

var buf = new Buffer(10);
ログイン後にコピー

方法 2

指定された配列からバッファ インスタンスを作成します:

var buf = new Buffer([10, 20, 30, 40, 50]);
ログイン後にコピー

メソッド 3

文字列からバッファ インスタンスを作成します:

var buf = new Buffer("bianchengsanmei", "utf-8");
ログイン後にコピー

utf-8はデフォルトのエンコーディングであり、「ascii」、「utf8」、「utf16le」、「ucs2」、「base64」、「hex」のエンコーディングもサポートしています。

書き込みバッファ

構文

ノード バッファを書き込むための構文は次のとおりです。

buf.write(string[, offset[, length]][, encoding])
ログイン後にコピー

パラメータ

パラメータは次のように説明されます:

  • string - バッファに書き込まれる文字列。
  • offset - バッファへの書き込みが開始されるインデックス値。デフォルトは 0 です。
  • length - 書き込まれたバイト数、デフォルトはbuffer.length
  • encoding - 使用されるエンコーディング。デフォルトは 'utf8' です。

#戻り値

実際に書き込まれたサイズを返します。バッファスペースが不十分な場合は、文字列の一部のみが書き込まれます。


buf = new Buffer(256);
len = buf.write("bi");
len = buf.write("bianchengsanmei"); 
console.log("写入字节数 : "+  len);
ログイン後にコピー

上記のコードを実行すると、出力結果は次のようになります:

$node main.js
写入字节数 : 15
ログイン後にコピー

バッファからデータを読み取ります

構文

ノード バッファ データを読み取るための構文は次のとおりです:

buf.toString([encoding[,start[,end]]])
ログイン後にコピー

パラメータ

パラメータは次のように説明されます:

  • encoding - 使用するエンコーディング。デフォルトは 'utf8' です。

  • start - 読み取りを開始するインデックス位置を指定します。デフォルトは 0 です。

  • end - 終了位置。デフォルトはバッファーの最後です。

#戻り値

バッファ データをデコードし、指定されたエンコーディングを使用して文字列を返します。

buf = new Buffer(26);
for (var i = 0 ; i < 26 ; i++) {
  buf[i] = i + 97;
}
 
console.log( buf.toString(&#39;ascii&#39;));       // 输出: abcdefghijklmnopqrstuvwxyz
console.log( buf.toString(&#39;ascii&#39;,0,5));   // 输出: abcde
console.log( buf.toString(&#39;utf8&#39;,0,5));    // 输出: abcde
console.log( buf.toString(undefined,0,5)); // 使用 &#39;utf8&#39; 编码, 并输出: abcde
ログイン後にコピー
上記のコードを実行すると、出力結果は次のようになります:

$ node main.js
abcdefghijklmnopqrstuvwxyz
abcde
abcde
abcde
ログイン後にコピー

バッファを JSON オブジェクトに変換

構文

ノード バッファーを JSON オブジェクトに変換するための関数の構文形式は次のとおりです。

buf.toJSON()
ログイン後にコピー

戻り値

JSON オブジェクトを返します。 。

var buf = new Buffer(&#39;bianchengsanmei&#39;);
var json = buf.toJSON(buf);
 
console.log(json);
ログイン後にコピー
上記のコードを実行すると、出力結果は次のようになります:

{
  type: &#39;Buffer&#39;,
  data: [
     98, 105, 97, 110, 99, 104, 101, 110, 103, 115, 97, 110, 109, 101, 105
  ]
}
ログイン後にコピー

バッファ マージ

構文

ノード バッファー マージの構文は次のとおりです:

Buffer.concat(list[, totalLength])
ログイン後にコピー

パラメーター

パラメーターは次のように説明されます:

list - マージに使用される Buffer オブジェクトの配列リスト。
  • totalLength - マージされた Buffer オブジェクトの合計の長さを指定します。
  • #戻り値

複数のメンバーを結合した新しい Buffer オブジェクトを返します。

var buffer1 = new Buffer(&#39;编程三昧 &#39;);
var buffer2 = new Buffer(&#39;bi&#39;);
var buffer2 = new Buffer(&#39;bianchengsanmei&#39;);
var buffer3 = Buffer.concat([buffer1,buffer2]);
console.log("buffer3 内容: " + buffer3.toString());
ログイン後にコピー
上記のコードを実行すると、出力結果は次のようになります:
buffer3 内容: 编程三昧 bianchengsanmei
ログイン後にコピー

バッファ比較

構文

ノード バッファ比較の関数構文は次のとおりです。このメソッドは Node.js v0.12.2 バージョンで導入されました:

buf.compare(otherBuffer);
ログイン後にコピー

Parameters

パラメータ 説明は次のとおりです。

otherBuffer
    -
  • buf オブジェクトと比較される別の Buffer オブジェクト。
  • 戻り値

buf

otherBuffer## の前、後、または同じであることを示す数値を返します。 #。

var buffer1 = new Buffer(&#39;ABC&#39;);
var buffer2 = new Buffer(&#39;ABCD&#39;);
var result = buffer1.compare(buffer2);
 
if(result < 0) {
   console.log(buffer1 + " 在 " + buffer2 + "之前");
}else if(result == 0){
   console.log(buffer1 + " 与 " + buffer2 + "相同");
}else {
   console.log(buffer1 + " 在 " + buffer2 + "之后");
}
ログイン後にコピー

上記のコードを実行すると、出力結果は次のようになります:

ABC在ABCD之前
ログイン後にコピー
コピー バッファ

構文

ノード バッファ コピーの構文は次のとおりです:

buf.copy(target[, targetStart[, sourceStart[, sourceEnd]]])
ログイン後にコピー

パラメータ

パラメータは次のように説明されます:

targetBuffer - コピーされる Buffer オブジェクト。

targetStart - 数値、オプション、デフォルト: 0
  • sourceStart - 数値、オプション、デフォルト: 0
  • sourceEnd - 数値、オプション、デフォルト:buffer.length
  • 戻り値

戻り値はありません。

var buffer1 = new Buffer(&#39;ABC&#39;);
// 拷贝一个缓冲区
var buffer2 = new Buffer(3);
buffer1.copy(buffer2);
console.log("buffer2 content: " + buffer2.toString());
ログイン後にコピー

上記のコードを実行すると、出力結果は次のようになります:

buffer2 content: ABC
ログイン後にコピー

缓冲区裁剪

Node 缓冲区裁剪语法如下所示:

buf.slice([start[, end]])
ログイン後にコピー

参数

参数描述如下:

  • start - 数字, 可选, 默认: 0
  • end - 数字, 可选, 默认: buffer.length

返回值

返回一个新的缓冲区,它和旧缓冲区指向同一块内存,但是从索引 start 到 end 的位置剪切。

实例

var buffer1 = new Buffer(&#39;youj&#39;);
// 剪切缓冲区
var buffer2 = buffer1.slice(0,2);
console.log("buffer2 content: " + buffer2.toString());
ログイン後にコピー

执行以上代码,输出结果为:

buffer2 content: yo
ログイン後にコピー

缓冲区长度

语法 Node 缓冲区长度计算语法如下所示:

buf.length;
ログイン後にコピー

返回值

返回 Buffer 对象所占据的内存长度。

实例

var buffer = new Buffer(&#39;bianchengsanmei&#39;);
//  缓冲区长度
console.log("buffer length: " + buffer.length);
ログイン後にコピー

执行以上代码,输出结果为:

buffer length: 15
ログイン後にコピー

~

~本文完,感谢阅读!

更多node相关知识,请访问:nodejs 教程

以上がNode.js のバッファーを詳しく見るの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:juejin.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート