Как обнаружить использование std::string SSO (оптимизация короткой строки)?C++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Как обнаружить использование std::string SSO (оптимизация короткой строки)?

Сообщение Anonymous »

Если у меня длинная строка:
std::string data("This is a string long enough so that it is not a short string");

И затем я вижу эту строку:
std::string_view dataView(std::begin(data) + 5, std::end(data) - 5);

Если я перенесу исходную строку:
std::string movedData(std::move(data));

Тогда я ожидаю, что представление dataView останется действительным.
Но это предположение не выполняется, если оптимизация коротких строк std::string вступит в силу, поскольку базовая память строки не выделяется динамически, и перемещение теперь (под капотом) становится деструктивной операцией копирования, оставляя представление недействительным.
Есть ли способ обнаружить SSO (чтобы я мог предпринять соответствующие действия в своем классе) переместить конструктор)? И есть ли в стандарте какая-либо ссылка на единый вход?
Контекст
У меня есть класс, который хранит URL-адрес в виде строки, а затем доступ к каждой части URL-адреса сохраняется как представления исходного URL-адреса. Конечно, подсчет просмотров имеет свои затраты, но лучше рассчитывать их один раз, чем при каждом доступе (или это был мой мыслительный процесс). Для копии вы пересчитали представления, но при перемещении (как я думал) не требуется пересчитывать представления, так как базовое хранилище будет перемещено, и, следовательно, представления останутся действительными.
class URL
{
std::string url;
std::string_view schema;
std::string_view host;
std::string_view path;
// .. etc (for the multiple parts of a URL you can extract).
// Note: Parsing a URL correctly is non-trivial (handling IPV6, etc.).
// So I don't want to do it that often.

public:
// Default constructor.
URL() {}
// Normal constructor: Accept input by copy/move
URL(std::string urlInput)
: url(std::move(urlInput))
{
// Compute Views.
}
// Copy constructor.
URL(URL const& copy)
: url(copy.url)
{
// Compute Views.
}
// Move constructor
// I hoped I could simply swap the two objects.
// This works if there is no short string optimization.
URL(URL&& move) noexcept
{
swap(move);
}
// Assignment (both copy and move in one place).
// Use standard copy and swap idium.
URL operator=(URL assign) noexcept
{
swap(assign);
return *this;
}
// Faithful swap function.
void swap(URL& other) noexcept
{
using std::swap;
swap(url, other.url);
swap(schema, other.schema);
swap(host, other.host);
swap(path, other.path);
}

// Getter functions removed. But simply return std::string_view.
};


Подробнее здесь: https://stackoverflow.com/questions/798 ... timization
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»