UnicodeEncoding Constructors

Definitie

Initialiseert een nieuw exemplaar van de UnicodeEncoding klasse.

Overloads

Name Description
UnicodeEncoding()

Initialiseert een nieuw exemplaar van de UnicodeEncoding klasse.

UnicodeEncoding(Boolean, Boolean)

Initialiseert een nieuw exemplaar van de UnicodeEncoding klasse. Parameters geven aan of de big endian bytevolgorde moet worden gebruikt en of de GetPreamble() methode een Unicode-bytevolgordemarkering retourneert.

UnicodeEncoding(Boolean, Boolean, Boolean)

Initialiseert een nieuw exemplaar van de UnicodeEncoding klasse. Parameters geven aan of de big endian-bytevolgorde moet worden gebruikt, of een Unicode-bytevolgorde moet worden opgegeven en of er een uitzondering moet worden gegenereerd wanneer een ongeldige codering wordt gedetecteerd.

UnicodeEncoding()

Initialiseert een nieuw exemplaar van de UnicodeEncoding klasse.

public:
 UnicodeEncoding();
public UnicodeEncoding();
Public Sub New ()

Voorbeelden

In het volgende voorbeeld ziet u hoe u een nieuw UnicodeEncoding exemplaar maakt en de naam van de codering weergeeft.

using System;
using System.Text;

class UnicodeEncodingExample {
    public static void Main() {
        UnicodeEncoding unicode = new UnicodeEncoding();
        String encodingName = unicode.EncodingName;
        Console.WriteLine("Encoding name: " + encodingName);
    }
}
Imports System.Text

Class UnicodeEncodingExample

    Public Shared Sub Main()
        Dim uni As New UnicodeEncoding()
        Dim encodingName As String = uni.EncodingName
        Console.WriteLine("Encoding name: " & encodingName)
    End Sub
End Class

Opmerkingen

Met deze constructor wordt een exemplaar gemaakt dat gebruikmaakt van de little endian bytevolgorde, een Unicode-bytevolgorde markeert en geen uitzondering genereert wanneer er een ongeldige codering wordt gedetecteerd.

Caution

Om veiligheidsredenen moet u foutdetectie inschakelen door de UnicodeEncoding(Boolean, Boolean, Boolean) constructor aan te roepen en het argument in throwOnInvalidBytes te stellen op true.

Van toepassing op

UnicodeEncoding(Boolean, Boolean)

Initialiseert een nieuw exemplaar van de UnicodeEncoding klasse. Parameters geven aan of de big endian bytevolgorde moet worden gebruikt en of de GetPreamble() methode een Unicode-bytevolgordemarkering retourneert.

public:
 UnicodeEncoding(bool bigEndian, bool byteOrderMark);
public UnicodeEncoding(bool bigEndian, bool byteOrderMark);
new System.Text.UnicodeEncoding : bool * bool -> System.Text.UnicodeEncoding
Public Sub New (bigEndian As Boolean, byteOrderMark As Boolean)

Parameters

bigEndian
Boolean

true om de big endian bytevolgorde te gebruiken (meest significante byte eerst) of false om de kleine endian bytevolgorde te gebruiken (minst significante byte eerst).

byteOrderMark
Boolean

trueom op te geven dat de GetPreamble() methode een Unicode-bytevolgordemarkering retourneert; anders. false

Voorbeelden

In het volgende voorbeeld ziet u hoe u een nieuw UnicodeEncoding exemplaar maakt waarin wordt aangegeven of kleine endian- of big endian bytevolgorde en het Unicode-bytevolgordeteken moeten worden ondersteund.

using System;
using System.Text;

class UnicodeEncodingExample {
    public static void Main() {

        // Create a UnicodeEncoding without parameters.
        UnicodeEncoding unicode = new UnicodeEncoding();

        // Create a UnicodeEncoding to support little-endian byte ordering
        // and include the Unicode byte order mark.
        UnicodeEncoding unicodeLittleEndianBOM = 
            new UnicodeEncoding(false, true);
        // Compare this UnicodeEncoding to the UnicodeEncoding without parameters.
        DescribeEquivalence(unicode.Equals(unicodeLittleEndianBOM));

        // Create a UnicodeEncoding to support little-endian byte ordering
        // and not include the Unicode byte order mark.
        UnicodeEncoding unicodeLittleEndianNoBOM =
            new UnicodeEncoding(false, false);
        // Compare this UnicodeEncoding to the UnicodeEncoding without parameters.
        DescribeEquivalence(unicode.Equals(unicodeLittleEndianNoBOM));

        // Create a UnicodeEncoding to support big-endian byte ordering
        // and include the Unicode byte order mark.
        UnicodeEncoding unicodeBigEndianBOM =
            new UnicodeEncoding(true, true);
        // Compare this UnicodeEncoding to the UnicodeEncoding without parameters.
        DescribeEquivalence(unicode.Equals(unicodeBigEndianBOM));

        // Create a UnicodeEncoding to support big-endian byte ordering
        // and not include the Unicode byte order mark.
        UnicodeEncoding unicodeBigEndianNoBOM =
            new UnicodeEncoding(true, false);
        // Compare this UnicodeEncoding to the UnicodeEncoding without parameters.
        DescribeEquivalence(unicode.Equals(unicodeBigEndianNoBOM));
    }

