Megjegyzés
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhat bejelentkezni vagy módosítani a címtárat.
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhatja módosítani a címtárat.
A ellenőrzött iterátorok biztosítják, hogy a tároló határai ne legyenek felülírva. A ellenőrzött iterátorok a kiadási buildekre és a hibakeresési buildekre is érvényesek. További információ a hibakeresési iterátorok hibakeresési módban történő használatáról: Hibakeresési iterátor támogatása.
Remarks
A bejelölt iterátorok által generált figyelmeztetések letiltásáról további információt a következő témakörben talál _SCL_SECURE_NO_WARNINGS: .
Az előfeldolgozó makróval _ITERATOR_DEBUG_LEVEL engedélyezheti vagy letilthatja a ellenőrzött iterátorok funkciót. Ha _ITERATOR_DEBUG_LEVEL 1 vagy 2 értékként van definiálva, az iterátorok nem biztonságos használata futásidejű hibát okoz, és a program leáll. Ha 0-ként van definiálva, a ellenőrzött iterátorok le vannak tiltva. Alapértelmezés szerint a kiadási buildek értéke _ITERATOR_DEBUG_LEVEL 0, a hibakeresési buildek esetében pedig 2.
Important
A régebbi dokumentáció és a forráskód a _SECURE_SCL makróra hivatkozhat. A vezérléshez _SECURE_SCLhasználható_ITERATOR_DEBUG_LEVEL. További információért lásd _ITERATOR_DEBUG_LEVEL.
Ha _ITERATOR_DEBUG_LEVEL 1 vagy 2 értékként van definiálva, a rendszer az alábbi iterátor-ellenőrzéseket hajtja végre:
A rendszer minden szabványos iterátort (például
vector::iterator) ellenőriz.Ha a kimeneti iterátor egy ellenőrzött iterátor, akkor a szokásos kódtár-függvényeket hívja meg, például
std::copyaz ellenőrzött viselkedést.Ha a kimeneti iterátor nem ellenőrzött iterátor, a szabványos kódtárfüggvényekre irányuló hívások fordítói figyelmeztetéseket okoznak.
Az alábbi függvények futásidejű hibát okoznak, ha a tároló határain kívül eső hozzáférés van:
Ha _ITERATOR_DEBUG_LEVEL 0-ként van definiálva:
Az összes standard iterátor nincs bejelölve. Az iterátorok túlléphetik a tároló határait, ami meghatározatlan viselkedéshez vezet.
Ha a kimeneti iterátor egy ellenőrzött iterátor, akkor a szokásos kódtár-függvényeket hívja meg, például
std::copyaz ellenőrzött viselkedést.Ha a kimeneti iterátor nem ellenőrzött iterátor, a standard kódtárfüggvények hívásai nem ellenőrzött viselkedést kapnak.
A ellenőrzött iterátor egy olyan iterátorra hivatkozik, amely meghívja invalid_parameter_handler , ha a tároló határain próbál túllépni. További információ: invalid_parameter_handlerParaméterérvényesítés.
A ellenőrzött iterátorokat támogató iterátoradapsztorok osztálychecked_array_iterator és unchecked_array_iterator osztály.
Examples
Amikor 1 vagy 2 értékre állítja _ITERATOR_DEBUG_LEVEL a fordítást, futásidejű hiba lép fel, ha bizonyos osztályok indexelő operátorával a tároló határain kívül eső elemet próbál elérni.
// checked_iterators_1.cpp
// cl.exe /Zi /MDd /EHsc /W4
#define _ITERATOR_DEBUG_LEVEL 1
#include <vector>
#include <iostream>
using namespace std;
int main()
{
vector<int> v;
v.push_back(67);
int i = v[0];
cout << i << endl;
i = v[1]; //triggers invalid parameter handler
}
Ez a program kinyomtatja a "67"-et, majd előugrik egy helyességi hiba párbeszédpanel, amely további információkat tartalmaz a hibáról.
Hasonlóképpen, ha 1 vagy 2 értékre állítja _ITERATOR_DEBUG_LEVEL a fordítást, futásidejű hiba lép fel, ha egy elemet front tárolóosztályokkal vagy back tárolóosztályokban próbál elérni, amikor a tároló üres.
// checked_iterators_2.cpp
// cl.exe /Zi /MDd /EHsc /W4
#define _ITERATOR_DEBUG_LEVEL 1
#include <vector>
#include <iostream>
using namespace std;
int main()
{
vector<int> v;
int& i = v.front(); // triggers invalid parameter handler
}
Ez a program előugrik egy helyességi hiba párbeszédpanelen, amely további információkat tartalmaz a hibáról.
Az alábbi kód bemutatja a különböző iterátor-használati eseteket, és mindegyikhez megjegyzéseket fűz. Alapértelmezés szerint _ITERATOR_DEBUG_LEVEL a hibakeresési buildekben 2, a kiskereskedelmi buildekben pedig 0 értékre van állítva.
// checked_iterators_3.cpp
// cl.exe /MTd /EHsc /W4
#include <algorithm>
#include <array>
#include <iostream>
#include <iterator>
#include <numeric>
#include <string>
#include <vector>
using namespace std;
template <typename C>
void print(const string& s, const C& c)
{
cout << s;
for (const auto& e : c)
{
cout << e << " ";
}
cout << endl;
}
int main()
{
vector<int> v(16);
iota(v.begin(), v.end(), 0);
print("v: ", v);
// OK: vector::iterator is checked in debug mode
// (i.e. an overrun causes a debug assertion)
vector<int> v2(16);
transform(v.begin(), v.end(), v2.begin(), [](int n) { return n * 2; });
print("v2: ", v2);
// OK: back_insert_iterator is marked as checked in debug mode
// (i.e. an overrun is impossible)
vector<int> v3;
transform(v.begin(), v.end(), back_inserter(v3), [](int n) { return n * 3; });
print("v3: ", v3);
// OK: array::iterator is checked in debug mode
// (i.e. an overrun causes a debug assertion)
array<int, 16> a4;
transform(v.begin(), v.end(), a4.begin(), [](int n) { return n * 4; });
print("a4: ", a4);
// OK: Raw arrays are checked in debug mode
// (an overrun causes a debug assertion)
// NOTE: This applies only when raw arrays are given to C++ Standard Library algorithms!
int a5[16];
transform(v.begin(), v.end(), a5, [](int n) { return n * 5; });
print("a5: ", a5);
// WARNING C4996: Pointers cannot be checked in debug mode
// (an overrun causes undefined behavior)
int a6[16];
int * p6 = a6;
transform(v.begin(), v.end(), p6, [](int n) { return n * 6; });
print("a6: ", a6);
// OK: stdext::checked_array_iterator is checked in debug mode
// (an overrun causes a debug assertion)
int a7[16];
int * p7 = a7;
transform(v.begin(), v.end(), stdext::make_checked_array_iterator(p7, 16), [](int n) { return n * 7; });
print("a7: ", a7);
// WARNING SILENCED: stdext::unchecked_array_iterator is marked as checked in debug mode
// (it performs no checking, so an overrun causes undefined behavior)
int a8[16];
int * p8 = a8;
transform(v.begin(), v.end(), stdext::make_unchecked_array_iterator(p8), [](int n) { return n * 8; });
print("a8: ", a8);
}
Ha ezt a kódot a fordító használatával cl.exe /EHsc /W4 /MTd checked_iterators_3.cpp fordítja le, figyelmeztetést ad ki, de hiba nélkül lefordítja egy végrehajtható fájlba:
algorithm(1026) : warning C4996: 'std::_Transform1': Function call with parameters
that may be unsafe - this call relies on the caller to check that the passed values
are correct. To disable this warning, use -D_SCL_SECURE_NO_WARNINGS. See documentation
on how to use Visual C++ 'Checked Iterators'
Amikor a parancssorban fut, a végrehajtható fájl a következő kimenetet hozza létre:
v: 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
v2: 0 2 4 6 8 10 12 14 16 18 20 22 24 26 28 30
v3: 0 3 6 9 12 15 18 21 24 27 30 33 36 39 42 45
a4: 0 4 8 12 16 20 24 28 32 36 40 44 48 52 56 60
a5: 0 5 10 15 20 25 30 35 40 45 50 55 60 65 70 75
a6: 0 6 12 18 24 30 36 42 48 54 60 66 72 78 84 90
a7: 0 7 14 21 28 35 42 49 56 63 70 77 84 91 98 105
a8: 0 8 16 24 32 40 48 56 64 72 80 88 96 104 112 120
See also
A C++ standard kódtár áttekintése
Iterator-támogatás hibakeresése