Panel użytkownika
Nazwa użytkownika:
Hasło:
Nie masz jeszcze konta?
Hasło nie zostało zweryfikowane
Niniejsze hasło zostało opracowane, jednak nie zostało ono zweryfikowane przez administrację serwisu. Jeżeli znalazłeś błędy merytoryczne w niniejszym dokumencie, prosimy o ich zgłoszenie na forum w dziale Znalezione błędy.
Opracował: Mrovqa
Język C++

basic_string::rfind

[metoda] Wyszukuje ostatniego wystąpienia danego łańcucha znaków.

Składnia

C/C++
#include <string>

namespace std
{
    template <
    class TypZnaku,
    class CechowanieZnakow = char_traits < TypZnaku >,
    class Alokator = allocator < TypZnaku >
    >
    class basic_string
    {
    private:
        typedef basic_string < TypZnaku, CechowanieZnakow, Alokator > UtworzonaKlasaT;
    public:
        size_type rfind( const UtworzonaKlasaT & _str, size_type _pos = 0 ) const noexcept; //(1)
       
        size_type rfind( const TypZnaku * _s, size_type _pos = 0 ) const; //(2)
       
        size_type rfind( const TypZnaku * _s, size_type _pos, size_type _n ) const; //(3)
       
        size_type rfind( TypZnaku _c, size_type _pos = 0 ) const noexcept; //(4)
       
    }; //class basic_string
} //namespace std

Argumenty

ArgumentOpis
_strInny obiekt tego samego typu co aktualny (z uwzględnieniem parametrów szablonu!), który będzie wzorcem wyszukiwania.
_posPozycja znaku w aktualnym obiekcie, na którym ma się zakończyć wyszukiwanie.
_sWskaźnik na tablicę znaków. Jeżeli argument _n jest określony, to oznacza on długość wzorca. W przeciwnym wypadku owa długość jest zdeterminowana przez bajt zerowy.
_nDługość wzorca.
_cPojedynczy znak do wyszukania.

Zwracana wartość

Pozycja pierwszego znaku ostatniego dopasowania wzorca. Jeżeli owy wzorzec nie został znaleziony, funkcja zwróci » standard C++ » basic_stringnpos.

Opis szczegółowy

Metoda (1) wyszukuje ostatnie wystąpienie wzorca określonego innym obiektem tego samego typu do pozycji _pos w aktualnym obiekcie. Wersja (2) czyni dokładnie to samo, z tą różnicą, iż wzorzec jest określony poprzez wskaźnik do tablicy znaków. Metoda (3) jest rozszerzoną metodą (2) o możliwość podania długości wzorca. Ostatnia wersja (4) wyszukuje pojedynczy znak w aktualnym obiekcie.

Rzucane wyjątki

Jeżeli _s nie wskazuje na wystarczająco dużą tablicę (_n jest za duże), to zachowanie jest niezdefiniowane.

Przykład

C/C++
#include <iostream>
#include <string>

typedef std::basic_string < char, std::char_traits < char >, std::allocator < char >> MojString;
int main()
{
    MojString str( "Tekst do wyszukiwan. Tekst. " );
    MojString str2( "Tekst" );
   
    MojString::size_type found = str.rfind( str2 );
    if( found != MojString::npos )
         std::cout << "Znaleziono ostatnie wystapienie 'Tekst' na pozycji " << found << '\n';
   
}
Standardowe wyjście programu:
Znaleziono ostatnie wystapienie 'Tekst' na pozycji 21

Zagadnienia powiązane

findWyszukuje pierwszego wystąpienia danego łańcucha znaków. (metoda)
find_last_not_ofWyszukuje ostatnie wystąpienie znaku spoza danej bazy znaków. (metoda)
find_last_ofWyszukuje ostatnie wystąpienie znaku z danej bazy znaków. (metoda)
replaceZamienia część znaków na inne. (metoda)
substrZwraca podciąg łańcucha znaków. (metoda)

Linki zewnętrzne