    public static void DescribeEquivalence(Boolean isEquivalent) {
        Console.WriteLine(
            "{0} equivalent encoding.", (isEquivalent ? "An" : "Not an")
        );
    }
}
Imports System.Text

Class UnicodeEncodingExample
    
    Public Shared Sub Main()

        ' Create a UnicodeEncoding without parameters.
        Dim unicodeDefault As New UnicodeEncoding()

        ' Create a UnicodeEncoding to support little-endian byte ordering
        ' and include the Unicode byte order mark.        
        Dim unicodeLittleEndianBOM As New UnicodeEncoding(False, True)
        ' Compare this UnicodeEncoding to the UnicodeEncoding without parameters.
        DescribeEquivalence(unicodeDefault.Equals(unicodeLittleEndianBOM))
        
        ' Create a UnicodeEncoding to support little-endian byte ordering
        ' and not include the Unicode byte order mark.
        Dim unicodeLittleEndianNoBOM As New UnicodeEncoding(False, False)
        ' Compare this UnicodeEncoding to the UnicodeEncoding without parameters.
        DescribeEquivalence(unicodeDefault.Equals(unicodeLittleEndianNoBOM))
        
        ' Create a UnicodeEncoding to support big-endian byte ordering
        ' and include the Unicode byte order mark.
        Dim unicodeBigEndianBOM As New UnicodeEncoding(True, True)
        ' Compare this UnicodeEncoding to the UnicodeEncoding without parameters.
        DescribeEquivalence(unicodeDefault.Equals(unicodeBigEndianBOM))
        
        ' Create a UnicodeEncoding to support big-endian byte ordering
        ' and not include the Unicode byte order mark.
        Dim unicodeBigEndianNoBOM As New UnicodeEncoding(True, False)
        ' Compare this UnicodeEncoding to the UnicodeEncoding without parameters.
        DescribeEquivalence(unicodeDefault.Equals(unicodeBigEndianNoBOM))
    End Sub
    
    
    Public Shared Sub DescribeEquivalence(isEquivalent As Boolean)
        Dim phrase as String
        If isEquivalent Then
            phrase = "An"
        Else
            phrase = "Not an"
        End If
        Console.WriteLine("{0} equivalent encoding.", phrase)
    End Sub
End Class

Opmerkingen

Met deze constructor wordt een exemplaar gemaakt dat geen uitzondering genereert wanneer een ongeldige codering wordt gedetecteerd.

Caution

Om veiligheidsredenen moet u foutdetectie inschakelen door de UnicodeEncoding(Boolean, Boolean, Boolean) constructor aan te roepen en het argument in throwOnInvalidBytes te stellen op true.

De byteOrderMark parameter bepaalt de werking van de GetPreamble methode. Als true, de methode retourneert een bytematrix met de Unicode byte order mark (BOM) in UTF-16-indeling. Als false, retourneert het een bytematrix met lengte nul. Als byteOrderMarktrue u deze instelling echter niet veroorzaakt, wordt de stuklijst aan het begin van de bytematrix voorafgegaan door de GetBytes methode en wordt het GetByteCount aantal bytes in de stuklijst in het byteaantal opgenomen.

Zie ook

Van toepassing op

UnicodeEncoding(Boolean, Boolean, Boolean)

Initialiseert een nieuw exemplaar van de UnicodeEncoding klasse. Parameters geven aan of de big endian-bytevolgorde moet worden gebruikt, of een Unicode-bytevolgorde moet worden opgegeven en of er een uitzondering moet worden gegenereerd wanneer een ongeldige codering wordt gedetecteerd.

public:
 UnicodeEncoding(bool bigEndian, bool byteOrderMark, bool throwOnInvalidBytes);
public UnicodeEncoding(bool bigEndian, bool byteOrderMark, bool throwOnInvalidBytes);
new System.Text.UnicodeEncoding : bool * bool * bool -> System.Text.UnicodeEncoding
Public Sub New (bigEndian As Boolean, byteOrderMark As Boolean, throwOnInvalidBytes As Boolean)

Parameters

bigEndian
Boolean

true om de big endian bytevolgorde te gebruiken (de belangrijkste byte eerst); false om de bytevolgorde little endian te gebruiken (minst significante byte eerst).

byteOrderMark
Boolean

trueom op te geven dat de GetPreamble() methode een Unicode-bytevolgordemarkering retourneert; anders. false

throwOnInvalidBytes
Boolean

true om op te geven dat er een uitzondering moet worden gegenereerd wanneer er een ongeldige codering wordt gedetecteerd; anders, false.

Voorbeelden

