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
Imports System.Globalization
Imports Microsoft.VisualBasic

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 'Main 

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. Например, LATIN CAPITAL LETTER (U + 0041) и LATIN НЕБОЛЬШОЙ буквы 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. Например, примере LATIN ЗАГЛАВНОЙ буквы (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. Например SAUIL буквы GOTHIC (U + 10343) представляется в кодировку, что и старший символ-заместитель, значение которого равно 0xD800 и младшим символом-заместителем, значение которого равно 0xDF43 UTF-16.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.

TextElementEnumerator Класс позволяет работать с помощью элементов текста в строке, а не с одним Char объектов.The 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. Current Свойство возвращает один и тот же элемент текста, пока не будет вызван либо MoveNext или Reset.The 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 Представляет моментальный снимок текущего состояния строковой переменной или строковым литералом в данный момент, TextElementEnumerator создается экземпляр объекта.The 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 объект перечисляет текстовые элементы присутствуют в строке во время, TextElementEnumerator создания экземпляра объекта.A 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.

  • Так как TextElementEnumerator класс не переопределяет Object.Equals, два TextElementEnumerator объекты, представляющие та же строка будет считаться неравными.Because 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)

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

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