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

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

Материал из cppreference.com
< cpp‎ | string‎ | basic string
 
 
 
std::basic_string
Функции-элементы
Доступ к элементам
Итераторы
Ёмкость
Операции
basic_string::copy
Поиск
Константы
Правила вывода (C++17)
Функции, не являющиеся элементами
Ввод/Вывод
Сравнение
(до C++20)(до C++20)(до C++20)(до C++20)(до C++20)(C++20)
Числовые преобразования
(C++11)(C++11)(C++11)
(C++11)(C++11)
(C++11)(C++11)(C++11)
(C++11)
(C++11)
Вспомогательные классы
 
size_type copy( CharT* dest, size_type count, size_type pos = 0 ) const;
(до C++20)
constexpr size_type copy( CharT* dest, size_type count, size_type pos = 0 ) const;
(начиная с C++20)

Копирует подстроку [pospos + count) в строку символов, на которую указывает dest. Если запрошенная подстрока выходит за конец строки или если count == npos, скопированная подстрока имеет вид [possize()).

Результирующая строка символов не заканчивается нулём.

Содержание

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

dest указатель на строку символов назначения
count длина подстроки
pos позиция первого символа, который будет включен

[править] Возвращаемое значение

Количество скопированных символов.

[править] Исключения

std::out_of_range, если pos > size().

Если по какой-либо причине генерируется исключение, эта функция не имеет эффекта (строгая гарантия безопасности исключений).

[править] Сложность

Линейная по count.

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

#include <iostream>
#include <string>
 
int main()
{
    std::string foo("WINE");
 
    // инициализация скобками инициализирует все символы значением 0,
    // обеспечивая нулевой терминатор
    char bar[4]{};
 
    // не копируйте последний символ, чтобы гарантировать нулевое завершение
    foo.copy(bar, sizeof bar - 1);
 
    std::cout << bar << '\n'; // требует, чтобы bar заканчивался нулём
}

Вывод:

WIN

[править] Отчёты о дефектах

Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:

Номер Применён Поведение в стандарте Корректное поведение
LWG 847 C++98 не было гарантии безопасности исключений добавлена надёжная гарантия безопасности исключений

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

возвращает подстроку
(public функция-элемент) [править]
(C++17)
копирует символы
(public функция-элемент std::basic_string_view<CharT,Traits>) [править]
копирует диапазон элементов в новое место
(шаблон функции) [править]
копирует один буфер в другой
(функция) [править]