Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
 Аватар для mat_for_c
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972

Ищу книгу

10.09.2017, 14:46. Показов 1062. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Ищу книгу (или статью), в которой рассказывается о возможных своих реализациях, скажем std::vector, которые позволяют обогнать стандартный вектор в зависимости от конкретных задач. Если не ошибаюсь, то видел упоминание о ней в чьем-то посте, но несколько лет назад, поэтому автора не помню . Кто-нибудь может помочь?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
10.09.2017, 14:46
Ответы с готовыми решениями:

Ищу книгу
Доброе время суток. Не пинайте если не туда написал. Сабжект, собственно "Язык программирования C"(авторы Харбисон и...

Ищу книгу С. Прата
Всем добрый день! ищу книгу Стивена Прата "Язык программирования C (Си). Лекции и упражнения, 5-е издание" В интернете не нашёл, так...

Ищу хорошую книгу
Подскажите хорошую книгу по С++. С практическими задачами(только без математики), что бы примеры были полезны в жизни. Наподобие П....

8
Каждому свое
 Аватар для Bretbas
533 / 219 / 81
Регистрация: 05.08.2013
Сообщений: 1,614
10.09.2017, 15:07
mat_for_c, а что за задачи Вы приследуете? Стандартная реализация std::vector довольно простая. Происходит расширение вектора при добавление нового элемента в том случае, если size становится > чем capacity. Ну и всякие еще оптимизации
0
 Аватар для mat_for_c
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
10.09.2017, 15:13  [ТС]
Цитата Сообщение от Bretbas Посмотреть сообщение
а что за задачи Вы приследуете
Вот эти :
Цитата Сообщение от Bretbas Посмотреть сообщение
Ну и всякие еще оптимизации
0
Каждому свое
 Аватар для Bretbas
533 / 219 / 81
Регистрация: 05.08.2013
Сообщений: 1,614
10.09.2017, 15:24
mat_for_c, Ну там вроде и так достаточно хорошо оптимизировано.
При добавлении элемента происходит следующее:
проверяется размер size больше ли емкости capacity?
если нет, то просто добавляем элемент в позицию arr[size] = value и прибавляем к size единичку size++
если да, то емкость capacity увеличивается в два раза, распределяется новая память в куче с размером новой емкостью capacity. Причем, если вам не нравится как распределяет память оператор new, то Вы можете написать свой аллокатор и передать его как второй необязательный шаблонный параметр в std::vector. Затем, (внимание оптимизация из коробки!) все элементы из старого массива перемещаются в новый, и старого теперь не существует. И также size++
Что еще можно оптимизировать?
1
19497 / 10102 / 2461
Регистрация: 30.01.2014
Сообщений: 17,813
10.09.2017, 15:29
Цитата Сообщение от mat_for_c Посмотреть сообщение
видел упоминание о ней в чьем-то посте
Не эта книга?
http://www.ozon.ru/context/detail/id/140145932/
3
Каждому свое
 Аватар для Bretbas
533 / 219 / 81
Регистрация: 05.08.2013
Сообщений: 1,614
10.09.2017, 15:34
DrOffset, Достойная? Стоит почитать?
0
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
10.09.2017, 15:34
Можно взять исходники libstdc++ и посмотреть, как там всё реализовано

В абстрактное постановке ускорение не имеет смысла, потому что в каждом компиляторе своя реализация всего std
0
19497 / 10102 / 2461
Регистрация: 30.01.2014
Сообщений: 17,813
10.09.2017, 15:35
Цитата Сообщение от Bretbas Посмотреть сообщение
Достойная? Стоит почитать?
Начинающий может почитать. Книжка неплохая.
0
 Аватар для mat_for_c
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
10.09.2017, 18:19  [ТС]
Цитата Сообщение от DrOffset Посмотреть сообщение
Не эта книга?
возможно)
я помню, где-то читал предисловие со словами "Приветствую вас! Меня зовут ... и я кодоголик."
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.09.2017, 18:19
Помогаю со студенческими работами здесь

Ищу сайт или книгу
Вот ищу сайт или книгу где есть много команд С++ и их описание. я понимаю что всех сразу не найти но если кто знает где они есть то...

Ищу книгу о сетевом программировании на с++
Можете подсказать какую-нибудь книгу о сетевом программировании на с++. Буду признателен.

Ищу пособие (книгу), по программированию на C++ для чайников
Подскажите какое-нибудь пособие(книгу),по программированию с++ для чайников,пожалуйста

ищу электронную книгу, в которой бы было написано про графы в с
хочу скачать бесплатно книгу, в которой бы было написано про графы, формы их представления, достижимость и обходы, алгоритмы Дейкстры! или...

Ищу книгу
Ищу книгу http://citforum.ru/book/cook/winsock.shtml Секреты поваров компьютерной кухни или ПК: решение проблем Касперски К. ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru