Inhaltsverzeichnis
Eigenschaften der Funktion strtok()
Example-2
Output
结论
Heim Backend-Entwicklung C++ Implementieren Sie die Funktion strtok() in C++

Implementieren Sie die Funktion strtok() in C++

Sep 01, 2023 pm 07:21 PM
c语言 实现 strtok

Die Funktion

Implementieren Sie die Funktion strtok() in C++

strtok() ist eine der am häufigsten verwendeten Funktionen in C++. Mithilfe von Trennzeichen als Richtlinie kann diese Funktion Text in kleinere Abschnitte oder Token aufteilen. Das Arbeiten mit Strings in C++ ist dank der Funktion strtok() einfach. In diesem Artikel wird die Funktion strtok() ausführlich erläutert, einschließlich ihrer Definition, Syntax, ihres Algorithmus und verschiedener Implementierungsstrategien. Beachten Sie, dass die Strtok-Funktion einige Einschränkungen und potenzielle Nachteile aufweist. Es kann beispielsweise nicht mit const- oder schreibgeschützten Zeichenfolgen verwendet werden, da es die ursprüngliche Zeichenfolge direkt ändert. Randfälle und unerwartete Eingaben, wie leere Zeichenfolgen oder Trennzeichen, die in einer Sequenz wiederkehren, können ebenfalls schwierig zu handhaben sein.

Trotz dieser Mängel bleibt diese Funktion für viele Programmierer ein nützliches Werkzeug und wird häufig in einer Vielzahl von Anwendungen verwendet, einschließlich Textverarbeitung, Datenanalyse und Netzwerkprotokollen. Es handelt sich um eine flexible und leistungsstarke Funktion, die viele gängige Programmieraufgaben erheblich vereinfachen kann.

Eigenschaften der Funktion strtok()

Um eine Zeichenfolge basierend auf einem Trennzeichen in kleinere Abschnitte oder Token aufzuteilen, verwenden Sie die Funktion strtok() in C++. Ein Zeiger auf die Zeichenfolge, die tokenisiert werden muss, und eine Zeichenfolge mit den Trennzeichen sind die beiden Eingaben für die Funktion A Der Zeiger auf das allererste Token der Zeichenfolge wird von der Funktion zurückgegeben. Solange noch Token in der Zeichenfolge vorhanden sind, geben aufeinanderfolgende Aufrufe der Funktion mit demselben Zeichenfolgenparameter zusätzliche Token zurück. Dies geschieht mithilfe des NULL-Zeigers in der While-Schleife . Wenn Sie die Funktion „strtok()“ erneut aufrufen, weist die Angabe von NULL als erstes Argument die Funktion an, dort fortzufahren, wo sie mit der vorherigen Tokenisierung derselben Zeichenfolge aufgehört hat.

Wenn die Funktion „strtok()“ zum ersten Mal mit der Eingabezeichenfolge als erstem Argument aufgerufen wird, beginnt sie mit der Suche nach dem ersten Token in der Zeichenfolge am Anfang. Wenn sie das anfängliche Token findet, beendet sie es, indem sie das Trennzeichen ersetzt kommt danach mit dem Nullzeichen („0“). Wenn „strtok()“ erneut mit einem NULL-Zeiger als erstes Argument verwendet wird, macht die Funktion dort weiter, wo sie mit der vorherigen Tokenisierung der Zeichenfolge aufgehört hat ist, direkt nach dem vorherigen Token. Es wird weiterhin nach dem nächsten Erscheinen des Trennzeichens gesucht

Grammatik

Char* strtok(char* str, const char* delimiters);  
Nach dem Login kopieren

Wo

- „str“ ist ein Zeiger auf die Zeichenfolge, die tokenisiert werden soll

- „Trennzeichen“ ist eine Zeichenfolge, die Trennzeichen enthält.

