Boost C++ Libraries Home Libraries People FAQ More

PrevUpHomeNext
url_base::persist

(Inherited from url_view_base)

Return a shared, persistent copy of the URL.

Synopsis
std::shared_ptr< url_view const >
persist() const;
Description

This function returns a read-only copy of the URL, with shared lifetime. The returned value owns (persists) the underlying string. The algorithm used to create the value minimizes the number of individual memory allocations, making it more efficient than when using direct standard library functions.

Example
std::shared_ptr< url_view const > sp;
{
    std::string s( "http://example.com" );
    url_view u( s );                        // u references characters in s

    assert( u.data() == s.data() );         // same buffer

    sp = u.persist();

    assert( sp->data() != s.data() );       // different buffer
    assert( sp->buffer() == s);             // same contents

    // s is destroyed and thus u
    // becomes invalid, but sp remains valid.
}
Complexity

Linear in this->size().

Exception Safety

Calls to allocate may throw.


PrevUpHomeNext