TextElementEnumerator TextElementEnumerator TextElementEnumerator TextElementEnumerator Class

Определение

Осуществляет нумерацию элементов текста в строке.Enumerates the text elements of a string.

public ref class TextElementEnumerator : System::Collections::IEnumerator
[System.Runtime.InteropServices.ComVisible(true)]
[System.Serializable]
public class TextElementEnumerator : System.Collections.IEnumerator
type TextElementEnumerator = class
    interface IEnumerator
Public Class TextElementEnumerator
Implements IEnumerator
Наследование
TextElementEnumeratorTextElementEnumeratorTextElementEnumeratorTextElementEnumerator
Атрибуты
Реализации

Примеры

В следующем примере TextElementEnumerator класс используется для перечисления текстовых элементов строки.The following example uses the TextElementEnumerator class to enumerate the text elements of a string.

using namespace System;
using namespace System::Globalization;
int main()
{
   
   // Creates and initializes a String containing the following:
   //   - a surrogate pair (high surrogate U+D800 and low surrogate U+DC00)
   //   - a combining character sequence (the Latin small letter S"a" followed by the combining grave accent)
   //   - a base character (the ligature S"")
   String^ myString = L"\xD800\xDC00"
   L"a\u0300\u00C6";
   
   // Creates and initializes a TextElementEnumerator for myString.
   TextElementEnumerator^ myTEE = StringInfo::GetTextElementEnumerator( myString );
   
   // Displays the values returned by ElementIndex, Current and GetTextElement.
   // Current and GetTextElement return a String* containing the entire text element. 
   Console::WriteLine( "Index\tCurrent\tGetTextElement" );
   myTEE->Reset();
   while ( myTEE->MoveNext() )
      Console::WriteLine( "[{0}]:\t {1}\t {2}", myTEE->ElementIndex, myTEE->Current, myTEE->GetTextElement() );
}

/*
This code produces the following output.  The question marks take the place of high and low surrogates.

Index   Current GetTextElement
[0]:    ??      ??
[2]:    a`      a`
[4]:    Æ       Æ

*/
using System;
using System.Globalization;


public class SamplesTextElementEnumerator  {

   public static void Main()  {

      // Creates and initializes a String containing the following:
      //   - a surrogate pair (high surrogate U+D800 and low surrogate U+DC00)
      //   - a combining character sequence (the Latin small letter "a" followed by the combining grave accent)
      //   - a base character (the ligature "")
      String myString = "\uD800\uDC00\u0061\u0300\u00C6";

      // Creates and initializes a TextElementEnumerator for myString.
      TextElementEnumerator myTEE = StringInfo.GetTextElementEnumerator( myString );

      // Displays the values returned by ElementIndex, Current and GetTextElement.
      // Current and GetTextElement return a string containing the entire text element. 
      Console.WriteLine( "Index\tCurrent\tGetTextElement" );
      myTEE.Reset();
      while (myTEE.MoveNext())  {
         Console.WriteLine( "[{0}]:\t{1}\t{2}", myTEE.ElementIndex, myTEE.Current, myTEE.GetTextElement() );
      }

   }

}

/*
This code produces the following output.  The question marks take the place of high and low surrogates.

Index   Current GetTextElement
[0]:    ??      ??
[2]:    a`      a`
[4]:    Æ       Æ

*/
Imports System.Globalization

Public Class SamplesTextElementEnumerator

   Public Shared Sub Main()

      ' Creates and initializes a String containing the following:
      '   - a surrogate pair (high surrogate U+D800 and low surrogate U+DC00)
      '   - a combining character sequence (the Latin small letter "a" followed by the combining grave accent)
      '   - a base character (the ligature "")
      Dim myString As String = ChrW(&HD800) & ChrW(&HDC00) & ChrW(&H0061) & ChrW(&H0300) & ChrW(&H00C6)

      ' Creates and initializes a TextElementEnumerator for myString.
      Dim myTEE As TextElementEnumerator = StringInfo.GetTextElementEnumerator( myString )

      ' Displays the values returned by ElementIndex, Current and GetTextElement.
      ' Current and GetTextElement return a string containing the entire text element. 
      Console.WriteLine("Index" + ControlChars.Tab + "Current" + ControlChars.Tab + "GetTextElement")
      myTEE.Reset()
      While myTEE.MoveNext()
         Console.WriteLine("[{0}]:" + ControlChars.Tab + "{1}" + ControlChars.Tab + "{2}", myTEE.ElementIndex, myTEE.Current, myTEE.GetTextElement())
      End While

   End Sub

