Пространства имён
Варианты
Действия

std::placeholders::_1, std::placeholders::_2, ..., std::placeholders::_N

Материал из cppreference.com
< cpp‎ | utility‎ | functional

 
 
 
Функция объектов


Функция обертки
Оригинал:
Function wrappers
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Привязка
Оригинал:
Bind
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
_1, _2, _3, ...
Ссылка обертки
Оригинал:
Reference wrappers
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Оператор обертки
Оригинал:
Operator wrappers
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Negators
Оригинал:
Negators
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Устаревшие связующих и адаптеры
Оригинал:
Deprecated binders and adaptors
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
 
Defined in header <functional>
extern /*unspecified*/ _1;

extern /*unspecified*/ _2;
.
.

extern /*unspecified*/ _N;
std::placeholders пространство имен содержит заполнитель объектов [_1, . . . _N] где N является реализацией определено максимальное количество.
Оригинал:
The std::placeholders namespace contains the placeholder objects [_1, . . . _N] where N is an implementation defined maximum number.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
При использовании в качестве аргумента в std::bind выражения, заполнитель объекты хранятся в созданном объекте функции, и когда это функциональный объект вызывается с несвязанными аргументов, каждый заполнитель _N заменяется соответствующим N-ый аргумент несвязанных.
Оригинал:
When used as an argument in a std::bind expression, the placeholder objects are stored in the generated function object, and when that function object is invoked with unbound arguments, each placeholder _N is replaced by the corresponding Nth unbound argument.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Типы заполнителей объектов DefaultConstructible и CopyConstructible, их копии по умолчанию / перемещения конструкторы не бросать исключения, и для любого заполнителя _N, типа std::is_placeholder<decltype(_N)> определен и является производным от std::integral_constant<int, N>.
Оригинал:
The types of the placeholder objects are DefaultConstructible and CopyConstructible, their default copy/move constructors do not throw exceptions, and for any placeholder _N, the type std::is_placeholder<decltype(_N)> is defined and is derived from std::integral_constant<int, N>.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

[править] Пример

В следующем коде показано создание функциональных объектов с заполнителем аргумент .
Оригинал:
The following code shows the creation of function objects with a placeholder argument.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

#include <functional>
#include <string>
#include <iostream>
 
void goodbye(const std::string& s)
{
    std::cout << "Goodbye " << s << '\n';
}
 
class Object {
public:
    void hello(const std::string& s)
    {
        std::cout << "Hello " << s << '\n';
    }
};
 
int main(int argc, char* argv[])
{
    typedef std::function<void(const std::string&)> ExampleFunction;
    Object instance;
    std::string str("World");
    ExampleFunction f = std::bind(&Object::hello, &instance,
                                  std::placeholders::_1);
 
    // equivalent to instance.hello(str)
    f(str);
    f = std::bind(&goodbye, std::placeholders::_1);
 
    // equivalent to goodbye(str)
    f(str);
    return 0;
}

Вывод:

Hello World
Goodbye World

[править] См. также

(C++11)
связывает один или несколько аргументов функции-объекта
(шаблон функции) [править]
указывает, что объект является стандартным заполнителя или может быть использован как один
Оригинал:
indicates that an object is a standard placeholder or can be used as one
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

(шаблон класса) [править]