Partilhar via


Classe gslice_array

Um modelo de classe auxiliar interna, que dá suporte a objetos de fatia geral fornecendo operações entre matrizes de subconjunto definidas pela fatia geral de uma valarray.

Sintaxe

template <class Type>
class gslice_array : public gsplice {
public:
    typedef Type value_type;
    void operator=(const valarray<Type>& x) const;

    void operator=(const Type& x) const;

    void operator*=(const valarray<Type>& x) const;

    void operator/=(const valarray<Type>& x) const;

    void operator%=(const valarray<Type>& x) const;

    void operator+=(const valarray<Type>& x) const;

    void operator-=(const valarray<Type>& x) const;

    void operator^=(const valarray<Type>& x) const;

    void operator&=(const valarray<Type>& x) const;

    void operator|=(const valarray<Type>& x) const;

    void operator<<=(const valarray<Type>& x) const;

    void operator>>=(const valarray<Type>& x) const;

// The rest is private or implementation defined
}

Comentários

A classe descreve um objeto que armazena uma referência a um objeto va da classe valarray<Type>, bem como um objeto gs da classe gslice, que descreve a sequência de elementos a serem selecionados do objeto valarray<Type>.

Você constrói um objeto gslice_array<Type> apenas escrevendo uma expressão no formato va[gs]. As funções de membro da classe gslice_array, então, se comportam como as assinaturas de função correspondentes definidas para valarray<Type>, exceto pelo fato de somente a sequência de elementos selecionados ser afetada.

O modelo de classe é criado indiretamente por determinadas operações valarray e não pode ser usado diretamente no programa. Em vez disso, um modelo de classe auxiliar interna é usada pelo operador de subscrito slice:

gslice_array<Type> valarray<Type>::operator[]( const gslice& ).

Você constrói um gslice_array<Type> objeto apenas escrevendo uma expressão da forma va[gsl], para um slice gsl de valarray va. As funções de membro da classe gslice_array, então, se comportam como as assinaturas de função correspondentes definidas para valarray<Type>, exceto pelo fato de somente a sequência de elementos selecionados ser afetada. A sequência controlada pelo gslice_array é definida pelos três parâmetros do construtor slice, o índice do primeiro elemento no primeiro slice, o número de elementos em cada slice e a distância entre os elementos em cada slice.

No exemplo a seguir:

const size_t lv[] = {2, 3};
const size_t dv[] = {7, 2};
const valarray<size_t> len(lv, 2), str(dv, 2);

// va[gslice(3, len, str)] selects elements with
//   indices 3, 5, 7, 10, 12, 14

Os índices devem ser válidos para que o procedimento seja válido.

Exemplo

Confira a amostra de gslice::gslice para obter um exemplo de como declarar e usar um slice_array.

Requisitos

Cabeçalho:<valarray>

Namespace: std

Confira também

Segurança de thread na Biblioteca Padrão do C++