指定したバイト配列から要素をデコードし、指定した Unicode 文字配列の要素として格納します。
オーバーロードの一覧
指定したバイト配列からある範囲の要素をデコードし、指定した Unicode 文字配列の要素として格納します。
.NET Compact Framework でもサポート。
[Visual Basic] Overloads Overrides Public Function GetChars(Byte(), Integer, Integer, Char(), Integer) As Integer
[C#] public override int GetChars(byte[], int, int, char[], int);
[C++] public: int GetChars(unsigned char __gc[], int, int, __wchar_t __gc[], int);
[JScript] public override function GetChars(Byte[], int, int, Char[], int) : int;
Encoding から継承されます。
.NET Compact Framework でもサポート。
[Visual Basic] Overloads Public Overridable Function GetChars(Byte()) As Char()
[C++] public: virtual __wchar_t GetChars(unsigned char __gc[]) __gc[];
Encoding から継承されます。
.NET Compact Framework でもサポート。
[Visual Basic] Overloads Public Overridable Function GetChars(Byte(), Integer, Integer) As Char()
[C++] public: virtual __wchar_t GetChars(unsigned char __gc[], int, int) __gc[];
[JScript] public function GetChars(Byte[], int, int) : Char[];
使用例
[Visual Basic, C#, C++] GetChars メソッドを使用して、バイト配列 bytes
からある範囲の要素をデコードし、その結果を文字配列 chars
に格納する方法を次の例に示します。 GetCharCount メソッドは、デコードされた要素を格納するために必要な文字数を計算するときに使用します。
[Visual Basic, C#, C++] メモ ここでは、GetChars のオーバーロード形式のうちの 1 つだけについて、使用例を示します。その他の例については、各オーバーロード形式のトピックを参照してください。
Imports System
Imports System.Text
Class UnicodeEncodingExample
Public Shared Sub Main()
Dim chars() As Char
Dim bytes() As Byte = {85, 0, 110, 0, 105, 0, 99, 0, 111, 0, 100, 0, 101, 0}
Dim uni As New UnicodeEncoding()
Dim charCount As Integer = uni.GetCharCount(bytes, 2, 8)
chars = New Char(charCount - 1) {}
Dim charsDecodedCount As Integer = uni.GetChars(bytes, 2, 8, chars, 0)
Console.WriteLine("{0} characters used to decode bytes.", charsDecodedCount)
Console.Write("Decoded chars: ")
Dim c As Char
For Each c In chars
Console.Write("[{0}]", c)
Next c
Console.WriteLine()
End Sub 'Main
End Class 'UnicodeEncodingExample
[C#]
using System;
using System.Text;
class UnicodeEncodingExample {
public static void Main() {
Char[] chars;
Byte[] bytes = new Byte[] {
85, 0, 110, 0, 105, 0, 99, 0, 111, 0, 100, 0, 101, 0
};
UnicodeEncoding Unicode = new UnicodeEncoding();
int charCount = Unicode.GetCharCount(bytes, 2, 8);
chars = new Char[charCount];
int charsDecodedCount = Unicode.GetChars(bytes, 2, 8, chars, 0);
Console.WriteLine(
"{0} characters used to decode bytes.", charsDecodedCount
);
Console.Write("Decoded chars: ");
foreach (Char c in chars) {
Console.Write("[{0}]", c);
}
Console.WriteLine();
}
}
[C++]
#using <mscorlib.dll>
using namespace System;
using namespace System::Text;
using namespace System::Collections;
int main()
{
Char chars[];
Byte bytes[] =
{
85, 0, 110, 0, 105, 0, 99, 0, 111, 0, 100, 0, 101, 0
};
UnicodeEncoding* Unicode = new UnicodeEncoding();
int charCount = Unicode -> GetCharCount(bytes, 2, 8);
chars = new Char[charCount];
int charsDecodedCount = Unicode -> GetChars(bytes, 2, 8, chars, 0);
Console::WriteLine(S"{0} characters used to decode bytes.", __box(charsDecodedCount));
Console::Write(S"Decoded chars: ");
IEnumerator* myEnum = chars->GetEnumerator();
while (myEnum->MoveNext())
{
Char* c = __try_cast<Char*>(myEnum->Current);
Console::Write(S"[{0}]", c -> ToString());
}
Console::WriteLine();
}
[JScript] JScript のサンプルはありません。Visual Basic、C#、および C++ のサンプルを表示するには、このページの左上隅にある言語のフィルタ ボタン をクリックします。
参照
UnicodeEncoding クラス | UnicodeEncoding メンバ | System.Text 名前空間