Häufigkeit eines Zeichens ermitteln

Status
Nicht offen für weitere Antworten.

deamon

Bekanntes Mitglied
Ich will herausfinden, wie oft ein bestimmtes Zeichen in einem String vorkommt.

Das Beste, was mir eingefallen ist, ist die Umwandlung in ein char-Array und dann ein zeichenweiser Vergleich in einer Schleife. Gibt es dafür auch eine bestehende Methode?
 

Ark

Top Contributor
Nein, aber es gibt [c]String.charAt(int)[/c] nebst [c]String.codepointAt(int)[/c], was die Umwandlung in ein char-Array überflüssig machen sollte.

Ark
 

deamon

Bekanntes Mitglied
Aber ist das auch schneller oder zumindest gleich schnell? Es geht um einen Bereich, wo es auf die Performance ankommt.
 

Ark

Top Contributor
Aber ist das auch schneller oder zumindest gleich schnell?
Das Erzeugen des Arrays kostet auch Zeit. ;)

Wenn es dir um Geschwindigkeit geht, solltest du dir vor allem das Design vorknöpfen. Meine bisherigen Erfahrungen zeigten, dass Strings kaum dazu geeignet sind, komplexe Strukturen darzustellen. Ich entwarf deshalb meist eigene, und das führte dazu, dass ich eben so etwas wie "Zählen von Zeichen in String" nie brauchte und wohl auch nie brauchen werde.

In Strukturen, bei denen es auf Performance ankommt, habe ich höchst selten Strings gesehen, und das aus einem guten Grund: Strings sind nicht dazu geschaffen, Daten in einer für die Maschine aufbereiteten Form zugänglich zu machen. Sie sind eher dazu gedacht, eine rein auf Text basierende Schnittstelle vor allem zu Menschen zu ermöglichen. In Schichten sehr hoher Abstraktion haben Strings selten etwas zu suchen, und wenn, dann werden nur Zeiger auf sie ausgetauscht, aber es wird nie auf den Strings gearbeitet.

Faustregel: String-Operationen sind inhärent langsam.

Ark
 

deamon

Bekanntes Mitglied
Das Erzeugen des Arrays kostet auch Zeit. ;)

Ein wichtiger Punkt! Wie es scheint sogar der entscheindende, denn der Gewinner ist ganz klar die Variante mit charAt(index).

Falls sich jemand über den komischen Java-Code wundert, das ist Scala ;-)
Code:
// 32 Millisekunden für 1 Mio aufrufe
def countCharAt(subject: String, c: Char)={
	var index = subject.length - 1
	var count = 0
	while(index >= 0){
		if(subject.charAt(index) == c) count += 1
		index -= 1
	}
	count
}

// 328 Millisekunden für 1 Mio aufrufe
def countArray(subject: String, c: Char)={
	var count = 0
	for(character <- subject.toCharArray)
		if(character == c) count += 1
	count
}

// 62 Millisekunden für 1 Mio aufrufe
def countCharAt(subject: String, c: Char)={
	var index = subject.length - 1
	val characters = subject.toCharArray
	var count = 0
	while(index >= 0){
		if(characters(index) == c) count += 1
		index -= 1
	}
	count
}

Etwas irritiert mich, wie brutal langsam die Variante mit der for-Schleife ist, aber da muss zum einen ein CharArray erzeugt werden und dann wird auch noch bei jedem Aufruf ein Char-Objekt erzeugt, das scheint teuer zu sein.

Wenn es dir um Geschwindigkeit geht, solltest du dir vor allem das Design vorknöpfen. Meine bisherigen Erfahrungen zeigten, dass Strings kaum dazu geeignet sind, komplexe Strukturen darzustellen. Ich entwarf deshalb meist eigene, und das führte dazu, dass ich eben so etwas wie "Zählen von Zeichen in String" nie brauchte und wohl auch nie brauchen werde.

Wenn es um ein abstraktes Problem ginge, wäre ich geneigt, dir zu zustimmen. Aber in diesem Fall kommen die Daten nur per String rein (über das Netz) und daran kann ich auch nichts ändern, solange das HTT-Protokoll von anderen festgelegt wird ;-)

Also vielen Dank für deinen Hinweis mit charAt! Ich hätte es vermutlich mit einem Array wesentlich weniger performant umgesetzt.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
M ArrayList<String>, String häufigkeit sortieren Allgemeine Java-Themen 4
L Nach Häufigkeit sortieren Allgemeine Java-Themen 6
Z Elemente in Vector nach Häufigkeit sortieren. Allgemeine Java-Themen 13
L Häufigkeit der Werte in Datei zählen! Heap Space beschränkt! Allgemeine Java-Themen 31
O regulärer Ausdruck zum durchsuchen eines Strings verwenden Allgemeine Java-Themen 2
T Rotationswinkel eines Bildes bestimmen Allgemeine Java-Themen 4
C Probleme beim Erstellen eines runnable-jar files Allgemeine Java-Themen 1
J JavaScript innerhalb eines Java Projekts ausführen Allgemeine Java-Themen 2
Encera Größe eines Objektes in Byte berechnen Allgemeine Java-Themen 2
8u3631984 Prüfen ob min. ein Element eines Sets in einem anderen Set enh Allgemeine Java-Themen 4
M Array Rang eines Elements Allgemeine Java-Themen 4
OnDemand Teile eines Links entfernen Allgemeine Java-Themen 6
H Auslesen eines (LDAP-)Attributs in Active Directory Allgemeine Java-Themen 2
W JSON parsen eines ,mit JS.stringify erstellten Strings Allgemeine Java-Themen 27
H Textposition eines gedrehten Textes verschieben Allgemeine Java-Themen 8
berserkerdq2 run-methode eines Threads so programmieren, dass 30x die Sekunde etwas ausgeführt wird. Allgemeine Java-Themen 44
E Ersetzen eines Bildes in der Kopfzeile eines Word-Docx-Dokuments mit Apache POI XWPF Allgemeine Java-Themen 0
N Fahrtrichtung eines selbstfahrenden Auto ändern Allgemeine Java-Themen 3
T Letztes Zeichen eines Strings enfernen Allgemeine Java-Themen 14
S Übergabe eines Sortierkriteriums für ein Artikel Array mittels BiPredicate<Artikel, Artikel> Allgemeine Java-Themen 13
gotzi242 Schatzsuche mithilfe eines O(log n) Algorithmus Allgemeine Java-Themen 2
C Koordinaten LONG/LAT eines neuen Punktes in bestimmter Entfernen und Winkel berechnen Allgemeine Java-Themen 3
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
LimDul Direktes return eines Array geht nicht Allgemeine Java-Themen 20
S Mittelwert anhand eines Stream berechnen Allgemeine Java-Themen 5
kodela Breite eines erweiterten Monitors feststellen Allgemeine Java-Themen 5
R Zeilen eines 2d Arrays abwechselnd links und rechts mit Nullen auffüllen Allgemeine Java-Themen 14
Zrebna Alternative Darstellung eines Codesnippets Allgemeine Java-Themen 33
kodela Inhalt eines Arrays ändert sich mysteriös Allgemeine Java-Themen 2
bueseb84 Wget mit Wildcards - oder wie lädt man bei JFrog die letzte Version eines Artifacts herunter Allgemeine Java-Themen 3
N Erkennen eines Programs Allgemeine Java-Themen 2
N Pausieren eines Programmes Allgemeine Java-Themen 4
D Input/Output Implementierung eines CommandHandlers/Parsers für viele Eingaben Allgemeine Java-Themen 26
M Gibt es eine API die den aktuellen Wert eines Indikators beim Trading zurückgibt? Allgemeine Java-Themen 7
F Wie bekommt man alle Filenamen eines Webserver Verzeichnisses Allgemeine Java-Themen 6
A Fehler beim Öffnen eines Projekts Allgemeine Java-Themen 6
N Eigenschaften eines Buttons per Setter verändern Allgemeine Java-Themen 5
S Ausfuehrung eines Programms aufzeichnen..? Allgemeine Java-Themen 4
X Ermittlung eines doppelte Paars mit Streams Allgemeine Java-Themen 50
Stonie Prüfen von direkter Implementierung eines Interfaces Allgemeine Java-Themen 7
S Vorbereitung eines Praktikums Allgemeine Java-Themen 4
H Aufruf eines Web Service anhand übergebenen Parameter Allgemeine Java-Themen 2
M Weiterleiten von empfangenen Nachrichten eines StompSessionHandlers Allgemeine Java-Themen 1
J Programm zum Suchen eines Wortes im Dateisystem Allgemeine Java-Themen 4
H Rename eines Projekts Allgemeine Java-Themen 1
J Fenstergröße eines anderen Programmes auslesen Allgemeine Java-Themen 9
ReinerCoder auf Klassen innerhalb eines package zugreifen Allgemeine Java-Themen 22
Meeresgott Erste Schritte Sourcetree - Git | Suchen eines Commits Allgemeine Java-Themen 2
E Status eines USB Mikrofon abfragen Allgemeine Java-Themen 2
DaCrazyJavaExpert OOP Ansätze und Tipps zum Porgrammieren eines Taschenrechners Allgemeine Java-Themen 25
A OOP Problem beim Berechnen der größten Fläche eines Ringes Allgemeine Java-Themen 19
JavaNewbie2.0 Start eines Anderen Programm erkennen Allgemeine Java-Themen 6
I Verbindung eines Java-Plugins mit Webserver Allgemeine Java-Themen 3
L Auswertung eines Testes funktioniert nicht Allgemeine Java-Themen 37
G Iteratoren - Wie kann man mithilfe von Iteratoren nur jeden zweiten Wert eines TreeSets ausgeben? Allgemeine Java-Themen 4
GreenTeaYT Elemente eines 2Dim LinkedList von links nach rechts ausgeben? Allgemeine Java-Themen 0
B Spalten eines 2d-Arrays Allgemeine Java-Themen 2
M Rechenprogramm eines wissenschaftlichen Taschenrechners Allgemeine Java-Themen 4
S Eigenschaften (hier Verknüpfung) eines Files lesen Allgemeine Java-Themen 2
E Typüberprüfung eines chars Allgemeine Java-Themen 5
H Hilfe bei Erstellung eines Hilfe Fenster bei Tastendruck (F1 bei Win98) Allgemeine Java-Themen 5
T Teile eines Double-Wertes verändern Allgemeine Java-Themen 2
R Rückgabe eines Arrays durch Funktion Allgemeine Java-Themen 9
H Datentypen Typ eines Arrays überprüfen Allgemeine Java-Themen 9
RalleYTN DPI eines Bildes ändern Allgemeine Java-Themen 4
N Methoden Methoden einer Klasse auf Grundlage eines Strings aufrufen Allgemeine Java-Themen 6
K Bestimmten Bereich eines Strings lesen Allgemeine Java-Themen 6
C -Verschiedene Versionen eines Programms verwalten Allgemeine Java-Themen 7
O Datentypen Erstellung eines Containers, der verschachtelte Map-Strukturen beherbergen kann Allgemeine Java-Themen 0
A einmalige Ausführung eines Methodenabschnittes Allgemeine Java-Themen 3
F CPU Last eines Thread ausfindig machen Allgemeine Java-Themen 0
L Menge der Buchstaben eines Textes zählen Allgemeine Java-Themen 3
F Teil eines Bildes laden Allgemeine Java-Themen 1
Neumi5694 Operatoren regEx für das Erstellen eines Strings verwenden Allgemeine Java-Themen 3
P Löschen eines keys in einer SortedMap Allgemeine Java-Themen 5
RalleYTN Input/Output URL eines Zip Entry? Allgemeine Java-Themen 2
S Alle Methodenaufrufe eines Threads notieren..? Allgemeine Java-Themen 7
J NullPointerExeption bei Inizialisierung eines Arrays Allgemeine Java-Themen 3
I Setzen und Lesen eines Objektes (Enum?) Allgemeine Java-Themen 10
L Implementierung eines AVT-Baums Allgemeine Java-Themen 2
D Größe der Zahlenkombinationen eines Arrays begrenzen Allgemeine Java-Themen 3
D Objekt entlang eines Funktionsgraphens bewegen Allgemeine Java-Themen 6
B Existenz eines Files max 30 sec prüfen Allgemeine Java-Themen 5
U Koordinaten alle Pixel eines Dreiecks zeichnen ausgeben Allgemeine Java-Themen 5
P Wie funktioniert das Feedback eines Klicks auf eine Java GUI Allgemeine Java-Themen 10
thet1983 nach teilen eines Dateinamens suchen Allgemeine Java-Themen 6
T Bezeichnung eines Objektes mit String/int kombinieren Allgemeine Java-Themen 3
Z Auswerten eines eingegeben Termes Allgemeine Java-Themen 13
X Registrierung eines Ecore-Models außerhalb der Eclipse-Umgebung Allgemeine Java-Themen 0
R Instanzen eines Programms Allgemeine Java-Themen 8
I Arbeitsmaterialien eines Softwareentwicklers? Allgemeine Java-Themen 7
L Größe eines Objekts im Arbeitsspeicher Allgemeine Java-Themen 1
D Name eines Nicht-String Objekts ausgeben Allgemeine Java-Themen 4
A Helligkeit eines Bildes berechnen Allgemeine Java-Themen 1
L Anzahl der Tage eines Monats Allgemeine Java-Themen 3
S Java Problem bei der Rückgabe eines Arrays Allgemeine Java-Themen 19
C Best Practice Tiefe Kopie eines Arrays unbekannter Dimension und unbekannten Typs Allgemeine Java-Themen 4
H Klassennamen zum Aufruf eines statischen Feldes aus Variable holen Allgemeine Java-Themen 4
C Methode für tiefe Kopie eines unbekannt (dimensionierten & typisierten) Feldes realisierbar? Allgemeine Java-Themen 7
M final vor dem parameter eines Konstruktors Allgemeine Java-Themen 1

Ähnliche Java Themen

Neue Themen


Oben