BreakIterator Klasse

Definition

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

[Android.Runtime.Register("java/text/BreakIterator", DoNotGenerateAcw=true)]
public abstract class BreakIterator : Java.Lang.Object, IDisposable, Java.Interop.IJavaPeerable, Java.Lang.ICloneable
[<Android.Runtime.Register("java/text/BreakIterator", DoNotGenerateAcw=true)>]
type BreakIterator = class
    inherit Object
    interface ICloneable
    interface IJavaObject
    interface IDisposable
    interface IJavaPeerable
Vererbung
BreakIterator
Attribute
Implementiert

Hinweise

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text. Instanzen von BreakIterator behalten eine aktuelle Position bei und scannen Text, die den Index der Zeichen zurückgeben, in denen Grenzen auftreten. Intern scannt Text mit einem CharacterIteratorund ist somit in der Lage, Text zu scannen, BreakIterator der von jedem Objekt gespeichert ist, das dieses Protokoll implementiert. Ein StringCharacterIterator wird verwendet, um an übergebene Objekte zu setTextüberprüfenString. Das CharacterIterator -Objekt darf nicht geändert werden, nachdem an setTextübergeben wurde. Wenn der Text im CharacterIterator -Objekt geändert wird, muss der Aufrufer durch Aufrufen setTextvon zurücksetzenBreakIterator.

Sie verwenden die von dieser Klasse bereitgestellten Factorymethoden, um Instanzen verschiedener Typen von Unterbrechungsiteratoren zu erstellen. Verwenden Sie getWordInstanceinsbesondere , getLineInstance, getSentenceInstanceund getCharacterInstance , um s zu erstellen BreakIterator, die eine Analyse der Wörter-, Zeilen-, Satz- und Zeichengrenzen durchführen. Ein einzelner BreakIterator kann nur für eine Einheit (Wort, Zeile, Satz usw.) verwendet werden. Sie müssen für jede Analyse der Einheitengrenzen, die Sie durchführen möchten, einen anderen Iterator verwenden.

> Die Linienbegrenzungsanalyse bestimmt, wo eine Textzeichenfolge beim Zeilenumbruch unterbrochen werden kann. Der Mechanismus behandelt Interpunktionszeichen und Bindestriche ordnungsgemäß. Der tatsächliche Zeilenumbruch muss auch die verfügbare Linienbreite berücksichtigen und wird von höherer Software behandelt.

> Die Satzbegrenzungsanalyse ermöglicht die Auswahl mit korrekter Interpretation von Punkten innerhalb von Zahlen und Abkürzungen sowie nachfolgenden Satzzeichen wie Anführungszeichen und Klammern.

"Wort"> Word Begrenzungsanalyse wird von Such- und Ersetzungsfunktionen sowie in Textbearbeitungsanwendungen verwendet, die es dem Benutzer ermöglichen, Wörter mit einem Doppelklick auszuwählen. Word Auswahl bietet eine korrekte Interpretation von Satzzeichen in und folgenden Wörtern. Zeichen, die nicht Teil eines Worts sind, z. B. Symbole oder Satzzeichen, weisen auf beiden Seiten Wortumbrüche auf.

> Die Zeichenbegrenzungsanalyse ermöglicht es Benutzern, mit Zeichen wie erwartet zu interagieren, z. B. beim Bewegen des Cursors durch eine Textzeichenfolge. Die Zeichenbegrenzungsanalyse ermöglicht eine korrekte Navigation durch Zeichenfolgen, unabhängig davon, wie das Zeichen gespeichert wird. Die zurückgegebenen Grenzen können die von ergänzenden Zeichen sein, die Zeichenfolgen oder Ligaturcluster kombinieren. Beispielsweise kann ein akzentiertes Zeichen als Basiszeichen und diakritische Zeichen gespeichert werden. Was Benutzer als Zeichen betrachten, kann sich in den verschiedenen Sprachen unterscheiden.

Die BreakIterator von den Factorymethoden dieser Klasse zurückgegebenen Instanzen sind nur für die Verwendung mit natürlichen Sprachen und nicht für Programmiersprachetext vorgesehen. Es ist jedoch möglich, Unterklassen zu definieren, die eine Programmiersprache tokenisieren.

<strong>Examples</strong>:

Erstellen und Verwenden von Textgrenzen: <blockquote>

public static void main(String args[]) {
                 if (args.length == 1) {
                     String stringToExamine = args[0];
                     //print each word in order
                     BreakIterator boundary = BreakIterator.getWordInstance();
                     boundary.setText(stringToExamine);
                     printEachForward(boundary, stringToExamine);
                     //print each sentence in reverse order
                     boundary = BreakIterator.getSentenceInstance(Locale.US);
                     boundary.setText(stringToExamine);
                     printEachBackward(boundary, stringToExamine);
                     printFirst(boundary, stringToExamine);
                     printLast(boundary, stringToExamine);
                 }
            }

