Classe checked_array_iterator
A classe checked_array_iterator
permite que você transforme uma matriz ou um ponteiro em um iterador verificado. Use essa classe como um wrapper (usando a função make_checked_array_iterator) para matrizes ou ponteiros brutos como uma maneira direcionada de fornecer verificação e gerenciar avisos de ponteiros não verificados, em vez de silenciar esses avisos globalmente. Se necessário, você pode usar a versão não verificada da classe, unchecked_array_iterator.
Observação
Essa classe é uma extensão da Microsoft da Biblioteca Padrão C++. O código implementado usando essa função não é portátil para ambientes de criação do C++ Standard que não oferecem suporte a essa extensão da Microsoft. Para ver um exemplo que demonstra como escrever código que não exige uso dessa classe, veja o segundo exemplo abaixo.
Sintaxe
template <class _Iterator>
class checked_array_iterator;
Comentários
Essa classe é definida no namespace stdext.
Para obter mais informações e o código de exemplo sobre o recurso de iterador verificado, consulte Iteradores verificados.
Exemplos
O exemplo a seguir mostra como definir e usar um iterador de matriz verificado.
Se o destino não for grande o suficiente para armazenar todos os elementos que estão sendo copiados, como seria se você tivesse alterado a linha:
copy(a, a + 5, checked_array_iterator<int*>(b, 5));
até
copy(a, a + 5, checked_array_iterator<int*>(b, 4));
Ocorrerá um erro de runtime.
// compile with: /EHsc /W4 /MTd
#include <algorithm>
#include <iostream>
using namespace std;
using namespace stdext;
int main() {
int a[]={0, 1, 2, 3, 4};
int b[5];
copy(a, a + 5, checked_array_iterator<int*>(b, 5));
cout << "(";
for (int i = 0 ; i < 5 ; i++)
cout << " " << b[i];
cout << " )" << endl;
// constructor example
checked_array_iterator<int*> checked_out_iter(b, 5);
copy(a, a + 5, checked_out_iter);
cout << "(";
for (int i = 0 ; i < 5 ; i++)
cout << " " << b[i];
cout << " )" << endl;
}
/* Output:
( 0 1 2 3 4 )
( 0 1 2 3 4 )
*/
Para evitar a necessidade da classe checked_array_iterator
ao usar algoritmos da Biblioteca Padrão C++, pense em usar um vector
, em vez de uma matriz dinamicamente alocada. O exemplo a seguir demonstra como fazer isso.
// compile with: /EHsc /W4 /MTd
#include <algorithm>
#include <iostream>
#include <vector>
using namespace std;
int main()
{
std::vector<int> v(10);
int *arr = new int[10];
for (int i = 0; i < 10; ++i)
{
v[i] = i;
arr[i] = i;
}
// std::copy(v.begin(), v.end(), arr); will result in
// warning C4996. To avoid this warning while using int *,
// use the Microsoft extension checked_array_iterator.
std::copy(v.begin(), v.end(),
stdext::checked_array_iterator<int *>(arr, 10));
// Instead of using stdext::checked_array_iterator and int *,
// consider using std::vector to encapsulate the array. This will
// result in no warnings, and the code will be portable.
std::vector<int> arr2(10); // Similar to int *arr = new int[10];
std::copy(v.begin(), v.end(), arr2.begin());
for (int j = 0; j < arr2.size(); ++j)
{
cout << " " << arr2[j];
}
cout << endl;
return 0;
}
/* Output:
0 1 2 3 4 5 6 7 8 9
*/
Construtores
Construtor | Descrição |
---|---|
checked_array_iterator | Constrói um checked_array_iterator padrão ou um checked_array_iterator de um iterador subjacente. |
Typedefs
Nome do tipo | Descrição |
---|---|
difference_type | Um tipo que fornece a diferença entre dois checked_array_iterator s que se referem a elementos no mesmo contêiner. |
pointer | Um tipo que fornece um ponteiro para um elemento tratado por um checked_array_iterator . |
referência | Um tipo que fornece uma referência a um elemento tratado por um checked_array_iterator . |
Funções de membro
Função de membro | Descrição |
---|---|
base | Recupera o iterador subjacente de seu checked_array_iterator . |
Operadores
Operador | Descrição |
---|---|
operator== | Testa a igualdade de dois checked_array_iterator s. |
operator!= | Testa a desigualdade de dois checked_array_iterator s. |
operator< | Testa se o checked_array_iterator à esquerda do operador é menor que o checked_array_iterator à direita. |
operator> | Testa se o checked_array_iterator à esquerda do operador é maior que o checked_array_iterator à direita. |
operator<= | Testa se o checked_array_iterator à esquerda do operador é menor ou igual ao checked_array_iterator à direita. |
operator>= | Testa se o checked_array_iterator à esquerda do operador é maior ou igual ao checked_array_iterator à direita. |
operator* | Retorna o elemento tratado por um checked_array_iterator . |
operator-> | Retorna um ponteiro para o elemento tratado pelo checked_array_iterator . |
operador++ | Incrementa o checked_array_iterator até o próximo elemento. |
operador-- | Decrementa o checked_array_iterator para o elemento anterior. |
operator+= | Adiciona um deslocamento especificado para um checked_array_iterator . |
operator+ | Adiciona um deslocamento a um iterador e retorna o novo checked_array_iterator que trata o elemento inserido na nova posição de deslocamento. |
operador-= | Decrementa um deslocamento especificado de um checked_array_iterator . |
operator- | Decrementa um deslocamento de um iterador e retorna o novo checked_array_iterator que trata o elemento inserido na nova posição de deslocamento. |
operator[] |
Retorna uma referência a um deslocamento do elemento tratado por um checked_array_iterator por um número especificado de posições. |
Requisitos
Cabeçalho:<iterator>
Namespace: stdext
checked_array_iterator::base
Recupera o iterador subjacente de seu checked_array_iterator
.
_Iterator base() const;
Comentários
Para obter mais informações, consulte Iteradores verificados.
Exemplo
// checked_array_iterators_base.cpp
// compile with: /EHsc
#include <iterator>
#include <vector>
#include <iostream>
int main() {
using namespace std;
int V1[10];
for (int i = 0; i < 10 ; i++)
V1[i] = i;
int* bpos;
stdext::checked_array_iterator<int*> rpos(V1, 10);
rpos++;
bpos = rpos.base ( );
cout << "The iterator underlying rpos is bpos & it points to: "
<< *bpos << "." << endl;
}
/* Output:
The iterator underlying rpos is bpos & it points to: 1.
*/
checked_array_iterator::checked_array_iterator
Constrói um checked_array_iterator
padrão ou um checked_array _iterator
de um iterador subjacente.
checked_array_iterator();
checked_array_iterator(
ITerator ptr,
size_t size,
size_t index = 0);
Parâmetros
ptr
Um ponteiro para a matriz.
size
O tamanho da matriz.
index
(Opcional) Um elemento na matriz para inicializar o iterador. Por padrão, o iterador é inicializado para o primeiro elemento na matriz.
Comentários
Para obter mais informações, consulte Iteradores verificados.
Exemplo
// checked_array_iterators_ctor.cpp
// compile with: /EHsc
#include <iterator>
#include <iostream>
using namespace std;
using namespace stdext;
int main() {
int a[] = {0, 1, 2, 3, 4};
int b[5];
copy(a, a + 5, checked_array_iterator<int*>(b,5));
for (int i = 0 ; i < 5 ; i++)
cout << b[i] << " ";
cout << endl;
checked_array_iterator<int*> checked_output_iterator(b,5);
copy (a, a + 5, checked_output_iterator);
for (int i = 0 ; i < 5 ; i++)
cout << b[i] << " ";
cout << endl;
checked_array_iterator<int*> checked_output_iterator2(b,5,3);
cout << *checked_output_iterator2 << endl;
}
/* Output:
0 1 2 3 4
0 1 2 3 4
3
*/
checked_array_iterator::d tipo_de_diferença
Um tipo que fornece a diferença entre dois checked_array_iterator
s que se referem a elementos no mesmo contêiner.
typedef typename iterator_traits<_Iterator>::difference_type difference_type;
Comentários
O tipo de diferença checked_array_iterator
é o mesmo que o tipo de diferença do iterador.
Consulte um exemplo de código em checked_array_iterator::operator[].
Para obter mais informações, consulte Iteradores verificados.
checked_array_iterator::operador==
Testa a igualdade de dois checked_array_iterator
s.
bool operator==(const checked_array_iterator<_Iterator>& right) const;
Parâmetros
direita
O checked_array_iterator
com relação ao qual verificar quanto à igualdade.
Comentários
Para obter mais informações, consulte Iteradores verificados.
Exemplo
// checked_array_iterators_opeq.cpp
// compile with: /EHsc
#include <iterator>
#include <iostream>
using namespace std;
using namespace stdext;
int main() {
int a[] = {0, 1, 2, 3, 4};
int b[5];
copy(a, a + 5, checked_array_iterator<int*>(b,5));
copy(a, a + 5, checked_array_iterator<int*>(b,5));
checked_array_iterator<int*> checked_output_iterator(b,5);
checked_array_iterator<int*> checked_output_iterator2(b,5);
if (checked_output_iterator2 == checked_output_iterator)
cout << "checked_array_iterators are equal" << endl;
else
cout << "checked_array_iterators are not equal" << endl;
copy (a, a + 5, checked_output_iterator);
checked_output_iterator++;
if (checked_output_iterator2 == checked_output_iterator)
cout << "checked_array_iterators are equal" << endl;
else
cout << "checked_array_iterators are not equal" << endl;
}
/* Output:
checked_array_iterators are equal
checked_array_iterators are not equal
*/
checked_array_iterator::operator!=
Testa a desigualdade de dois checked_array_iterator
s.
bool operator!=(const checked_array_iterator<_Iterator>& right) const;
Parâmetros
direita
O checked_array_iterator
com relação ao qual verificar quanto à desigualdade.
Comentários
Para obter mais informações, consulte Iteradores verificados.
Exemplo
// checked_array_iterators_opneq.cpp
// compile with: /EHsc
#include <iterator>
#include <iostream>
using namespace std;
using namespace stdext;
int main() {
int a[] = {0, 1, 2, 3, 4};
int b[5];
copy(a, a + 5, checked_array_iterator<int*>(b,5));
copy(a, a + 5, checked_array_iterator<int*>(b,5));
checked_array_iterator<int*> checked_output_iterator(b,5);
checked_array_iterator<int*> checked_output_iterator2(b,5);
if (checked_output_iterator2 != checked_output_iterator)
cout << "checked_array_iterators are not equal" << endl;
else
cout << "checked_array_iterators are equal" << endl;
copy (a, a + 5, checked_output_iterator);
checked_output_iterator++;
if (checked_output_iterator2 != checked_output_iterator)
cout << "checked_array_iterators are not equal" << endl;
else
cout << "checked_array_iterators are equal" << endl;
}
/* Output:
checked_array_iterators are equal
checked_array_iterators are not equal
*/
checked_array_iterator::operator<
Testa se o checked_array_iterator
à esquerda do operador é menor que o checked_array_iterator
à direita.
bool operator<(const checked_array_iterator<_Iterator>& right) const;
Parâmetros
direita
O checked_array_iterator
com relação ao qual verificar quanto à desigualdade.
Comentários
Para obter mais informações, consulte Iteradores verificados.
Exemplo
// checked_array_iterators_oplt.cpp
// compile with: /EHsc
#include <iterator>
#include <iostream>
using namespace std;
using namespace stdext;
int main() {
int a[] = {0, 1, 2, 3, 4};
int b[5];
copy(a, a + 5, checked_array_iterator<int*>(b,5));
copy(a, a + 5, checked_array_iterator<int*>(b,5));
checked_array_iterator<int*> checked_output_iterator(b,5);
checked_array_iterator<int*> checked_output_iterator2(b,5);
if (checked_output_iterator2 < checked_output_iterator)
cout << "checked_output_iterator2 is less than checked_output_iterator" << endl;
else
cout << "checked_output_iterator2 is not less than checked_output_iterator" << endl;
copy (a, a + 5, checked_output_iterator);
checked_output_iterator++;
if (checked_output_iterator2 < checked_output_iterator)
cout << "checked_output_iterator2 is less than checked_output_iterator" << endl;
else
cout << "checked_output_iterator2 is not less than checked_output_iterator" << endl;
}
/* Output:
checked_output_iterator2 is not less than checked_output_iterator
checked_output_iterator2 is less than checked_output_iterator
*/
checked_array_iterator::operator>
Testa se o checked_array_iterator
à esquerda do operador é maior que o checked_array_iterator
à direita.
bool operator>(const checked_array_iterator<_Iterator>& right) const;
Parâmetros
direita
O checked_array_iterator
com o qual comparar.
Comentários
Consulte checked_array_iterator::operator<
para obter um exemplo de código.
Para obter mais informações, consulte Iteradores verificados.
checked_array_iterator::operator<=
Testa se o checked_array_iterator
à esquerda do operador é menor ou igual ao checked_array_iterator
à direita.
bool operator<=(const checked_array_iterator<_Iterator>& right) const;
Parâmetros
direita
O checked_array_iterator
com o qual comparar.
Comentários
Consulte checked_array_iterator::operator>=
para obter um exemplo de código.
Para obter mais informações, consulte Iteradores verificados.
checked_array_iterator::operator>=
Testa se o checked_array_iterator
à esquerda do operador é maior ou igual ao checked_array_iterator
à direita.
bool operator>=(const checked_array_iterator<_Iterator>& right) const;
Parâmetros
direita
O checked_array_iterator
com o qual comparar.
Comentários
Para obter mais informações, consulte Iteradores verificados.
Exemplo
// checked_array_iterators_opgteq.cpp
// compile with: /EHsc
#include <iterator>
#include <iostream>
using namespace std;
using namespace stdext;
int main() {
int a[] = {0, 1, 2, 3, 4};
int b[5];
copy(a, a + 5, checked_array_iterator<int*>(b,5));
copy(a, a + 5, checked_array_iterator<int*>(b,5));
checked_array_iterator<int*> checked_output_iterator(b,5);
checked_array_iterator<int*> checked_output_iterator2(b,5);
if (checked_output_iterator2 >= checked_output_iterator)
cout << "checked_output_iterator2 is greater than or equal to checked_output_iterator" << endl;
else
cout << "checked_output_iterator2 is less than checked_output_iterator" << endl;
copy (a, a + 5, checked_output_iterator);
checked_output_iterator++;
if (checked_output_iterator2 >= checked_output_iterator)
cout << "checked_output_iterator2 is greater than or equal to checked_output_iterator" << endl;
else
cout << "checked_output_iterator2 is less than checked_output_iterator" << endl;
}
/* Output:
checked_output_iterator2 is greater than or equal to checked_output_iterator
checked_output_iterator2 is less than checked_output_iterator
*/
checked_array_iterator::operador*
Retorna o elemento tratado por um checked_array_iterator
.
reference operator*() const;
Valor de retorno
O valor do elemento abordado por checked_array_iterator
.
Comentários
Para obter mais informações, consulte Iteradores verificados.
Exemplo
// checked_array_iterator_pointer.cpp
// compile with: /EHsc
#include <iterator>
#include <algorithm>
#include <vector>
#include <utility>
#include <iostream>
using namespace std;
using namespace stdext;
int main() {
int a[] = {0, 1, 2, 3, 4};
int b[5];
pair<int, int> c[1];
copy(a, a + 5, checked_array_iterator<int*>(b,5));
for (int i = 0 ; i < 5 ; i++)
cout << b[i] << endl;
c[0].first = 10;
c[0].second = 20;
checked_array_iterator<int*> checked_output_iterator(b,5);
checked_array_iterator<int*>::pointer p = &(*checked_output_iterator);
checked_array_iterator<pair<int, int>*> chk_c(c, 1);
checked_array_iterator<pair<int, int>*>::pointer p_c = &(*chk_c);
cout << "b[0] = " << *p << endl;
cout << "c[0].first = " << p_c->first << endl;
}
/* Output:
0
1
2
3
4
b[0] = 0
c[0].first = 10
*/
checked_array_iterator::operator->
Retorna um ponteiro para o elemento tratado pelo checked_array_iterator
.
pointer operator->() const;
Valor de retorno
Um ponteiro para o elemento tratado pelo checked_array_iterator
.
Comentários
Consulte checked_array_iterator::pointer para obter um exemplo de código.
Para obter mais informações, consulte Iteradores verificados.
checked_array_iterator::operador++
Incrementa o checked_array_iterator
até o próximo elemento.
checked_array_iterator& operator++();
checked_array_iterator<_Iterator> operator++(int);
Valor de retorno
O primeiro operador retorna o checked_array_iterator
pré-incrementado e o segundo, o operador pós-incrementado, retorna uma cópia do checked_array_iterator
incrementado.
Comentários
Para obter mais informações, consulte Iteradores verificados.
Exemplo
// checked_array_iterators_op_plus_plus.cpp
// compile with: /EHsc
#include <vector>
#include <iostream>
int main() {
using namespace stdext;
using namespace std;
int a[] = {6, 3, 77, 199, 222};
int b[5];
copy(a, a + 5, checked_array_iterator<int*>(b,5));
checked_array_iterator<int*> checked_output_iterator(b,5);
cout << *checked_output_iterator << endl;
++checked_output_iterator;
cout << *checked_output_iterator << endl;
checked_output_iterator++;
cout << *checked_output_iterator << endl;
}
/* Output:
6
3
77
*/
checked_array_iterator::operador--
Decrementa o checked_array_iterator
para o elemento anterior.
checked_array_iterator<_Iterator>& operator--();
checked_array_iterator<_Iterator> operator--(int);
Valor de retorno
O primeiro operador retorna o checked_array_iterator
pré-decrementado e o segundo, o operador pós-decrementado, retorna uma cópia do checked_array_iterator
decrementado.
Comentários
Para obter mais informações, consulte Iteradores verificados.
Exemplo
// checked_array_iterators_op_minus_minus.cpp
// compile with: /EHsc
#include <vector>
#include <iostream>
int main() {
using namespace stdext;
using namespace std;
int a[] = {6, 3, 77, 199, 222};
int b[5];
copy(a, a + 5, checked_array_iterator<int*>(b,5));
checked_array_iterator<int*> checked_output_iterator(b,5);
cout << *checked_output_iterator << endl;
checked_output_iterator++;
cout << *checked_output_iterator << endl;
checked_output_iterator--;
cout << *checked_output_iterator << endl;
}
/* Output:
6
3
6
*/
checked_array_iterator::operador+=
Adiciona um deslocamento especificado para um checked_array_iterator
.
checked_array_iterator<_Iterator>& operator+=(difference_type _Off);
Parâmetros
_Off
O deslocamento pelo qual incrementar o iterador.
Valor de retorno
Uma referência ao elemento tratado pelo checked_array_iterator
.
Comentários
Para obter mais informações, consulte Iteradores verificados.
Exemplo
// checked_array_iterators_op_plus_eq.cpp
// compile with: /EHsc
#include <vector>
#include <iostream>
int main() {
using namespace stdext;
using namespace std;
int a[] = {6, 3, 77, 199, 222};
int b[5];
copy(a, a + 5, checked_array_iterator<int*>(b,5));
checked_array_iterator<int*> checked_output_iterator(b,5);
cout << *checked_output_iterator << endl;
checked_output_iterator += 3;
cout << *checked_output_iterator << endl;
}
/* Output:
6
199
*/
checked_array_iterator::operador+
Adiciona um deslocamento a um iterador e retorna o novo checked_array_iterator
que trata o elemento inserido na nova posição de deslocamento.
checked_array_iterator<_Iterator> operator+(difference_type _Off) const;
Parâmetros
_Off
O deslocamento a ser adicionado a checked_array_iterator
.
Valor de retorno
Um checked_array_iterator
que trata o elemento de deslocamento.
Comentários
Para obter mais informações, consulte Iteradores verificados.
Exemplo
// checked_array_iterators_op_plus.cpp
// compile with: /EHsc
#include <vector>
#include <iostream>
int main() {
using namespace stdext;
using namespace std;
int a[] = {6, 3, 77, 199, 222};
int b[5];
copy(a, a + 5, checked_array_iterator<int*>(b,5));
checked_array_iterator<int*> checked_output_iterator(b,5);
cout << *checked_output_iterator << endl;
checked_output_iterator = checked_output_iterator + 3;
cout << *checked_output_iterator << endl;
}
/* Output:
6
199
*/
checked_array_iterator::operador-=
Decrementa um deslocamento especificado de um checked_array_iterator
.
checked_array_iterator<_Iterator>& operator-=(difference_type _Off);
Parâmetros
_Off
O deslocamento pelo qual incrementar o iterador.
Valor de retorno
Uma referência ao elemento tratado pelo checked_array_iterator
.
Comentários
Para obter mais informações, consulte Iteradores verificados.
Exemplo
// checked_array_iterators_op_minus_eq.cpp
// compile with: /EHsc
#include <vector>
#include <iostream>
int main() {
using namespace stdext;
using namespace std;
int a[] = {6, 3, 77, 199, 222};
int b[5];
copy(a, a + 5, checked_array_iterator<int*>(b,5));
checked_array_iterator<int*> checked_output_iterator(b,5);
checked_output_iterator += 3;
cout << *checked_output_iterator << endl;
checked_output_iterator -= 2;
cout << *checked_output_iterator << endl;
}
/* Output:
199
3
*/
checked_array_iterator::operador-
Decrementa um deslocamento de um iterador e retorna o novo checked_array_iterator
que trata o elemento inserido na nova posição de deslocamento.
checked_array_iterator<_Iterator> operator-(difference_type _Off) const;
difference_type operator-(const checked_array_iterator& right) const;
Parâmetros
_Off
O deslocamento a ser decrementado do checked_array_iterator
.
Valor de retorno
Um checked_array_iterator
que trata o elemento de deslocamento.
Comentários
Para obter mais informações, consulte Iteradores verificados.
checked_array_iterator::operador
Retorna uma referência a um deslocamento do elemento tratado por um checked_array_iterator
por um número especificado de posições.
reference operator[](difference_type _Off) const;
Parâmetros
_Off
O deslocamento do endereço checked_array_iterator
.
Valor de retorno
A referência ao deslocamento de elemento.
Comentários
Para obter mais informações, consulte Iteradores verificados.
Exemplo
// checked_array_iterators_op_diff.cpp
// compile with: /EHsc
#include <vector>
#include <iostream>
int main() {
using namespace std;
int V1[10];
for (int i = 0; i < 10 ; i++)
V1[i] = i;
// Declare a difference type for a parameter
stdext::checked_array_iterator<int*>::difference_type diff = 2;
stdext::checked_array_iterator<int*> VChkIter(V1, 10);
stdext::checked_array_iterator<int*>::reference refrpos = VChkIter [diff];
cout << refrpos + 1 << endl;
}
/* Output:
3
*/
checked_array_iterator::p ointer
Um tipo que fornece um ponteiro para um elemento tratado por um checked_array_iterator
.
typedef typename iterator_traits<_Iterator>::pointer pointer;
Comentários
Consulte um exemplo de código em checked_array_iterator::operator*.
Para obter mais informações, consulte Iteradores verificados.
checked_array_iterator::referência
Um tipo que fornece uma referência a um elemento tratado por um checked_array_iterator
.
typedef typename iterator_traits<_Iterator>::reference reference;
Comentários
Consulte um exemplo de código em checked_array_iterator::operator[].
Para obter mais informações, consulte Iteradores verificados.