Скотт Мейерс - Эффективный и современный С++. 42 рекомендации по использованию С++11 и С++14

Здесь есть возможность читать онлайн «Скотт Мейерс - Эффективный и современный С++. 42 рекомендации по использованию С++11 и С++14» весь текст электронной книги совершенно бесплатно (целиком полную версию без сокращений). В некоторых случаях можно слушать аудио, скачать через торрент в формате fb2 и присутствует краткое содержание. Город: Москва, Год выпуска: 2016, ISBN: 2016, Издательство: Вильямс, Жанр: Программирование, на русском языке. Описание произведения, (предисловие) а так же отзывы посетителей доступны на портале библиотеки ЛибКат.

Эффективный и современный С++. 42 рекомендации по использованию С++11 и С++14: краткое содержание, описание и аннотация

Предлагаем к чтению аннотацию, описание, краткое содержание или предисловие (зависит от того, что написал сам автор книги «Эффективный и современный С++. 42 рекомендации по использованию С++11 и С++14»). Если вы не нашли необходимую информацию о книге — напишите в комментариях, мы постараемся отыскать её.

Эффективный и современный С++
В книге рассматриваются следующие темы. Освоение С++11 и С++14 — это больше, чем просто ознакомление с вводимыми этими стандартами возможностями (например, объявлениями типов
, семантикой перемещения, лямбда-выражениями или поддержкой многопоточности). Вопрос в том, как использовать их эффективно, чтобы создаваемые программы были корректны, эффективны и переносимы, а также чтобы их легко можно было сопровождать. Именно этим вопросам и посвящена данная книга, описывающая создание по-настоящему хорошего программного обеспечения с использованием C++11 и С++14 — т.е. с использованием современного С++.
■ Преимущества и недостатки инициализации с помощью фигурных скобок, спецификации
, прямой передачи и функций
интеллектуальных указателей
■ Связь между
,
, rvalue-ссылками и универсальными ссылками
■ Методы написания понятных, корректных,
лямбда-выражений
■ Чем
отличается от
, как они используются и как соотносятся с API параллельных вычислений С++
■ Какие из лучших методов “старого” программирования на С++ (т.е. С++98) должны быть пересмотрены при работе с современным С++
Более чем 20 лет книги
серии
являются критерием уровня книг по программированию на С++. Понятное пояснение сложного технического материала принесло ему всемирную известность. Он всегда самый желанный гость на международных конференциях, а его услуги консультанта широко востребованы во всем мире.
Скотт Мейерс Эффективный и современный С++, После изучения основ С++ я перешел к изучению того, как применять С++ в промышленном программировании, с помощью серии книг Скотта Мейерса Эффективный С++. Эффективный и современный С++ — наиболее важная из книг серии, предлагающая ключевые рекомендации, стили и идиомы, позволяющие эффективно использовать современный С++. Вы еще не купили эту книгу? Сделайте это прямо сейчас. Герб Саттер,
глава Комитета ISO по стандартизации С++, специалист в области архитектуры программного обеспечения на С++ в Microsoft

Эффективный и современный С++. 42 рекомендации по использованию С++11 и С++14 — читать онлайн бесплатно полную книгу (весь текст) целиком

Ниже представлен текст книги, разбитый по страницам. Система сохранения места последней прочитанной страницы, позволяет с удобством читать онлайн бесплатно книгу «Эффективный и современный С++. 42 рекомендации по использованию С++11 и С++14», без необходимости каждый раз заново искать на чём Вы остановились. Поставьте закладку, и сможете в любой момент перейти на страницу, на которой закончили чтение.

Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

Для исправления ситуации надо просто обеспечить полноту типа Widget::Implв точке, где генерируется код, уничтожающий std::unique_ptr. Тип становится полным, когда его определение становится видимым, а Widget::Implопределен в файле widget.cpp. Ключом к успешной компиляции является требование, чтобы компилятор видел тело деструктора Widget(т.e. место, где компилятор будет генерировать код для уничтожения члена-данных std::unique_ptr) только внутри widget.cpp, после определения Widget::Impl.

Добиться этого просто. Объявим деструктор Widgetв widget.h, но не будем определять его там:

class Widget { // Как и ранее, в файле "widget.h"

public:

Widget();

~Widget(); // Только объявление

private: // Как и ранее

struct Impl;

std::unique_ptr pImpl;

};

Определим его в widget.cppпосле определения Widget::Impl:

#include "widget.h" // Как и ранее, в файле "widget.cpp"