Algorithmus

  • Schritt 1 − Die Funktion „strtok()“ benötigt zwei Argumente – das erste Argument ist die Eingabezeichenfolge, die tokenisiert werden soll, und das zweite Argument ist eine Zeichenfolge, die alle Trennzeichen enthält, die zum Aufteilen der Eingabezeichenfolge in Token verwendet werden sollen .

  • Schritt 2 − Wenn die Funktion zum ersten Mal aufgerufen wird, wird die Eingabezeichenfolge als erstes Argument und die Trennzeichenfolge als zweites Argument übergeben

  • Schritt 3 - Diese Funktion durchsucht die Eingabezeichenfolge nach dem ersten Vorkommen eines Trennzeichens

  • Schritt 4 − Wenn ein Trennzeichen gefunden wird, ersetzt es es durch ein Null-Terminator („

  • Schritt 5
  • – Beim nächsten Aufruf der Funktion sollte der erste Parameter auf „NULL“ anstelle der ursprünglichen Eingabezeichenfolge gesetzt werden. Dadurch wird die Funktion angewiesen, dort fortzufahren, wo sie aufgehört hat, und nach dem nächsten Token in der Zeichenfolge zu suchen.

  • Schritt 6
  • - Die Funktion sucht weiterhin nach Trennzeichen und gibt Zeiger auf den Anfang nachfolgender Token zurück, bis sie das Ende der Zeichenfolge erreicht. An diesem Punkt gibt sie „NULL“ zurück

    Zu verfolgende Ansätze

  • Methode 1
– Ein Programm, das Schleifen und die Funktion strtok() sowie ein einzelnes Trennzeichen verwendet, um den Code anzuzeigen.

Methode 2 – Ein Programm, das Schleifen und die Funktion strtok() sowie mehrere Trennzeichen zum Anzeigen von Code verwendet

Methode 1

Unten finden Sie das Programm zum Anzeigen von Code mithilfe einer Schleife mit der Funktion strtok() und einem einzelnen Trennzeichen

Dieses Beispiel zeigt, wie man mit strtok eine Zeichenfolge nach Leerzeichen segmentiert. Die Eingabezeichenfolge str wird zunächst zusammen mit dem Trennzeichen „“ an strtok übergeben. Der erste Aufruf von strtok gibt einen Zeiger auf das erste Token („Hi,“) zurück, das auf der Konsole ausgegeben wird. strtok setzt die Tokenisierung der Zeichenfolge fort, bis keine Token mehr vorhanden sind und jedes Token auf der Konsole ausgegeben wird. Bitte beachten Sie, dass wir bei nachfolgenden Aufrufen von strtok einen Nullzeiger als erstes Argument übergeben, der angibt, dass wir mit der Tokenisierung der ursprünglichen Zeichenfolge fortfahren möchten

Beispiel 1

#include <iostream>
#include <cstring> // Include the header for strtok()
using namespace std;

int main() {
   char str[] = "Hi, this topic tells about strtok() function";
   char* ptr;
   ptr = strtok(str, " ");
   while (ptr != NULL) {
      cout << ptr << endl;
      ptr = strtok(NULL, " ");
   }
   return 0;
}
Nach dem Login kopieren

Ausgabe

Hi, 
this  
topic 
tells  
about 
strtok()  
function 
Nach dem Login kopieren

Methode 2

Unten finden Sie das Programm zum Anzeigen von Code mit mehreren Trennzeichen mithilfe der Schleife und der Funktion strtok(). Unten finden Sie den Programmcode dafür.

The '|' and'' (space) delimiters are used to tokenize the string "The boy|is|standing|with his pet|lazy dog." in this example. Once with the string as the first argument and the characters '|' and'' as the second argument, the strtok() method is called twice. Following calls return the remaining tokens, the initial call returns the first token, "The." Until all tokens have been extracted, the loop keeps running.

Example-2

#include <iostream> 
#include <cstring> 
 
int main() { 
   char str[] = "The boy|is|standing|with his pet|lazy dog."; 
   char* token = strtok(str, "| "); 
   while (token != NULL) { 
      std::cout << token << std::endl; 
      token = strtok(NULL, "| "); 
   } 
   return 0; 
} 
Nach dem Login kopieren

Output

The 
boy 
is 
standing 
with 
his 
pet 
lazy 
dog.
Nach dem Login kopieren

结论

总之,C++的strtok函数是一个有用且有效的用于操作字符串的工具。尽管它有一些重要的限制和潜在的缺点,但它仍然是解析和处理文本数据的常见选择,并且对于任何编码人员来说都是一个有用的工具。

Das obige ist der detaillierte Inhalt vonImplementieren Sie die Funktion strtok() in C++. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

C Sprachdatenstruktur: Datenrepräsentation und Betrieb von Bäumen und Grafiken C Sprachdatenstruktur: Datenrepräsentation und Betrieb von Bäumen und Grafiken Apr 04, 2025 am 11:18 AM

C Sprachdatenstruktur: Die Datenrepräsentation des Baumes und des Diagramms ist eine hierarchische Datenstruktur, die aus Knoten besteht. Jeder Knoten enthält ein Datenelement und einen Zeiger auf seine untergeordneten Knoten. Der binäre Baum ist eine besondere Art von Baum. Jeder Knoten hat höchstens zwei Kinderknoten. Die Daten repräsentieren structTreenode {intdata; structTreenode*links; structTreenode*rechts;}; Die Operation erstellt einen Baumtraversalbaum (Vorbereitung, in Ordnung und späterer Reihenfolge) Suchbauminsertion-Knoten Lösches Knotendiagramm ist eine Sammlung von Datenstrukturen, wobei Elemente Scheitelpunkte sind, und sie können durch Kanten mit richtigen oder ungerechten Daten miteinander verbunden werden, die Nachbarn darstellen.

Die Wahrheit hinter dem Problem der C -Sprachdatei Die Wahrheit hinter dem Problem der C -Sprachdatei Apr 04, 2025 am 11:24 AM

Die Wahrheit über Probleme mit der Dateibetrieb: Dateiöffnung fehlgeschlagen: unzureichende Berechtigungen, falsche Pfade und Datei besetzt. Das Schreiben von Daten fehlgeschlagen: Der Puffer ist voll, die Datei ist nicht beschreibbar und der Speicherplatz ist nicht ausreichend. Andere FAQs: Langsame Dateitraversal, falsche Textdateicodierung und Binärdatei -Leser -Fehler.

C Sprach -Multithread -Programmierung: Ein Anfängerleitfaden und Fehlerbehebung C Sprach -Multithread -Programmierung: Ein Anfängerleitfaden und Fehlerbehebung Apr 04, 2025 am 10:15 AM

C Sprachmultithreading -Programmierhandbuch: Erstellen von Threads: Verwenden Sie die Funktion pThread_create (), um Thread -ID, Eigenschaften und Threadfunktionen anzugeben. Threadsynchronisation: Verhindern Sie den Datenwettbewerb durch Mutexes, Semaphoren und bedingte Variablen. Praktischer Fall: Verwenden Sie Multi-Threading, um die Fibonacci-Nummer zu berechnen, mehrere Threads Aufgaben zuzuweisen und die Ergebnisse zu synchronisieren. Fehlerbehebung: Lösen Sie Probleme wie Programmabstürze, Thread -Stop -Antworten und Leistungs Engpässe.

CS-Woche 3 CS-Woche 3 Apr 04, 2025 am 06:06 AM

Algorithmen sind die Anweisungen zur Lösung von Problemen, und ihre Ausführungsgeschwindigkeit und Speicherverwendung variieren. Bei der Programmierung basieren viele Algorithmen auf der Datensuche und Sortierung. In diesem Artikel werden mehrere Datenabruf- und Sortieralgorithmen eingeführt. Die lineare Suche geht davon aus, dass es ein Array gibt [20.500,10,5,100, 1,50] und die Nummer 50 ermitteln muss. Der lineare Suchalgorithmus prüft jedes Element im Array Eins nach eins nach dem anderen, bis der Zielwert gefunden oder das vollständige Array durchquert wird. Der Algorithmus-Flussdiagramm lautet wie folgt: Der Pseudo-Code für die lineare Suche lautet wie folgt: Überprüfen Sie jedes Element: Wenn der Zielwert gefunden wird: Return Return Falsch C-Sprache Implementierung: #includeIntmain (void) {i

Wie man einen Countdown in der C -Sprache ausgibt Wie man einen Countdown in der C -Sprache ausgibt Apr 04, 2025 am 08:54 AM

Wie gibt ich einen Countdown in C aus? Antwort: Verwenden Sie Schleifenanweisungen. Schritte: 1. Definieren Sie die Variable N und speichern Sie die Countdown -Nummer in der Ausgabe. 2. Verwenden Sie die while -Schleife, um n kontinuierlich zu drucken, bis n weniger als 1 ist; 3. Drucken Sie im Schleifenkörper den Wert von n aus; 4. Am Ende der Schleife subtrahieren Sie N um 1, um den nächsten kleineren gegenseitigen gegenseitigen gegenseitigen gegenseitig auszugeben.

C Sprachdatenstruktur: Die Schlüsselrolle von Datenstrukturen in der künstlichen Intelligenz C Sprachdatenstruktur: Die Schlüsselrolle von Datenstrukturen in der künstlichen Intelligenz Apr 04, 2025 am 10:45 AM

C Sprachdatenstruktur: Überblick über die Schlüsselrolle der Datenstruktur in der künstlichen Intelligenz im Bereich der künstlichen Intelligenz sind Datenstrukturen für die Verarbeitung großer Datenmengen von entscheidender Bedeutung. Datenstrukturen bieten eine effektive Möglichkeit, Daten zu organisieren und zu verwalten, Algorithmen zu optimieren und die Programmeffizienz zu verbessern. Gemeinsame Datenstrukturen, die häufig verwendete Datenstrukturen in der C -Sprache sind: Arrays: Eine Reihe von nacheinander gespeicherten Datenelementen mit demselben Typ. Struktur: Ein Datentyp, der verschiedene Arten von Daten zusammen organisiert und ihnen einen Namen gibt. Linked List: Eine lineare Datenstruktur, in der Datenelemente durch Zeiger miteinander verbunden werden. Stack: Datenstruktur, die dem LEST-In-First-Out-Prinzip (LIFO) folgt. Warteschlange: Datenstruktur, die dem First-In-First-Out-Prinzip (FIFO) folgt. Praktischer Fall: Die benachbarte Tabelle in der Graphentheorie ist künstliche Intelligenz

Das Konzept der C -Sprachfunktionen und dessen Definitionsformat Das Konzept der C -Sprachfunktionen und dessen Definitionsformat Apr 03, 2025 pm 11:33 PM

C -Sprachfunktionen sind wiederverwendbare Codeblöcke, empfangen Parameter für die Verarbeitung und die Rückgabeergebnisse. Es ähnelt dem schweizerischen Armeemesser, mächtig und erfordert sorgfältige Verwendung. Funktionen umfassen Elemente wie das Definieren von Formaten, Parametern, Rückgabetwerten und Funktionskörpern. Die erweiterte Verwendung umfasst Funktionszeiger, rekursive Funktionen und Rückruffunktionen. Häufige Fehler sind Fehlanpassung vom Typ und Vergessen, Prototypen zu deklarieren. Zu den Debugging -Fähigkeiten gehören das Druckvariablen und die Verwendung eines Debuggers. Leistungsoptimierung verwendet Inline -Funktionen. Das Funktionsdesign sollte dem Prinzip der einzigen Verantwortung folgen. Kenntnisse in C -Sprachfunktionen können die Programmierungseffizienz und die Codequalität erheblich verbessern.

Fehlerbehebungstipps für die Verarbeitung von Dateien in der C -Sprache Fehlerbehebungstipps für die Verarbeitung von Dateien in der C -Sprache Apr 04, 2025 am 11:15 AM

Fehlerbehebungstipps für C -Sprachverarbeitungsdateien Wenn Dateien in der C -Sprache verarbeitet werden, können Sie auf verschiedene Probleme stoßen. Das Folgende sind häufig zu Problemen und entsprechende Lösungen: Problem 1: Der Dateicode kann nicht geöffnet werden: Datei*fp = fopen ("myFile.txt", "r"); if (fp == null) {// Datei Öffnen fehlgeschlagen} Grund} Grund: Dateipfad -Fehler -Datei nicht vorhandener Datei -Read -Lösung vorhanden. Charbuffer [100]; size_tread_bytes = fread (Puffer, 1, Siz

See all articles