</Blockquote>

Jedes Element in der Reihenfolge drucken: <blockquote>

public static void printEachForward(BreakIterator boundary, String source) {
                int start = boundary.first();
                for (int end = boundary.next();
                     end != BreakIterator.DONE;
                     start = end, end = boundary.next()) {
                     System.out.println(source.substring(start,end));
                }
            }

</Blockquote>

Drucken jedes Elements in umgekehrter Reihenfolge: <blockquote>

public static void printEachBackward(BreakIterator boundary, String source) {
                int end = boundary.last();
                for (int start = boundary.previous();
                     start != BreakIterator.DONE;
                     end = start, start = boundary.previous()) {
                    System.out.println(source.substring(start,end));
                }
            }

</Blockquote>

Erstes Element drucken: <blockquote>

public static void printFirst(BreakIterator boundary, String source) {
                int start = boundary.first();
                int end = boundary.next();
                System.out.println(source.substring(start,end));
            }

</Blockquote>

Letztes Element drucken: <blockquote>

public static void printLast(BreakIterator boundary, String source) {
                int end = boundary.last();
                int start = boundary.previous();
                System.out.println(source.substring(start,end));
            }

</Blockquote>

Drucken des Elements an einer angegebenen Position: <blockquote>

public static void printAt(BreakIterator boundary, int pos, String source) {
                int end = boundary.following(pos);
                int start = boundary.previous();
                System.out.println(source.substring(start,end));
            }

</Blockquote>

Suchen Sie das nächste Wort: <blockquote>

{@code
            public static int nextWordStartAfter(int pos, String text) {
                BreakIterator wb = BreakIterator.getWordInstance();
                wb.setText(text);
                int last = wb.following(pos);
                int current = wb.next();
                while (current != BreakIterator.DONE) {
                    for (int p = last; p < current; p++) {
                        if (Character.isLetter(text.codePointAt(p)))
                            return last;
                    }
                    last = current;
                    current = wb.next();
                }
                return BreakIterator.DONE;
            }
            }

(Der von BreakIterator.getWordInstance() zurückgegebene Iterator ist eindeutig, da die zurückgegebenen Umbruchpositionen nicht sowohl den Anfang als auch das Ende der durchlaufenen Sache darstellen. Das heißt, ein Satzumbruch-Iterator gibt Umbrüche zurück, die jeweils das Ende eines Satzes und den Anfang des nächsten darstellen. Mit dem Wörterumbruch-Iterator können die Zeichen zwischen zwei Begrenzungen ein Wort sein, oder es kann sich um die Interpunktion oder den Leerraum zwischen zwei Wörtern handeln. Der obige Code verwendet eine einfache Heuristik, um zu bestimmen, welche Grenze der Anfang eines Worts ist: Wenn die Zeichen zwischen dieser Grenze und der nächsten Grenze mindestens einen Buchstaben enthalten (dies kann ein alphabetischer Buchstabe, ein CJK-Ideograph, eine Hangul-Silbe, ein Kana-Zeichen usw.), dann ist der Text zwischen dieser Grenze und dem nächsten ein Wort; Andernfalls ist es das Material zwischen Wörtern.) </Blockquote>

In Version 1.1 hinzugefügt.

Java-Dokumentation für java.text.BreakIterator.

Teile dieser Seite sind Änderungen, die auf Arbeiten basieren, die vom Android Open Source Project erstellt und freigegeben wurden und gemäß den In Attribution License beschriebenen Begriffen verwendet werden.

Konstruktoren

BreakIterator()

Konstruktor.

BreakIterator(IntPtr, JniHandleOwnership)

Ein Konstruktor, der beim Erstellen verwalteter Darstellungen von JNI-Objekten verwendet wird; wird von der Runtime aufgerufen.

Felder

Done

DONE wird von previous(), next(), next(int), previous(int) und following(int) zurückgegeben, wenn entweder die erste oder die letzte Textgrenze erreicht wurde.

Eigenschaften

CharacterInstance

Gibt eine neue BreakIterator instance für Zeichenumbrüche für das Standardgebietsschema Locale#getDefault() zurück.

Class

Gibt die Laufzeitklasse dieses Objectzurück.

(Geerbt von Object)
Handle

Das Handle für die zugrunde liegende Android-instance.

(Geerbt von Object)
JniIdentityHashCode

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

(Geerbt von Object)
JniPeerMembers

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

LineInstance

Gibt einen neuen BreakIterator instance für Zeilenumbrüche für das Standardgebietsschema Locale#getDefault() zurück.

PeerReference

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

(Geerbt von Object)
SentenceInstance

Gibt eine neue BreakIterator instance für Satzumbrüche für das Standardgebietsschema Locale#getDefault() zurück.

Text

Gibt einen CharacterIterator zurück, der den analysierten Text darstellt.

ThresholdClass

Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen.

ThresholdType

Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen.

WordInstance