#include "gadget.h"

#include

#include

struct Widget::Impl { // Как и ранее, определение

std::string name; // Widget::Impl

std::vector data;

Gadget g1, g2, g3;

};

Widget::Widget() // Как и ранее

: pImpl(std::make_unique()) {}

Widget::~Widget() // Определение ~Widget

{}

Это хорошо работает и требует небольшого набора текста, но если вы хотите подчеркнуть, что генерируемый компилятором деструктор работает верно, что единственная причина его объявления — генерация его определения в файле реализации Widget, то вы можете определить тело деструктора как = default:

Widget::~Widget() = default; // Тот же результат, что и выше

Классы, использующие идиому Pimpl, являются естественными кандидатами на поддержку перемещения, поскольку генерируемые компилятором операции перемещения делают именно то, что требуется: выполняют перемещение std::unique_ptr. Как поясняется в разделе 3.11, объявление деструктора Widgetпрепятствует генерации компилятором операций перемещения, так что, если вы хотите обеспечить их поддержку, вы должны объявить их самостоятельно. Поскольку генерируемые компилятором версии ведут себя так, как надо, соблазнительно реализовать их следующим образом:

class Widget { // В "widget.h"

public:

Widget();

~Widget();

Widget(Widget&& rhs) = default; // Идея верна,

Widget& operator=(Widget&& rhs) = default;// код – нет!

private: // Как и ранее

struct Impl;

std::unique_ptr pImpl;

};

Этот подход приводит к тем же проблемам, что и объявление класса без деструктора, и по той же самой причине. Генерируемый компилятором оператор перемещающего присваивания должен уничтожить объект, на который указывает pImpl, перед тем как присвоить указателю новое значение, но в заголовочном файле Widgetуказатель pImplуказывает на неполный тип. Ситуация отличается для перемещающего конструктора. Проблема в том, что компиляторы обычно генерируют код для уничтожения pImplв том случае, когда в перемещающем конструкторе генерируется исключение, а уничтожение pImplтребует, чтобы тип Implбыл полным.

Поскольку проблема точно такая же, как и ранее, то и решение ее такое же — перенос определений перемещающих операций в файл реализации:

class Widget { // В файле "widget.h"

public:

Widget();

~Widget();

Widget(Widget&& rhs); // Только объявления

Widget& operator=(Widget&& rhs);

private: // Как и ранее

struct Impl;

std::unique_ptr pImpl;

};

#include // В файле "widget.cpp"

struct Widget:: Impl { … }; // Как и ранее

Widget::Widget() // Как и ранее

: pImpl(std::make_unique())

{}

Widget::~Widget() = default; // Как и ранее

// Определения:

Widget::Widget(Widget&& rhs) = default;

Widget& Widget::operator=(Widget&& rhs) = default;

Идиома Pimplпредставляет собой способ снижения зависимости между реализацией класса и его клиентами, но концептуально идиома не меняет то, что представляет собой класс. Исходный класс Widgetсодержал члены-данные std::string, std::vectorи Gadget, так что в предположении, что объекты Gadget, как и объекты std::stringи std::vector, могут копироваться, имеет смысл в поддержке классом Widget копирующих операций. Мы должны написать эти функции самостоятельно, поскольку (1) компиляторы не генерируют копирующие операции для классов с типами, поддерживающими только перемещение (наподобие std::unique_ptr) и (2) даже если бы они генерировались, то такие функции выполняли бы копирование только указателя std::unique_ptr(т.e. выполняли бы мелкое копирование ), а мы хотим копировать то, на что указывает этот указатель (т.e. выполнять глубокое копирование ).

Читать дальше
Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

Похожие книги на «Эффективный и современный С++. 42 рекомендации по использованию С++11 и С++14»

Представляем Вашему вниманию похожие книги на «Эффективный и современный С++. 42 рекомендации по использованию С++11 и С++14» списком для выбора. Мы отобрали схожую по названию и смыслу литературу в надежде предоставить читателям больше вариантов отыскать новые, интересные, ещё непрочитанные произведения.


Отзывы о книге «Эффективный и современный С++. 42 рекомендации по использованию С++11 и С++14»

Обсуждение, отзывы о книге «Эффективный и современный С++. 42 рекомендации по использованию С++11 и С++14» и просто собственные мнения читателей. Оставьте ваши комментарии, напишите, что Вы думаете о произведении, его смысле или главных героях. Укажите что конкретно понравилось, а что нет, и почему Вы так считаете.

x