End Class 'SamplesTextElementEnumerator

'This code produces the following output.  The question marks take the place of high and low surrogates.
'
'Index   Current GetTextElement
'[0]:    ??      ??
'[2]:    a`      a`
'[4]:    Æ       Æ

Комментарии

.NET Framework определяет текстовый элемент как единицу текста, который отображается как один символ, то есть графеме.The .NET Framework defines a text element as a unit of text that is displayed as a single character, that is, a grapheme. Текстовый элемент может быть любым из следующих:A text element can be any of the following:

  • Базовый символ, представленный как одно Char значение.A base character, which is represented as a single Char value. Например, Латинская ПРОПИСная БУКВа A (U + 0041) и Латинская маленькая БУКВа AE (U + 00E6) являются базовыми символами.For example, LATIN CAPITAL LETTER A (U+0041) and LATIN SMALL LETTER AE (U+00E6) are base characters.

  • Последовательность несамостоятельных символов, состоящая из базового символа и одного или нескольких Объединенных символов.A combining character sequence, which consists of a base character and one or more combining characters. Например, Латинская ПРОПИСная БУКВа A (U + 0041), за которой следует сочетание МАКРОН (U + 0304), является сочетанием последовательности символов.For example, example, LATIN CAPITAL LETTER A (U+0041) followed by COMBINING MACRON (U+0304) is a combining character sequence.

  • Суррогатные пары, которые Стандарт Юникода определяет как закодированное символьное представление для одного абстрактного символа, состоящего из последовательности двух единиц кода: старший суррогат и младший суррогат.Surrogate pairs, which the Unicode Standard defines as a coded character representation for a single abstract character that consists of a sequence of two code units: a high surrogate, and a low surrogate. Суррогатные пары используются для представления символов за пределами многоязычной многоязыковой панели Юникода как символов в кодировке UTF-16.Surrogate pairs are used to represent characters outside of the Unicode Basic Multilingual Plane as UTF-16 encoded characters. Например, готическая БУКВа САУИЛ (U + 10343) представлена в кодировке UTF-16 как старший суррогат со значением 0xD800 и младшим суррогатом, значение которого равно 0xDF43.For example, GOTHIC LETTER SAUIL (U+10343) is represented in UTF-16 encoding as a high surrogate whose value is 0xD800 and a low surrogate whose value is 0xDF43. Суррогатная пара может представлять собой базовый символ или присоединяемый символ.A surrogate pair can represent a base character or a combining character.

Класс позволяет работать с текстовыми элементами в строке, а не с отдельными Char объектами. TextElementEnumeratorThe TextElementEnumerator class allows you to work with the text elements in a string rather than with single Char objects.

Вы создаете экземпляр TextElementEnumerator объекта, который представляет определенную строку, передавая строку StringInfo.GetTextElementEnumerator в метод.You instantiate a TextElementEnumerator object that represents a particular string by passing the string to the StringInfo.GetTextElementEnumerator method. Он возвращает перечислитель, расположенный перед первым текстовым элементом в строке.This returns an enumerator that is positioned before the first text element in the string. При вызове Reset метода перечислитель возвращается в эту точку.Calling the Reset method also brings the enumerator back to this position. Поскольку представляет недопустимое состояние, необходимо вызвать метод MoveNext , чтобы переместить перечислитель к первому текстовому элементу строки перед считыванием значения Current свойства для возврата текущего текстового элемента.Because this represents an invalid state, you must call MoveNext to advance the enumerator to the first text element of the string before reading the value of the Current property to return the current text element.