Gibt eine neue BreakIterator instance für Wortumbrüche für das Standardgebietsschema Locale#getDefault() zurück.

Methoden

Clone()

Erstellen einer Kopie dieses Iterators

Current()

Gibt den Zeichenindex der Textgrenze zurück, die zuletzt von next(), next(int), previous(), first(), last(), following(int) oder previous(int) zurückgegeben wurde.

Dispose()

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

(Geerbt von Object)
Dispose(Boolean)

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

(Geerbt von Object)
Equals(Object)

Gibt an, ob ein anderes Objekt "gleich" diesem objekt ist.

(Geerbt von Object)
First()

Gibt die erste Grenze zurück.

Following(Int32)

Gibt die erste Grenze nach dem angegebenen Zeichenoffset zurück.

GetAvailableLocales()

Gibt ein Array aller Gebietsschemas zurück, für die die get*Instance Methoden dieser Klasse lokalisierte Instanzen zurückgeben können.

GetCharacterInstance(Locale)

Gibt einen neuen BreakIterator instance für Zeichenumbrüche für das angegebene Gebietsschema zurück.

GetHashCode()

Gibt einen Hashcodewert für das Objekt zurück.

(Geerbt von Object)
GetLineInstance(Locale)

Gibt einen neuen BreakIterator instance für Zeilenumbrüche für das angegebene Gebietsschema zurück.

GetSentenceInstance(Locale)

Gibt einen neuen BreakIterator instance für Satzumbrüche für das angegebene Gebietsschema zurück.

GetWordInstance(Locale)

Gibt eine neue BreakIterator instance für Wortumbrüche für das angegebene Gebietsschema zurück.

IsBoundary(Int32)

Gibt true zurück, wenn der angegebene Zeichenoffset eine Textgrenze ist.

JavaFinalize()

Wird vom Garbage Collector für ein Objekt aufgerufen, wenn die Garbage Collection feststellt, dass keine Verweise mehr auf das Objekt vorhanden sind.

(Geerbt von Object)
Last()

Gibt die letzte Grenze zurück.

Next()

Gibt die Grenze zurück, die der aktuellen Grenze folgt.

Next(Int32)

Gibt die n-te Grenze von der aktuellen Grenze zurück.

Notify()

Aktiviert einen einzelnen Thread, der auf den Monitor dieses Objekts wartet.

(Geerbt von Object)
NotifyAll()

Aktiviert alle Threads, die auf den Monitor dieses Objekts warten.

(Geerbt von Object)
Preceding(Int32)

Gibt die letzte Grenze vor dem angegebenen Zeichenoffset zurück.

Previous()

Gibt die Grenze zurück, die der aktuellen Grenze vorangeht.

SetHandle(IntPtr, JniHandleOwnership)

Legt die Handle-Eigenschaft fest.

(Geerbt von Object)
SetText(String)

Legen Sie eine neue Textzeichenfolge fest, die gescannt werden soll.

ToArray<T>()

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

(Geerbt von Object)
ToString()

Gibt eine Zeichenfolgendarstellung des Objekts zurück.

(Geerbt von Object)
UnregisterFromRuntime()

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

(Geerbt von Object)
Wait()

Bewirkt, dass der aktuelle Thread wartet, bis er aktiviert ist, in der Regel durch <>Benachrichtigung</em> oder <em>interrupted</em>.

(Geerbt von Object)
Wait(Int64)

Bewirkt, dass der aktuelle Thread wartet, bis er aktiviert ist, in der Regel durch>< Benachrichtigung</em> oder <em>interrupted</em>, oder bis eine bestimmte Menge an Echtzeit verstrichen ist.

(Geerbt von Object)
Wait(Int64, Int32)

Bewirkt, dass der aktuelle Thread wartet, bis er aktiviert ist, in der Regel durch>< Benachrichtigung</em> oder <em>interrupted</em>, oder bis eine bestimmte Menge an Echtzeit verstrichen ist.

(Geerbt von Object)

Explizite Schnittstellenimplementierungen

IJavaPeerable.Disposed()

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

(Geerbt von Object)
IJavaPeerable.DisposeUnlessReferenced()

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

(Geerbt von Object)
IJavaPeerable.Finalized()

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

(Geerbt von Object)
IJavaPeerable.JniManagedPeerState

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

(Geerbt von Object)
IJavaPeerable.SetJniIdentityHashCode(Int32)

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

(Geerbt von Object)
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates)

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

(Geerbt von Object)
IJavaPeerable.SetPeerReference(JniObjectReference)

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

(Geerbt von Object)

Erweiterungsmethoden

JavaCast<TResult>(IJavaObject)

Führt eine Typkonvertierung mit Überprüfung der Android-Laufzeit aus.

JavaCast<TResult>(IJavaObject)

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

GetJniTypeName(IJavaPeerable)

Die BreakIterator -Klasse implementiert Methoden zum Ermitteln der Position von Grenzen im Text.

Gilt für: