官术网_书友最值得收藏!

Algorithms that affect object lifetime

The <memory> header provides an obscure family of algorithms with names such as std::uninitialized_copy, std::uninitialized_default_construct, and std::destroy (for the full list, consult an online reference such as cppreference.com). Consider the following algorithm that uses explicit destructor calls to destroy the elements of a range:

    template<class T>
void destroy_at(T *p)
{
p->~T();
}

template<class FwdIt>
void destroy(FwdIt first, FwdIt last)
{
for ( ; first != last; ++first) {
std::destroy_at(std::addressof(*first));
}
}

Notice that std::addressof(x) is a convenient little helper function that returns the address of its parameter; it's exactly the same thing as &x except in the rare case that x is of some class type that sadistically overloads its own operator&.

And consider this algorithm that uses explicit placement-new syntax to "copy-construct into" the elements of a range (notice how it neatly cleans up after itself if an exception is thrown during the copying). This algorithm clearly shouldn't be used on any range whose elements already exist; so the following example looks very contrived:

    template<class It, class FwdIt>
FwdIt uninitialized_copy(It first, It last, FwdIt out)
{
using T = typename std::iterator_traits<FwdIt>::value_type;
FwdIt old_out = out;
try {
while (first != last) {
::new (static_cast<void*>(std::addressof(*out))) T(*first);
++first;
++out;
}
return out;
} catch (...) {
std::destroy(old_out, out);
throw;
}
}

void test()
{
alignas(std::string) char b[5 * sizeof (std::string)];
std::string *sb = reinterpret_cast<std::string *>(b);

std::vector<const char *> vec = {"quick", "brown", "fox"};

// Construct three std::strings.
auto end = std::uninitialized_copy(vec.begin(), vec.end(), sb);

assert(end == sb + 3);

// Destroy three std::strings.
std::destroy(sb, end);
}

We'll see more about how these algorithms are meant to be used in Chapter 4, The Container Zoo, when we talk about std::vector.

主站蜘蛛池模板: 福海县| 桃园县| 德兴市| 二连浩特市| 汉中市| 文安县| 大同县| 宽甸| 阿克苏市| 巴东县| 铜鼓县| 鹿泉市| 扶风县| 光山县| 延安市| 于都县| 盘山县| 贺兰县| 成武县| 平罗县| 沁水县| 乐业县| 安泽县| 蓝山县| 南京市| 南宁市| 丰台区| 桐乡市| 厦门市| 来安县| 习水县| 和平区| 额敏县| 涿鹿县| 徐州市| 彰武县| 龙山县| 修水县| 长沙县| 凌源市| 临夏市|