LoveRead.info » Книги » Разная литература » Программирование. Принципы и практика использования C++ Исправленное издание - Бьёрн Страуструп

Программирование. Принципы и практика использования C++ Исправленное издание - Бьёрн Страуструп

Книгу Программирование. Принципы и практика использования C++ Исправленное издание - Бьёрн Страуструп читаем онлайн бесплатно полную версию! Чтобы начать читать не надо регистрации. Напомним, что читать онлайн вы можете не только на компьютере, но и на андроид (Android), iPhone и iPad. Приятного чтения!

292 0 18:03, 26-08-2023
Программирование. Принципы и практика использования C++ Исправленное издание - Бьёрн Страуструп
26 август 2023

Книга Программирование. Принципы и практика использования C++ Исправленное издание - Бьёрн Страуструп читать онлайн бесплатно без регистрации

Специальное издание самой читаемой и содержащей наиболее достоверные сведения книги по C++. Книга написана Бьярне Страуструпом — автором языка программирования C++ — и является каноническим изложением возможностей этого языка. Помимо подробного описания собственно языка, на страницах книги вы найдете доказавшие свою эффективность подходы к решению разнообразных задач проектирования и программирования. Многочисленные примеры демонстрируют как хороший стиль программирования на С-совместимом ядре C++, так и современный -ориентированный подход к созданию программных продуктов. Третье издание бестселлера было существенно переработано автором. Результатом этой переработки стала большая доступность книги для новичков. В то же время, текст обогатился сведениями и методиками программирования, которые могут оказаться полезными даже для многоопытных специалистов по C++. Не обойдены вниманием и нововведения языка: стандартная библиотека шаблонов (STL), пространства имен (namespaces), механизм идентификации типов во время выполнения (RTTI), явные приведения типов (cast-операторы) и другие. Настоящее специальное издание отличается от третьего добавлением двух новых приложений (посвященных локализации и безопасной обработке исключений средствами стандартной библиотеки), довольно многочисленными уточнениями в остальном тексте, а также исправлением множества опечаток. Книга адресована программистам, использующим в своей повседневной работе C++. Она также будет полезна преподавателям, студентам и всем, кто хочет ознакомиться с описанием языка «из первых рук».

    1 ... 172 173 174 175 176 177 178 179 180 ... 337
    Перейти на страницу:
    Shape, поскольку класс Shape является открытым базовым классом по отношению к классу Circle. Рассмотрим пример.

    void rotate(Shape* s, int n); // поворачиваем фигуру *s на угол n

    Shape* p = new Circle(Point(100,100),40);

    Circle c(Point(200,200),50);

    rotate(&c,45);

    Это можно сделать и с помощью ссылок.

    void rotate(Shape& s, int n); // поворачиваем фигуру *s на угол n

    Shape& r = c;

    rotate(c,75);

    Этот факт является чрезвычайно важным для большинства объектно-ориентированных технологий программирования (см. разделы 14.3, 14.4).

    17.9.3. Пример: списки

    Наиболее распространенными и полезными структурами данных являются списки. Как правило, список создается с помощью узлов, каждый из которых содержит определенную информацию и указатель на другие узлы. Это — классический пример использования указателей. Например, короткий список норвежских богов можно представить в следующем виде.

     

     Такой список называют двусвязным (doubly-linked list), поскольку в нем существуют предшествующий и последующий узлы. Список, в котором существуют только последующие узлы, называют односвязным (singly-linked list). Мы используем двусвязные узлы, когда хотим облегчить удаление элемента. Узлы списка определяются следующим образом:

    struct Link {

      string value;

      Link* prev;

      Link* succ;

      Link(const string& v,Link* p = 0,Link* s = 0)

          :value(v),prev(p),succ(s) { }

    };

    Иначе говоря, имея объект типа Link, мы можем получить доступ к последующему элементу, используя указатель succ, а к предыдущему элементу — используя указатель prev. Нулевой указатель позволяет указать, что узел не имеет предшествующего или последующего узла. Список норвежских богов можно закодировать так:

    Link* norse_gods = new Link("Thor",0,0);

    norse_gods = new Link("Odin",0,norse_gods);

    norse_gods–>succ–>prev = norse_gods;

    norse_gods = new Link("Freia",0,norse_gods);

    norse_gods–>succ–>prev = norse_gods;

    Мы создали этот список с помощью структуры Link: во главе списка находится Тор, за ним следует Один, являющийся предшественником Тора, а завершает список Фрея — предшественница Одина. Следуя за указателями. можете убедиться, что мы правы и каждый указатель succ и prev ссылается на правильного бога. Однако этот код мало понятен, так как мы не определили явно и не присвоили имя операции вставки.

    Link* insert(Link* p, Link* n) // вставка n перед p ( фрагмент )

    {

      n–>succ = p;       // p следует после n

      p–>prev–>succ = n; // n следует после предшественника p

      n–>prev = p–>prev; // предшественник p становится

                         // предшественником n

      p–>prev = n;       // n становится предшественником p

      return n;

    }

    Этот фрагмент программы работает, если указатель p действительно ссылается на объект типа Link и этот объект действительно имеет предшественника. Убедитесь, что это именно так. Размышляя об указателях и связанных структурах, таких как список, состоящий из объектов типа Link, мы практически всегда рисуем на бумаге диаграммы, состоящие из прямоугольников и стрелок, чтобы проверить программу на небольших примерах. Пожалуйста, не пренебрегайте этим эффективным средством.

    Приведенная версия функции insert() неполна, поскольку в ней не предусмотрен случай, когда указатели n, p или p–>prev равны 0. Добавив соответствующую проверку, мы получим немного более сложный, но зато правильный вариант функции insert.

    Link* insert(Link* p, Link* n) // вставляет n перед p; возвращает n

    {

      if (n==0) return p;

      if (p==0) return n;

      n–>succ = p;         // p следует после n

      if (p–>prev) p–>prev–>succ = n;

      n–>prev = p–>prev;   // предшественник p становится

                           // предшественником n

      p–>prev = n;         // n становится предшественником p

      return n;

    }

    В этом случае мы можем написать такой код:

    Link* norse_gods = new Link("Thor");

    norse_gods = insert(norse_gods,new Link("Odin"));

    norse_gods = insert(norse_gods,new Link("Freia"));

     

     Теперь все возможные неприятности, связанные с указателями prev и succ, исключены. Проверка корректности указателей очень утомительна и подвержена ошибкам, поэтому ее обязательно следует скрывать в хорошо спроектированных и тщательно проверенных функциях. В частности, многие ошибки в программах возникают оттого, что программисты забывают проверять, не равен ли указатель нулю, — как это было (преднамеренно) продемонстрировано в первой версии функции insert().

    Обратите внимание на то, что мы использовали аргументы по умолчанию (см. разделы 15.3.1, A.9.2), чтобы освободить пользователей от необходимости указывать предшествующие и последующие элементы в каждом вызове конструктора.

    17.9.4. Операции над списками

     Стандартная библиотека содержит класс list, который будет описан в разделе 20.4. В нем реализованы все необходимые операции, но в данном разделе мы самостоятельно разработаем список, основанный на классе Link, чтобы узнать, что скрывается “под оболочкой” стандартного списка, и продемонстрировать еще несколько примеров использования указателей.

    Какие операции необходимы пользователю, чтобы избежать ошибок, связанных с указателями? В некотором смысле это дело вкуса, но мы все же приведем полезный набор.

    • Конструктор.

    • insert: вставка перед элементом.

    • add: вставка после элемента.

    • erase: удаление элемента.

    • find: поиск узла с заданным значением.

    • advance: переход к n-му последующему узлу.

    Эти операции можно написать следующим образом:

    Link* add(Link* p,Link* n) // вставляет n после p; возвращает n

    {

      // напоминает insert (см. упр. 11)

    }

    Link* erase(Link* p) // удаляет узел *p из списка; возвращает

                         // следующий за p

    {

      if (p==0) return 0;

      if (p–>succ) p–>succ–>prev = p–>prev;

      if (p–>prev) p–>prev–>succ = p–>succ;

      return p–>succ;

    }

    Link* find(Link* p,const string& s) // находит s в списке;

                                        // если не находит, возвращает 0

    {

      while(p) {

        if (p–>value == s) return p;

        p = p–>succ;

      }

      return 0;

    }

    Link* advance(Link* p,int n) // удаляет n позиций из списка

     // если не находит, возвращает 0

     // при положительном n переносит указатель на n узлов вперед,

     // при отрицательном — на n узлов назад

    {

      if (p==0) return 0;

      if (0<n)

    1 ... 172 173 174 175 176 177 178 179 180 ... 337
    Перейти на страницу:
    1. Жалоба
    Отзывы - 0

    Прочитали книгу? Предлагаем вам поделится своим отзывом от прочитанного(прослушанного)! Ваш отзыв будет полезен читателям, которые еще только собираются познакомиться с произведением.


    Уважаемые читатели, слушатели и просто посетители нашей библиотеки! Просим Вас придерживаться определенных правил при комментировании литературных произведений.

    • 1. Просьба отказаться от дискриминационных высказываний. Мы защищаем право наших читателей свободно выражать свою точку зрения. Вместе с тем мы не терпим агрессии. На сайте запрещено оставлять комментарий, который содержит унизительные высказывания или призывы к насилию по отношению к отдельным лицам или группам людей на основании их расы, этнического происхождения, вероисповедания, недееспособности, пола, возраста, статуса ветерана, касты или сексуальной ориентации.
    • 2. Просьба отказаться от оскорблений, угроз и запугиваний.
    • 3. Просьба отказаться от нецензурной лексики.
    • 4. Просьба вести себя максимально корректно как по отношению к авторам, так и по отношению к другим читателям и их комментариям.

    Надеемся на Ваше понимание и благоразумие. С уважением, администратор LoveRead.info.


    Установить VPN и читай слушай бесплатно

    Новые отзывы

    1. Борис Борис14 июнь 00:50 Колокола в России тем и отличались от западных что раскачиаали именно язык колокола,а не сам колокол! Авторы что-жертвы ЕГЭ? Не... Соединенные Штаты России 3 - Полина Ром
    2. Людмила Хофман Людмила Хофман10 июнь 22:13 У меня перевернулся мир после прочтения ваших книг! Так приятно и чисто на душе, ведь по сути неважно кто с кем , а только любовь... Долгая игра - Рейчел Рид
    3. Анна Анна08 июнь 11:28 Спасибо за новую историю жизни и любви на сайте,прочитала с удовольствием .... Давай поженимся - Юлия Резник
    Все комметарии
    Новинки бесплатной онлайн библиотеки