При работе с TextElementEnumerator объектом вы несете ответственность за размещение перечислителя.When working with a TextElementEnumerator object, you are responsible for positioning the enumerator. Свойство возвращает тот же текстовый элемент, пока не будет MoveNext вызван метод Resetили. CurrentThe Current property returns the same text element until you call either MoveNext or Reset. Перечислитель находится в недопустимом состоянии, если он расположен перед первым текстовым элементом или после последнего текстового элемента в строке.The enumerator is in an invalid state if it is positioned before the first text element or after the last text element in the string. Если перечислитель находится в недопустимом состоянии, попытка получить значение Current свойства вызывает исключение.When the enumerator is in an invalid state, attempting to retrieve the value of the Current property throws an exception. Можно определить, находится ли перечислитель в недопустимом состоянии, проверив, является MoveNext falseли возвращаемое значение свойства.You can determine whether the enumerator is in an invalid state by testing whether the return value of the MoveNext property is false.

Объект представляет моментальный снимок текущего состояния строковой переменной или строкового литерала в момент TextElementEnumerator создания экземпляра объекта. TextElementEnumeratorThe TextElementEnumerator object represents a snapshot of the current state of a string variable or string literal at the moment that the TextElementEnumerator object is instantiated. Обратите внимание на следующее.Note that:

  • Перечислители с текстовыми элементами могут использоваться только для чтения данных в строке.Text element enumerators can only be used to read data in a string. Они не могут изменять базовую строку.They cannot modify the underlying string.

  • Перечислитель не имеет монопольного доступа к строке, которую он представляет.An enumerator does not have exclusive access to the string that it represents. Строковая переменная может быть изменена после создания перечислителя.A string variable can be modified after the enumerator is created.

  • Объект перечисляет текстовые элементы, TextElementEnumerator содержащиеся в строке, на момент создания экземпляра объекта. TextElementEnumeratorA TextElementEnumerator object enumerates the text elements present in the string at the time that the TextElementEnumerator object was instantiated. Он не отражает последующие изменения строковой переменной, если эта переменная изменяется позже.It does not reflect any subsequent changes to the string variable if that variable is modified afterward.

  • Поскольку класс не переопределяется Object.Equals, два TextElementEnumerator объекта, представляющие одну и ту же строку, будут считаться неравными. TextElementEnumeratorBecause the TextElementEnumerator class does not override Object.Equals, two TextElementEnumerator objects that represent the same string will be considered unequal.

Свойства

Current Current Current Current

Возвращает текущий текстовый элемент строки.Gets the current text element in the string.

ElementIndex ElementIndex ElementIndex ElementIndex

Возвращает индекс текстового элемента, на котором в настоящий момент помещен перечислитель.Gets the index of the text element that the enumerator is currently positioned over.

Методы

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

Определяет, равен ли заданный объект текущему объекту.Determines whether the specified object is equal to the current object.

(Inherited from Object)
GetHashCode() GetHashCode() GetHashCode() GetHashCode()

Служит хэш-функцией по умолчанию.Serves as the default hash function.

(Inherited from Object)
GetTextElement() GetTextElement() GetTextElement() GetTextElement()

Возвращает текущий текстовый элемент строки.Gets the current text element in the string.

GetType() GetType() GetType() GetType()

Возвращает объект Type для текущего экземпляра.Gets the Type of the current instance.

(Inherited from Object)
MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

Создает неполную копию текущего объекта Object.Creates a shallow copy of the current Object.

(Inherited from Object)
MoveNext() MoveNext() MoveNext() MoveNext()

Перемещает перечислитель на следующий текстовый элемент строки.Advances the enumerator to the next text element of the string.

Reset() Reset() Reset() Reset()

Перемещает перечислитель в исходное положение, перед первым текстовым элементом в строке.Sets the enumerator to its initial position, which is before the first text element in the string.

ToString() ToString() ToString() ToString()

Возвращает строку, представляющую текущий объект.Returns a string that represents the current object.

(Inherited from Object)

Применяется к

Дополнительно