Namespaces
Variants

std::basic_string<CharT,Traits,Allocator>:: find_last_of

From cppreference.net
std::basic_string
size_type find_last_of ( const basic_string & str,
size_type pos = npos ) const ;
(1) (noexcept seit C++11)
(constexpr seit C++20)
size_type find_last_of ( const CharT * s,
size_type pos, size_type count ) const ;
(2) (constexpr seit C++20)
size_type find_last_of ( const CharT * s, size_type pos = npos ) const ;
(3) (constexpr seit C++20)
size_type find_last_of ( CharT ch, size_type pos = npos ) const ;
(4) (noexcept seit C++11)
(constexpr seit C++20)
template < class StringViewLike >

size_type
find_last_of ( const StringViewLike & t,

size_type pos = npos ) const noexcept ( /* siehe unten */ ) ;
(5) (seit C++17)
(constexpr seit C++20)

Findet das letzte Zeichen, das einem der Zeichen in der gegebenen Zeichenfolge entspricht. Der genaue Suchalgorithmus ist nicht spezifiziert. Die Suche berücksichtigt nur den Bereich [ 0 , pos ] . Wenn keines der Zeichen in der gegebenen Zeichenfolge im Bereich vorhanden ist, wird npos zurückgegeben.

1) Findet das letzte Zeichen, das einem der Zeichen in str entspricht.
2) Findet das letzte Zeichen, das einem der Zeichen im Bereich [ s , s + count ) entspricht. Dieser Bereich kann Nullzeichen enthalten.
Falls [ s , s + count ) kein gültiger Bereich ist, ist das Verhalten undefiniert.
3) Findet das letzte Zeichen, das einem der Zeichen in der Zeichenkette entspricht, auf die s zeigt. Die Länge der Zeichenkette wird durch das erste Nullzeichen mittels Traits :: length ( s ) bestimmt.
Wenn [ s , s + Traits :: length ( s ) ) kein gültiger Bereich ist, ist das Verhalten undefiniert.
4) Findet das letzte Zeichen gleich ch .
5) Konvertiert implizit t zu einem String-View sv als ob durch std:: basic_string_view < CharT, Traits > sv = t ; , findet dann das letzte Zeichen, das einem der Zeichen in sv entspricht.
Diese Überladung nimmt nur dann an der Überladungsauflösung teil, wenn std:: is_convertible_v < const StringViewLike & ,
std:: basic_string_view < CharT, Traits >>
true ist und std:: is_convertible_v < const StringViewLike & , const CharT * > false ist.

In allen Fällen wird Gleichheit durch Aufruf von Traits::eq überprüft.

Inhaltsverzeichnis

Parameter

str - Zeichenkette, die die zu suchenden Zeichen identifiziert
pos - Position, an der die Suche beendet werden soll
count - Länge der Zeichenkette, die die zu suchenden Zeichen identifiziert
s - Zeiger auf eine Zeichenkette, die die zu suchenden Zeichen identifiziert
ch - zu suchendes Zeichen
t - Objekt (konvertierbar zu std::basic_string_view ), das die zu suchenden Zeichen identifiziert

Rückgabewert

Position des gefundenen Zeichens oder npos falls kein solches Zeichen gefunden wurde.

Exceptions

1,4) Wirft nichts.
5)
noexcept Spezifikation:
noexcept ( std:: is_nothrow_convertible_v < const T & , std:: basic_string_view < CharT, Traits >> )

Wenn aus irgendeinem Grund eine Exception ausgelöst wird, hat diese Funktion keine Wirkung ( strong exception safety guarantee ).

Beispiel

#include <iostream>
#include <string>
int main()
{
    const std::string path = "/root/config";
    auto const pos = path.find_last_of('/');
    const auto leaf = path.substr(pos + 1);
    std::cout << leaf << '\n';
}

Ausgabe:

config

Fehlerberichte

Die folgenden verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR Angewendet auf Verhalten wie veröffentlicht Korrigiertes Verhalten
LWG 141 C++98 Überladung (1) konnte nur npos zurückgeben, falls pos >= size ( ) der Suchbereich ist in diesem Fall
[ 0 , size ( ) )
LWG 847 C++98 es gab keine Ausnahmesicherheitsgarantie starke Ausnahmesicherheitsgarantie hinzugefügt
LWG 2064 C++11 Überladungen (3,4) waren noexcept entfernt
LWG 2946 C++17 Überladung (5) verursachte in einigen Fällen Mehrdeutigkeit vermieden durch Template-Implementierung
P1148R0 C++11
C++17
noexcept für Überladungen (4,5) wurden
versehentlich durch LWG2064/LWG2946 entfernt
wiederhergestellt

Siehe auch

findet das erste Vorkommen der gegebenen Teilzeichenkette
(öffentliche Elementfunktion)
findet das letzte Vorkommen einer Teilzeichenkette
(öffentliche Elementfunktion)
findet das erste Vorkommen von Zeichen
(öffentliche Elementfunktion)
findet das erste Fehlen von Zeichen
(öffentliche Elementfunktion)
findet das letzte Fehlen von Zeichen
(öffentliche Elementfunktion)
findet das letzte Vorkommen von Zeichen
(öffentliche Elementfunktion von std::basic_string_view<CharT,Traits> )