UTF7Encoding.GetBytes Yöntem
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
Bir karakter kümesini bayt dizisine kodlar.
Aşırı Yüklemeler
| Name | Description |
|---|---|
| GetBytes(Char*, Int32, Byte*, Int32) |
Belirtilen karakter işaretçisinde başlayan bir karakter kümesini, belirtilen bayt işaretçisinde başlayan bir bayt dizisine kodlar. |
| GetBytes(Char[], Int32, Int32, Byte[], Int32) |
Belirtilen karakter dizisinden bir dizi karakteri belirtilen bayt dizisine kodlar. |
| GetBytes(String, Int32, Int32, Byte[], Int32) |
Belirtilenden bir dizi karakteri belirtilen String bayt dizisine kodlar. |
GetBytes(Char*, Int32, Byte*, Int32)
- Kaynak:
- UTF7Encoding.cs
- Kaynak:
- UTF7Encoding.cs
- Kaynak:
- UTF7Encoding.cs
- Kaynak:
- UTF7Encoding.cs
- Kaynak:
- UTF7Encoding.cs
Önemli
Bu API, CLS uyumlu değildir.
Belirtilen karakter işaretçisinde başlayan bir karakter kümesini, belirtilen bayt işaretçisinde başlayan bir bayt dizisine kodlar.
public:
override int GetBytes(char* chars, int charCount, System::Byte* bytes, int byteCount);
[System.CLSCompliant(false)]
[System.Security.SecurityCritical]
public override int GetBytes(char* chars, int charCount, byte* bytes, int byteCount);
[System.CLSCompliant(false)]
public override int GetBytes(char* chars, int charCount, byte* bytes, int byteCount);
[System.CLSCompliant(false)]
[System.Runtime.InteropServices.ComVisible(false)]
public override int GetBytes(char* chars, int charCount, byte* bytes, int byteCount);
[System.CLSCompliant(false)]
[System.Security.SecurityCritical]
[System.Runtime.InteropServices.ComVisible(false)]
public override int GetBytes(char* chars, int charCount, byte* bytes, int byteCount);
[<System.CLSCompliant(false)>]
[<System.Security.SecurityCritical>]
override this.GetBytes : nativeptr<char> * int * nativeptr<byte> * int -> int
[<System.CLSCompliant(false)>]
override this.GetBytes : nativeptr<char> * int * nativeptr<byte> * int -> int
[<System.CLSCompliant(false)>]
[<System.Runtime.InteropServices.ComVisible(false)>]
override this.GetBytes : nativeptr<char> * int * nativeptr<byte> * int -> int
[<System.CLSCompliant(false)>]
[<System.Security.SecurityCritical>]
[<System.Runtime.InteropServices.ComVisible(false)>]
override this.GetBytes : nativeptr<char> * int * nativeptr<byte> * int -> int
Parametreler
- chars
- Char*
Kodlanacak ilk karakterin işaretçisi.
- charCount
- Int32
Kodlanacak karakter sayısı.
- bytes
- Byte*
Elde edilen bayt dizisini yazmaya başlama konumuna yönelik bir işaretçi.
- byteCount
- Int32
Yazacak bayt sayısı üst sınırı.
Döndürülenler
tarafından bytesbelirtilen konumda yazılan gerçek bayt sayısı.
- Öznitelikler
Özel durumlar
charCount veya byteCount sıfırdan küçüktür.
byteCount elde edilen bayt sayısından küçüktür.
Bir geri dönüş oluştu (daha ayrıntılı açıklama için bkz. Character Encoding in .NET).
-ve-
EncoderFallback olarak ayarlanır EncoderExceptionFallback.
Açıklamalar
Uygulama, tarafından elde edilen baytları depolamak için gereken GetBytes dizi boyutunu tam olarak hesaplamak için kullanır GetByteCount. En büyük dizi boyutunu hesaplamak için uygulama kullanmalıdır GetMaxByteCount. GetByteCount yöntemi genellikle daha az bellek ayırmaya izin verirken, GetMaxByteCount yöntem genellikle daha hızlı yürütülür.
Bir akıştan okunan veriler gibi dönüştürülecek veriler yalnızca sıralı bloklarda kullanılabilir. Bu durumda veya veri miktarı daha küçük bloklara bölünmesi gereken kadar büyükse, uygulama sırasıyla yöntemi veya yöntemi tarafından Decoder sağlanan veya öğesini kullanmalıdır.EncoderGetDecoderGetEncoder
Note
UTF7Encoding hata algılama sağlamaz. Geçersiz karakterler değiştirilmiş temel 64 karakter olarak kodlanmış. Güvenlik nedeniyle, uygulamalarınızın , UTF8Encodingveya UnicodeEncoding kullanmaları UTF32Encodingve hata algılamayı etkinleştirmeleri önerilir.
Ayrıca bkz.
Şunlara uygulanır
GetBytes(Char[], Int32, Int32, Byte[], Int32)
- Kaynak:
- UTF7Encoding.cs
- Kaynak:
- UTF7Encoding.cs
- Kaynak:
- UTF7Encoding.cs
- Kaynak:
- UTF7Encoding.cs
- Kaynak:
- UTF7Encoding.cs
Belirtilen karakter dizisinden bir dizi karakteri belirtilen bayt dizisine kodlar.
public:
override int GetBytes(cli::array <char> ^ chars, int charIndex, int charCount, cli::array <System::Byte> ^ bytes, int byteIndex);
public override int GetBytes(char[] chars, int charIndex, int charCount, byte[] bytes, int byteIndex);
override this.GetBytes : char[] * int * int * byte[] * int -> int
Public Overrides Function GetBytes (chars As Char(), charIndex As Integer, charCount As Integer, bytes As Byte(), byteIndex As Integer) As Integer
Parametreler
- chars
- Char[]
Kodlanması gereken karakter kümesini içeren karakter dizisi.
- charIndex
- Int32
Kodlanacak ilk karakterin dizini.
- charCount
- Int32
Kodlanacak karakter sayısı.
- bytes
- Byte[]
Elde edilen bayt dizisini içeren bayt dizisi.
- byteIndex
- Int32
Elde edilen bayt sırasını yazmaya başlanması gereken dizin.
Döndürülenler
içine yazılan bytesgerçek bayt sayısı.
Özel durumlar
charIndex veya charCountbyteIndex sıfırdan küçüktür.
-veya-
charIndex ve charCount içinde charsgeçerli bir aralığı ifade etmeyin.
-veya-
byteIndex içinde bytesgeçerli bir dizin değil.
bytes dizinin sonundan byteIndex elde edilen baytları barındırmak için yeterli kapasiteye sahip değil.
Bir geri dönüş oluştu (daha ayrıntılı açıklama için bkz. Character Encoding in .NET).
-ve-
EncoderFallback olarak ayarlanır EncoderExceptionFallback.
Örnekler
Aşağıdaki kod örneği, bir karakter aralığını kodlamak ve kodlanmış baytları GetBytes bayt dizisindeki bir öğe aralığında depolamak için yönteminin nasıl kullanılacağını String gösterir.
using System;
using System.Text;
class UTF7EncodingExample {
public static void Main() {
Byte[] bytes;
// Unicode characters.
Char[] chars = new Char[] {
'\u0023', // #
'\u0025', // %
'\u03a0', // Pi
'\u03a3' // Sigma
};
UTF7Encoding utf7 = new UTF7Encoding();
int byteCount = utf7.GetByteCount(chars, 1, 2);
bytes = new Byte[byteCount];
int bytesEncodedCount = utf7.GetBytes(chars, 1, 2, bytes, 0);
Console.WriteLine(
"{0} bytes used to encode characters.", bytesEncodedCount
);
Console.Write("Encoded bytes: ");
foreach (Byte b in bytes) {
Console.Write("[{0}]", b);
}
Console.WriteLine();
}
}
Imports System.Text
Imports Microsoft.VisualBasic.strings
Class UTF7EncodingExample
Public Shared Sub Main()
Dim bytes() As Byte
' Unicode characters.
' ChrW(35) = #
' ChrW(37) = %
' ChrW(928) = Pi
' ChrW(931) = Sigma
Dim chars() As Char = {ChrW(35), ChrW(37), ChrW(928), ChrW(931)}
Dim utf7 As New UTF7Encoding()
Dim byteCount As Integer = utf7.GetByteCount(chars, 1, 2)
bytes = New Byte(byteCount - 1) {}
Dim bytesEncodedCount As Integer = utf7.GetBytes(chars, 1, 2, bytes, 0)
Console.WriteLine("{0} bytes used to encode characters.", bytesEncodedCount)
Console.Write("Encoded bytes: ")
Dim b As Byte
For Each b In bytes
Console.Write("[{0}]", b)
Next b
Console.WriteLine()
End Sub
End Class
Açıklamalar
Uygulama, tarafından elde edilen baytları depolamak için gereken GetBytes dizi boyutunu tam olarak hesaplamak için kullanır GetByteCount. En büyük dizi boyutunu hesaplamak için uygulama kullanmalıdır GetMaxByteCount. GetByteCount yöntemi genellikle daha az bellek ayırmaya izin verirken, GetMaxByteCount yöntem genellikle daha hızlı yürütülür.
Bir akıştan okunan veriler gibi dönüştürülecek veriler yalnızca sıralı bloklarda kullanılabilir. Bu durumda veya veri miktarı daha küçük bloklara bölünmesi gereken kadar büyükse, uygulama sırasıyla yöntemi veya yöntemi tarafından Decoder sağlanan veya öğesini kullanmalıdır.EncoderGetDecoderGetEncoder
Note
UTF7Encoding hata algılama sağlamaz. Geçersiz karakterler değiştirilmiş temel 64 karakter olarak kodlanmış. Güvenlik nedeniyle, uygulamalarınızın , UTF8Encodingveya UnicodeEncoding kullanmaları UTF32Encodingve hata algılamayı etkinleştirmeleri önerilir.
Ayrıca bkz.
Şunlara uygulanır
GetBytes(String, Int32, Int32, Byte[], Int32)
- Kaynak:
- UTF7Encoding.cs
- Kaynak:
- UTF7Encoding.cs
- Kaynak:
- UTF7Encoding.cs
- Kaynak:
- UTF7Encoding.cs
- Kaynak:
- UTF7Encoding.cs
Belirtilenden bir dizi karakteri belirtilen String bayt dizisine kodlar.
public:
override int GetBytes(System::String ^ s, int charIndex, int charCount, cli::array <System::Byte> ^ bytes, int byteIndex);
public override int GetBytes(string s, int charIndex, int charCount, byte[] bytes, int byteIndex);
[System.Runtime.InteropServices.ComVisible(false)]
public override int GetBytes(string s, int charIndex, int charCount, byte[] bytes, int byteIndex);
override this.GetBytes : string * int * int * byte[] * int -> int
[<System.Runtime.InteropServices.ComVisible(false)>]
override this.GetBytes : string * int * int * byte[] * int -> int
Public Overrides Function GetBytes (s As String, charIndex As Integer, charCount As Integer, bytes As Byte(), byteIndex As Integer) As Integer
Parametreler
- charIndex
- Int32
Kodlanacak ilk karakterin dizini.
- charCount
- Int32
Kodlanacak karakter sayısı.
- bytes
- Byte[]
Elde edilen bayt dizisini içeren bayt dizisi.
- byteIndex
- Int32
Elde edilen bayt sırasını yazmaya başlanması gereken dizin.
Döndürülenler
içine yazılan bytesgerçek bayt sayısı.
- Öznitelikler
Özel durumlar
charIndex veya charCountbyteIndex sıfırdan küçüktür.
-veya-
charIndex ve charCount içinde sgeçerli bir aralığı ifade etmeyin.
-veya-
byteIndex içinde bytesgeçerli bir dizin değil.
bytes dizinin sonundan byteIndex elde edilen baytları barındırmak için yeterli kapasiteye sahip değil.
Bir geri dönüş oluştu (daha ayrıntılı açıklama için bkz. Character Encoding in .NET).
-ve-
EncoderFallback olarak ayarlanır EncoderExceptionFallback.
Örnekler
Aşağıdaki kod örneği, unicode karakter dizisindeki bir öğe aralığını kodlamak ve kodlanmış baytları bayt dizisindeki bir öğe aralığında depolamak için yönteminin nasıl kullanılacağını GetBytes gösterir.
using System;
using System.Text;
class UTF7EncodingExample {
public static void Main() {
Byte[] bytes;
// Unicode characters.
Char[] chars = new Char[] {
'\u0023', // #
'\u0025', // %
'\u03a0', // Pi
'\u03a3' // Sigma
};
UTF7Encoding utf7 = new UTF7Encoding();
int byteCount = utf7.GetByteCount(chars, 1, 2);
bytes = new Byte[byteCount];
int bytesEncodedCount = utf7.GetBytes(chars, 1, 2, bytes, 0);
Console.WriteLine(
"{0} bytes used to encode characters.", bytesEncodedCount
);
Console.Write("Encoded bytes: ");
foreach (Byte b in bytes) {
Console.Write("[{0}]", b);
}
Console.WriteLine();
}
}
Imports System.Text
Imports Microsoft.VisualBasic.strings
Class UTF7EncodingExample
Public Shared Sub Main()
Dim bytes() As Byte
' Unicode characters.
' ChrW(35) = #
' ChrW(37) = %
' ChrW(928) = Pi
' ChrW(931) = Sigma
Dim chars() As Char = {ChrW(35), ChrW(37), ChrW(928), ChrW(931)}
Dim utf7 As New UTF7Encoding()
Dim byteCount As Integer = utf7.GetByteCount(chars, 1, 2)
bytes = New Byte(byteCount - 1) {}
Dim bytesEncodedCount As Integer = utf7.GetBytes(chars, 1, 2, bytes, 0)
Console.WriteLine("{0} bytes used to encode characters.", bytesEncodedCount)
Console.Write("Encoded bytes: ")
Dim b As Byte
For Each b In bytes
Console.Write("[{0}]", b)
Next b
Console.WriteLine()
End Sub
End Class
Açıklamalar
Uygulama, tarafından elde edilen baytları depolamak için gereken GetBytes dizi boyutunu tam olarak hesaplamak için kullanır GetByteCount. En büyük dizi boyutunu hesaplamak için uygulama kullanmalıdır GetMaxByteCount. GetByteCount yöntemi genellikle daha az bellek ayırmaya izin verirken, GetMaxByteCount yöntem genellikle daha hızlı yürütülür.
Bir akıştan okunan veriler gibi dönüştürülecek veriler yalnızca sıralı bloklarda kullanılabilir. Bu durumda veya veri miktarı daha küçük bloklara bölünmesi gereken kadar büyükse, uygulama sırasıyla yöntemi veya yöntemi tarafından Decoder sağlanan veya öğesini kullanmalıdır.EncoderGetDecoderGetEncoder
Note
UTF7Encoding hata algılama sağlamaz. Geçersiz karakterler değiştirilmiş temel 64 karakter olarak kodlanmış. Güvenlik nedeniyle, uygulamalarınızın , UTF8Encodingveya UnicodeEncoding kullanmaları UTF32Encodingve hata algılamayı etkinleştirmeleri önerilir.