In het volgende voorbeeld ziet u het gedrag van UnicodeEncoding, zowel met foutdetectie ingeschakeld als zonder.

using System;
using System.Text;

public class SamplesUnicodeEncoding  {

   public static void Main()  {

      // Create an instance of UnicodeEncoding using little-endian byte order.
      // This will be used for encoding.
      UnicodeEncoding u16LE     = new UnicodeEncoding( false, true );

      // Create two instances of UnicodeEncoding using big-endian byte order: one with error detection and one without.
      // These will be used for decoding.
      UnicodeEncoding u16withED = new UnicodeEncoding( true, true, true );
      UnicodeEncoding u16noED   = new UnicodeEncoding( true, true, false );

      // Create byte arrays from the same string containing the following characters:
      //    Latin Small Letter Z (U+007A)
      //    Latin Small Letter A (U+0061)
      //    Combining Breve (U+0306)
      //    Latin Small Letter AE With Acute (U+01FD)
      //    Greek Small Letter Beta (U+03B2)
      //    Latin Capital Letter U with  Diaeresis (U+00DC)
      String myStr = "za\u0306\u01FD\u03B2\u00DC";

      // Encode the string using little-endian byte order.
      byte[] myBytes = new byte[u16LE.GetByteCount( myStr )];
      u16LE.GetBytes( myStr, 0, myStr.Length, myBytes, 0 );

      // Decode the byte array with error detection.
      Console.WriteLine( "Decoding with error detection:" );
      PrintDecodedString( myBytes, u16withED );

      // Decode the byte array without error detection.
      Console.WriteLine( "Decoding without error detection:" );
      PrintDecodedString( myBytes, u16noED );
   }

   // Decode the bytes and display the string.
   public static void PrintDecodedString( byte[] bytes, Encoding enc )  {

      try  {
         Console.WriteLine( "   Decoded string: {0}", enc.GetString( bytes, 0, bytes.Length ) );
      }
      catch ( System.ArgumentException e )  {
         Console.WriteLine( e.ToString() );
      }

      Console.WriteLine();
   }
}
Imports System.Text

Public Class SamplesUnicodeEncoding   

   Public Shared Sub Main()

      ' Create an instance of UnicodeEncoding using little-endian byte order.
      ' This will be used for encoding.
      Dim u16LE As New UnicodeEncoding(False, True)

      ' Create two instances of UnicodeEncoding using big-endian byte order: one with error detection and one without.
      ' These will be used for decoding.
      Dim u16withED As New UnicodeEncoding(True, True, True)
      Dim u16noED As New UnicodeEncoding(True, True, False)

      ' Create byte arrays from the same string containing the following characters:
      '    Latin Small Letter Z (U+007A)
      '    Latin Small Letter A (U+0061)
      '    Combining Breve (U+0306)
      '    Latin Small Letter AE With Acute (U+01FD)
      '    Greek Small Letter Beta (U+03B2)
      '    Latin Capital Letter U with  Diaeresis (U+00DC)
      Dim myStr As String = "za" & ChrW(&H0306) & ChrW(&H01FD) & ChrW(&H03B2) & ChrW(&H00DC)

      ' Encode the string using little-endian byte order.
      Dim myBytes(u16LE.GetByteCount(myStr)) As Byte
      u16LE.GetBytes(myStr, 0, myStr.Length, myBytes, 0)

      ' Decode the byte array with error detection.
      Console.WriteLine("Decoding with error detection:")
      PrintDecodedString(myBytes, u16withED)

      ' Decode the byte array without error detection.
      Console.WriteLine("Decoding without error detection:")
      PrintDecodedString(myBytes, u16noED)

   End Sub


   ' Decode the bytes and display the string.
   Public Shared Sub PrintDecodedString(bytes() As Byte, enc As Encoding)

      Try
         Console.WriteLine("   Decoded string: {0}", enc.GetString(bytes, 0, bytes.Length))
      Catch e As System.ArgumentException
         Console.WriteLine(e.ToString())
      End Try

      Console.WriteLine()

   End Sub

End Class

Opmerkingen

De byteOrderMark parameter bepaalt de werking van de GetPreamble methode. Als true, de methode retourneert een bytematrix met de Unicode byte order mark (BOM) in UTF-16-indeling. Als false, retourneert het een bytematrix met lengte nul. Als byteOrderMarktrue u deze instelling echter niet veroorzaakt, wordt de stuklijst aan het begin van de bytematrix voorafgegaan door de GetBytes methode en wordt het GetByteCount aantal bytes in de stuklijst in het byteaantal opgenomen.

Als de throwOnInvalidBytes parameter is true, een methode die een ongeldige bytevolgorde detecteert, genereert System.ArgumentException. Anders genereert de methode geen uitzondering en wordt de ongeldige reeks genegeerd.

Caution

Om veiligheidsredenen moet u deze constructor gebruiken om een exemplaar van de UnicodeEncoding klasse te maken en foutdetectie in te schakelen door in te stellen throwOnInvalidBytes op true.

Zie ook

Van toepassing op