C++ за 21 день седьмое издание



Download 1,38 Mb.
bet297/437
Sana22.02.2022
Hajmi1,38 Mb.
#89455
TuriРеферат
1   ...   293   294   295   296   297   298   299   300   ...   437
Bog'liq
word1

Vector of

integers

wasinstantiated with

Size: 5,

Capacity:

5

After inserting an

additionalelement...

Size: 6,

Capacity:

7

After inserting yet another element...

Size: 7, Capacity:

7



Анализ



    1. строке 8 показано создание экземпляра вектора целых чисел, способного изначально содержать пять целых чисел со значением по умолчанию (0). Строки 11 и 12 отображают размер и емкость вектора соответственно, свидетельствуя, что во время создания экзем­ пляра они равны. В строке 9 в вектор вставляется шестой элемент. Поскольку емкость вектора до вставки была пять, во внутреннем буфере вектора нет места для сохранения этого нового элемента. Другими словами, для сохранения шестого элемента класс v e c to r должен повторно зарезервировать свой внутренний буфер. Реализация логики повторного резервирования достаточно интеллектуальна, чтобы избежать очередного резервирования при вставке следующего элемента; она преимущ ественно резервирует емкость, превос­ ходящую требования текущего момента.

Вывод демонстрирует это при вставке в вектор емкостью пять элементов ш естого элемента — повторное резервирование увеличивает емкость до семи элементов. Метод s i z e () всегда отображает количество элементов в векторе и имеет на данном этапе зна­ чение шесть. Добавление седьмого элемента в строке 22 не приводит к увеличению емко­ сти — имеющейся памяти вполне достаточно. На данном этапе и размер, и емкость имеют одинаковое значение, указывая, что вектор заполнен полностью и вставка следующего элемента приведет к резервированию вектором нового внутреннего буфера, копированию





  1. него существующих значений и вставке нового значения.






14 Зак. 3626

418 ЗАНЯТИЕ 17. Классы динамических массивов библиотеки STL


ПРИМЕЧАНИЕ Избыточное увеличение емкости внутреннего буфера вектора не регулируется никакими стандартными директивами. Это зависит от разновидности исполь­ зуемой библиотеки STL.

Download 1,38 Mb.

Do'stlaringiz bilan baham:
1   ...   293   294   295   296   297   298   299   300   ...   437




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2024
ma'muriyatiga murojaat qiling

kiriting | ro'yxatdan o'tish
    Bosh sahifa
юртда тантана
Боғда битган
Бугун юртда
Эшитганлар жилманглар
Эшитмадим деманглар
битган бодомлар
Yangiariq tumani
qitish marakazi
Raqamli texnologiyalar
ilishida muhokamadan
tasdiqqa tavsiya
tavsiya etilgan
iqtisodiyot kafedrasi
steiermarkischen landesregierung
asarlaringizni yuboring
o'zingizning asarlaringizni
Iltimos faqat
faqat o'zingizning
steierm rkischen
landesregierung fachabteilung
rkischen landesregierung
hamshira loyihasi
loyihasi mavsum
faolyatining oqibatlari
asosiy adabiyotlar
fakulteti ahborot
ahborot havfsizligi
havfsizligi kafedrasi
fanidan bo’yicha
fakulteti iqtisodiyot
boshqaruv fakulteti
chiqarishda boshqaruv
ishlab chiqarishda
iqtisodiyot fakultet
multiservis tarmoqlari
fanidan asosiy
Uzbek fanidan
mavzulari potok
asosidagi multiservis
'aliyyil a'ziym
billahil 'aliyyil
illaa billahil
quvvata illaa
falah' deganida
Kompyuter savodxonligi
bo’yicha mustaqil
'alal falah'
Hayya 'alal
'alas soloh
Hayya 'alas
mavsum boyicha


yuklab olish