Namensräume
Varianten
Aktionen

std::experimental::default_searcher, std::experimental::make_default_searcher

Von cppreference.com
 
 
 
 
Definiert im Header <experimental/functional>
template< class ForwardIterator1, class BinaryPredicate = std::equal_to<> >
class default_searcher;
(library fundamentals TS)

Eine Klasse, die für die Verwendung mit std::experimental::search geeignet ist und die Suchoperation an die Standardbibliothek delegiert std::search.

default_searcher ist CopyConstructible und CopyAssignable.

Inhalt

[bearbeiten] Member-Funktionen

std::experimental::default_searcher::default_searcher

default_searcher( ForwardIterator pat_first,

                  ForwardIterator pat_last,

                  BinaryPredicate pred = BinaryPredicate() );

Konstruiert einen default_searcher durch Speichern von Kopien von pat_first, pat_last und pred.

Parameter

pat_first, pat_last - ein Iteratorpaar, das die zu suchende Zeichenkette bezeichnet
pred - ein aufrufbares Objekt, das zur Bestimmung der Gleichheit verwendet wird

Ausnahmen

Alle Ausnahmen, die von den Konstruktoren von BinaryPredicate oder ForwardIterator ausgelöst werden.

std::experimental::default_searcher::operator()

template< class ForwardIterator2 >
ForwardIterator2 operator()( ForwardIterator2 first, ForwardIterator2 last ) const;
(bis C++17)
template< class ForwardIterator2 >

std::pair<ForwardIterator2, ForwardIterator2>

    operator()( ForwardIterator2 first, ForwardIterator2 last ) const;
(seit C++17)

Die Member-Funktion, die von std::experimental::search aufgerufen wird, um eine Suche mit diesem Sucher durchzuführen.

Äquivalent zu std::search(first, last, pat_first, pat_last, pred);.

(bis C++17)

Gibt ein Paar Iteratoren i, j zurück, wobei i std::search(first, last, pat_first, pat_last, pred) ist und j std::next(i, std::distance(pat_first, pat_last)) ist, es sei denn, std::search gab last zurück (keine Übereinstimmung), in diesem Fall ist j ebenfalls gleich last.

(bis C++17)

Parameter

first, last - ein Iteratorpaar, das die zu untersuchende Zeichenkette bezeichnet

Rückgabewert

Iterator zur ersten Position in [firstlast), an der eine Teilsequenz, die gleich [pat_firstpat_last) ist, wie durch pred definiert, gefunden wird, andernfalls ein Kopie von last.

(bis C++17)

Ein Paar von Iteratoren zur ersten und zur Position nach der letzten Stelle in [firstlast), an der eine Teilsequenz, die gleich [pat_firstpat_last) ist, wie durch pred definiert, gefunden wird, andernfalls ein Paar von Kopien von last.

(seit C++17)

[bearbeiten] Hilfsfunktionen

template< class ForwardIterator, class BinaryPredicate = std::equal_to<> >

default_searcher<ForwardIterator, BinaryPredicate> make_default_searcher(
    ForwardIterator pat_first,
    ForwardIterator pat_last,

    BinaryPredicate pred = BinaryPredicate());
(library fundamentals TS)

Hilfsfunktion, die einen std::experimental::default_searcher unter Verwendung der Template-Argument-Ableitung konstruiert. Äquivalent zu return default_searcher<ForwardIterator, BinaryPredicate>(pat_first, pat_last, pred);

[bearbeiten] Parameter

pat_first, pat_last - ein Iteratorpaar, das die zu suchende Zeichenkette bezeichnet
pred - ein aufrufbares Objekt, das zur Bestimmung der Gleichheit verwendet wird

[bearbeiten] Rückgabewert

Ein default_searcher, konstruiert mit den Argumenten pat_first, pat_last, pred.

[bearbeiten] Beispiel

#include <experimental/algorithm>
#include <experimental/functional>
#include <iostream>
#include <string>
 
int main()
{
    std::string in = "Lorem ipsum dolor sit amet, consectetur adipiscing elit,"
                     " sed do eiusmod tempor incididunt ut labore et dolore magna aliqua";
    std::string needle = "pisci";
    auto it = std::experimental::search(in.begin(), in.end(),
                  std::experimental::make_default_searcher(
                      needle.begin(), needle.end()));
    if (it != in.end())
        std::cout << "The string " << needle << " found at offset "
                  << it - in.begin() << '\n';
    else
        std::cout << "The string " << needle << " not found\n";
}

Ausgabe

The string pisci found at offset 43

[bearbeiten] Siehe auch

Sucht nach dem ersten Vorkommen eines Elementbereichs
(Funktionstempelat) [edit]