Klasa valarray
Szablon klasy valarray<Type>
opisuje obiekt, który kontroluje sekwencję elementów typu Type
, które są przechowywane jako tablica, zaprojektowane pod kątem szybkich operacji matematycznych i zoptymalizowane pod kątem wydajności obliczeniowej.
Uwagi
Klasa jest reprezentacją matematycznej koncepcji uporządkowanego zestawu wartości. Jego elementy są numerowane sekwencyjnie od zera. Klasa jest opisana jako blisko kontenera , ponieważ obsługuje niektóre, ale nie wszystkie funkcje, które kontenery sekwencji pierwszej klasy, takie jak vector
, obsługują. Różni się on od szablonu vector
klasy na dwa ważne sposoby:
Definiuje wiele operacji arytmetycznych między odpowiednimi elementami
valarray<Type>
obiektów tego samego typu i długości, takimi jakvarr_x* = cos(varr_y) + sin(varr_z)
.Definiuje on różne interesujące sposoby podskrypcji
valarray<Type>
obiektu przez przeciążenie elementuoperator[]
.
Obiekt klasy Type
:
Ma publiczny konstruktor domyślny, destruktor, konstruktor kopiowania i operator przypisania z konwencjonalnym zachowaniem.
Definiuje operatory arytmetyczne i funkcje matematyczne zdefiniowane zgodnie z potrzebami dla typów zmiennoprzecinkowych z konwencjonalnym zachowaniem.
W szczególności nie mogą istnieć subtelne różnice między konstrukcją kopii a domyślną konstrukcją, po której następuje przypisanie. Żadne operacje na obiektach klasy Type
nie mogą zgłaszać wyjątków.
Elementy członkowskie
Konstruktory
Nazwa/nazwisko | opis |
---|---|
valarray |
valarray Tworzy określony rozmiar lub elementy określonej wartości lub jako kopię innego valarray lub podzestawu innego valarray . |
Typedefs
Nazwa/nazwisko | opis |
---|---|
value_type |
Typ reprezentujący typ elementu przechowywanego w obiekcie valarray . |
Funkcje
Nazwa/nazwisko | opis |
---|---|
apply |
Stosuje określoną funkcję do każdego elementu elementu valarray . |
cshift |
Cyklicznie przesuwa wszystkie elementy w obiekcie valarray o określoną liczbę pozycji. |
free |
Zwalnia pamięć używaną przez element valarray . |
max |
Znajduje największy element w obiekcie valarray . |
min |
Znajduje najmniejszy element w obiekcie valarray . |
resize |
Zmienia liczbę elementów w valarray liczbie na określoną liczbę, dodając lub usuwając elementy zgodnie z potrzebami. |
shift |
Przesuwa wszystkie elementy w obiekcie valarray o określoną liczbę pozycji. |
size |
Znajduje liczbę elementów w obiekcie valarray . |
sum |
Określa sumę wszystkich elementów o valarray długości niezerowej. |
swap |
Operatory
Nazwa/nazwisko | opis |
---|---|
operator! |
Operator jednoargumentowy, który uzyskuje logiczne wartości NOT (! ) każdego elementu w obiekcie valarray . |
operator%= |
Uzyskuje pozostałą część dzielenia elementów tablicy według określonej valarray lub przez wartość typu elementu. |
operator&= |
Uzyskuje bitowe AND (& ) elementów w tablicy z odpowiednimi elementami w określonym valarray lub z wartością typu elementu. |
operator>>= |
Przesuwa bity w prawo dla każdego elementu valarray operandu określoną liczbę pozycji lub przez liczbę elementów mądry określoną przez sekundę valarray . |
operator<<= |
Przesuwa bity w lewo dla każdego elementu valarray operandu określoną liczbę pozycji lub przez liczbę elementów mądry określoną przez sekundę valarray . |
operator*= |
Mnoży elementy określonego valarray elementu lub wartość typu elementu, element-wise, do operandu valarray . |
operator+ |
Operator jednoargumentowy, który stosuje znak plus do każdego elementu w obiekcie valarray . W normalnych typach arytmetycznych ten operator nie ma wpływu. |
operator+= |
Dodaje elementy określonego valarray elementu lub wartość typu elementu, element-wise, do operandu valarray . |
operator- |
Operator jednoargumentowy, który stosuje negację arytmetyczną do każdego elementu w obiekcie valarray . |
operator-= |
Odejmuje elementy określonego valarray elementu lub wartość typu elementu, element-wise, z operandu valarray . |
operator/= |
Dzieli element operand valarray mądry przez elementy określonego valarray lub wartości typu elementu. |
operator= |
Przypisuje elementy do obiektu valarray , którego wartości są określane bezpośrednio lub w ramach innych valarray lub przez slice_array element , gslice_array , mask_array lub indirect_array . |
operator[] |
Zwraca odwołanie do elementu lub jego wartości w określonym indeksie lub określonym podzestawie. |
operator^= |
Uzyskuje bitową wyłączność lub (^ ) valarray elementu z określoną valarray lub wartością typu elementu. |
operator|= |
Uzyskuje bitowe OR (| ) elementów w tablicy z odpowiednimi elementami w określonym valarray lub z wartością typu elementu. |
operator~ |
Operator jednoargumentowy, który uzyskuje wartości uzupełniania bitowego (~ ) każdego elementu w obiekcie valarray . |
apply
Stosuje określoną funkcję do każdego elementu elementu valarray
.
valarray<Type> apply(Type function_object(Type)) const;
valarray<Type> apply(Type function_object(const Type&)) const;
Parametry
function_object(Type)
Obiekt funkcji, który ma zostać zastosowany do każdego elementu operandu valarray
.
function_object(const Type&)
Obiekt funkcji dla const
elementów, które mają być stosowane do każdego elementu operandu valarray
.
Wartość zwracana
Element valarray
, którego elementy zastosowały function_object
element mądry do elementów operandu valarray
.
Uwagi
Funkcja składowa zwraca obiekt klasy valarray<Type>
, o długości size
, każdy z których elementy elem
są wynikiem function_object((*this)[elem])
.
Przykład
// valarray_apply.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
using namespace std;
int __cdecl MyApplyFunc( int n )
{
return n*2;
}
int main( int argc, char* argv[] )
{
valarray<int> vaR(10), vaApplied(10);
int i;
for ( i = 0; i < 10; i += 3 )
vaR[i] = i;
for ( i = 1; i < 10; i += 3 )
vaR[i] = 0;
for ( i = 2; i < 10; i += 3 )
vaR[i] = -i;
cout << "The initial Right valarray is: (";
for ( i=0; i < 10; ++i )
cout << " " << vaR[i];
cout << " )" << endl;
vaApplied = vaR.apply( MyApplyFunc );
cout << "The element-by-element result of "
<< "applying MyApplyFunc to vaR is the\nvalarray: ( ";
for ( i = 0; i < 10; ++i )
cout << " " << vaApplied[i];
cout << " )" << endl;
}
The initial Right valarray is: ( 0 0 -2 3 0 -5 6 0 -8 9 )
The element-by-element result of applying MyApplyFunc to vaR is the
valarray: ( 0 0 -4 6 0 -10 12 0 -16 18 )
cshift
Cyklicznie przesuwa wszystkie elementy w obiekcie valarray
o określoną liczbę pozycji.
valarray<Type> cshift(int count) const;
Parametry
count
Liczba miejsc, w których elementy mają być przesunięte do przodu.
Wartość zwracana
Nowy valarray
, w którym wszystkie elementy zostały przeniesione count
pozycje cyklicznie w kierunku przodu , lub lewej valarray
w porównaniu do ich pozycji w operand valarray
.
Uwagi
Dodatnia count
wartość przesuwa cyklicznie lewe count
miejsca elementów.
Ujemna wartość count
zmienia cyklicznie prawe count
miejsca elementów.
Przykład
// valarray_cshift.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main()
{
using namespace std;
int i;
valarray<int> va1(10), va2(10);
for (i = 0; i < 10; i+=1)
va1[i] = i;
for (i = 0; i < 10; i+=1)
va2[i] = 10 - i;
cout << "The operand valarray va1 is: (";
for (i = 0; i < 10; i++)
cout << " " << va1[i];
cout << ")" << endl;
// A positive parameter shifts elements right
va1 = va1.cshift(4);
cout << "The cyclically shifted valarray va1 is:\nva1.cshift (4) = (";
for (i = 0; i < 10; i++)
cout << " " << va1[i];
cout << ")" << endl;
cout << "The operand valarray va2 is: (";
for (i = 0; i < 10; i++)
cout << " " << va2[i];
cout << ")" << endl;
// A negative parameter shifts elements left
va2 = va2.cshift(-4);
cout << "The cyclically shifted valarray va2 is:\nva2.shift (-4) = (";
for (i = 0; i < 10; i++)
cout << " " << va2[i];
cout << ")" << endl;
}
The operand valarray va1 is: ( 0 1 2 3 4 5 6 7 8 9)
The cyclically shifted valarray va1 is:
va1.cshift (4) = ( 4 5 6 7 8 9 0 1 2 3)
The operand valarray va2 is: ( 10 9 8 7 6 5 4 3 2 1)
The cyclically shifted valarray va2 is:
va2.shift (-4) = ( 4 3 2 1 10 9 8 7 6 5)
free
Zwalnia pamięć używaną przez element valarray
.
void free();
Uwagi
Ta niestandardowa funkcja jest równoważna przypisaniu pustego valarray
elementu . Na przykład:
valarray<T> v;
v = valarray<T>();
// equivalent to v.free()
max
Znajduje największy element w obiekcie valarray
.
Type max() const;
Wartość zwracana
Maksymalna wartość elementów w operandzie valarray
.
Uwagi
Funkcja składowa porównuje wartości, stosując operator lub operator>< między parami elementów klasy Type
, dla których operatory muszą być podane dla elementu .Type
Przykład
// valarray_max.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i, MaxValue;
valarray<int> vaR ( 10 );
for ( i = 0 ; i < 10 ; i += 3 )
vaR [ i ] = i;
for ( i = 1 ; i < 10 ; i += 3 )
vaR [ i ] = 2*i - 1;
for ( i = 2 ; i < 10 ; i += 3 )
vaR [ i ] = 10 - i;
cout << "The operand valarray is: ( ";
for (i = 0 ; i < 10 ; i++ )
cout << vaR [ i ] << " ";
cout << ")." << endl;
MaxValue = vaR.max ( );
cout << "The largest element in the valarray is: "
<< MaxValue << "." << endl;
}
The operand valarray is: ( 0 1 8 3 7 5 6 13 2 9 ).
The largest element in the valarray is: 13.
min
Znajduje najmniejszy element w obiekcie valarray
.
Type min() const;
Wartość zwracana
Minimalna wartość elementów w operand valarray
.
Uwagi
Funkcja składowa porównuje wartości, stosując operator lub operator>< między parami elementów klasy Type
, dla których operatory muszą być podane dla elementu .Type
Przykład
// valarray_min.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i, MinValue;
valarray<int> vaR ( 10 );
for ( i = 0 ; i < 10 ; i += 3 )
vaR [ i ] = -i;
for ( i = 1 ; i < 10 ; i += 3 )
vaR [ i ] = 2*i;
for ( i = 2 ; i < 10 ; i += 3 )
vaR [ i ] = 5 - i;
cout << "The operand valarray is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaR [ i ] << " ";
cout << ")." << endl;
MinValue = vaR.min ( );
cout << "The smallest element in the valarray is: "
<< MinValue << "." << endl;
}
/* Output:
The operand valarray is: ( 0 2 3 -3 8 0 -6 14 -3 -9 ).
The smallest element in the valarray is: -9.
*/
operator!
Operator jednoargumentowy, który uzyskuje logiczne wartości NOT (!
) każdego elementu w obiekcie valarray
.
valarray<bool> operator!() const;
Wartość zwracana
Wartości valarray
logiczne, które są logicznym negacją wartości elementów operandu valarray
.
Uwagi
Operacja logiczna NOT, oznaczona przez !
, logicznie neguje elementy, ponieważ konwertuje wszystkie wartości zerowe na true
i wszystkie wartości inne niż zero na false
. Zwracane valarray
wartości logiczne mają taki sam rozmiar jak operand valarray
.
Przykład
// valarray_op_lognot.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> vaL ( 10 );
valarray<bool> vaNOT ( 10 );
for ( i = 0 ; i < 10 ; i += 2 )
vaL [ i ] = 0;
for ( i = 1 ; i < 10 ; i += 2 )
vaL [ i ] = i-1;
cout << "The initial valarray is: ( ";
for (i = 0 ; i < 10 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
vaNOT = !vaL;
cout << "The element-by-element result of "
<< "the logical NOT operator! is the"
<< endl << "valarray: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaNOT [ i ] << " ";
cout << ")." << endl;
}
The initial valarray is: ( 0 0 0 2 0 4 0 6 0 8 ).
The element-by-element result of the logical NOT operator! is the
valarray: ( 1 1 1 0 1 0 1 0 1 0 ).
operator%=
Uzyskuje pozostałą część dzielenia elementów tablicy według określonej valarray
lub przez wartość typu elementu.
valarray<Type>& operator%=(const valarray<Type>& right);
valarray<Type>& operator%=(const Type& right);
Parametry
right
Wartość valarray
lub typu elementu identyczna z argumentem operandu valarray
, który ma być podzielony, mądry element, operand valarray
.
Wartość zwracana
A valarray
, których elementy są resztą z podziałów elementów operandu valarray
przez right
.
Przykład
// valarray_class_op_rem.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> vaL ( 6 ), vaR ( 6 );
for ( i = 0 ; i < 6 ; i += 2 )
vaL [ i ] = 53;
for ( i = 1 ; i < 6 ; i += 2 )
vaL [ i ] = -67;
for ( i = 0 ; i < 6 ; i++ )
vaR [ i ] = 3*i+1;
cout << "The initial valarray is: ( ";
for ( i = 0 ; i < 6 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
cout << "The initial right valarray is: ( ";
for ( i = 0 ; i < 6 ; i++ )
cout << vaR [ i ] << " ";
cout << ")." << endl;
vaL %= vaR;
cout << "The remainders from the element-by-element "
<< "division is the"
<< endl << "valarray: ( ";
for ( i = 0 ; i < 6 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
}
The initial valarray is: ( 53 -67 53 -67 53 -67 ).
The initial right valarray is: ( 1 4 7 10 13 16 ).
The remainders from the element-by-element division is the
valarray: ( 0 -3 4 -7 1 -3 ).
operator&=
Uzyskuje bitowe AND (&
) elementów w tablicy z odpowiednimi elementami w określonym valarray
lub z wartością typu elementu.
valarray<Type>& operator&=(const valarray<Type>& right);
valarray<Type>& operator&=(const Type& right);
Parametry
right
Wartość valarray
lub typu elementu identycznego z argumentem operandu valarray
, który ma być połączony, element-mądry, przez bitowe AND (&
) z operandem valarray
.
Wartość zwracana
Element valarray
, którego elementy są bitowe AND (&
) operandu valarray
przez right
Uwagi
Operację bitową można używać tylko do manipulowania bitami w całkowitych typach danych, takich jak char
i int
. Nie działa w przypadku float
bardziej złożonych typów danych , , void
double
long double
, , bool
lub innych.
Bitowe AND (&
) ma zastosowanie do typu danych na poziomie poszczególnych bitów. Podane bity b1
i b2
, b1 & b2
jest 1, jeśli oba bity mają wartość 1; 0, jeśli co najmniej jeden bit to 0.
Przykład
// valarray_class_op_bitand.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> vaL ( 10 ), vaR ( 10 );
for ( i = 0 ; i < 10 ; i += 2 )
vaL [ i ] = 0;
for ( i = 1 ; i < 10 ; i += 2 )
vaL [ i ] = i-1;
for ( i = 0 ; i < 10 ; i++ )
vaR [ i ] = i;
cout << "The initial valarray is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
cout << "The initial Right valarray is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaR [ i ] << " ";
cout << ")." << endl;
vaL &= vaR;
cout << "The element-by-element result of "
<< "the bitwise AND operator&= is the"
<< endl << "valarray: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
}
The initial valarray is: ( 0 0 0 2 0 4 0 6 0 8 ).
The initial Right valarray is: ( 0 1 2 3 4 5 6 7 8 9 ).
The element-by-element result of the bitwise AND operator&= is the
valarray: ( 0 0 0 2 0 4 0 6 0 8 ).
operator>>=
Przesuwa bity w prawo dla każdego elementu valarray
operandu określoną liczbę pozycji lub przez liczbę elementów mądry określoną przez sekundę valarray
.
valarray<Type>& operator>>=(const valarray<Type>& right);
valarray<Type>& operator>>=(const Type& right);
Parametry
right
Wartość wskazująca ilość przesunięcia w prawo lub valarray
, których elementy wskazują mądry poziom przesunięcia w prawo.
Wartość zwracana
Elementvalarray
, którego elementy zostały przesunięte w prawo, kwota określona w .right
Uwagi
Podpisane numery mają swoje znaki zachowane.
Przykład
// valarray_class_op_rs.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> vaL ( 8 ), vaR ( 8 );
for ( i = 0 ; i < 8 ; i += 2 )
vaL [ i ] = 64;
for ( i = 1 ; i < 8 ; i += 2 )
vaL [ i ] = -64;
for ( i = 0 ; i < 8 ; i++ )
vaR [ i ] = i;
cout << "The initial operand valarray is: ( ";
for ( i = 0 ; i < 8 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
cout << "The right valarray is: ( ";
for ( i = 0 ; i < 8 ; i++ )
cout << vaR [ i ] << " ";
cout << ")." << endl;
vaL >>= vaR;
cout << "The element-by-element result of "
<< "the right shift is the"
<< endl << "valarray: ( ";
for ( i = 0 ; i < 8 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
}
The initial operand valarray is: ( 64 -64 64 -64 64 -64 64 -64 ).
The right valarray is: ( 0 1 2 3 4 5 6 7 ).
The element-by-element result of the right shift is the
valarray: ( 64 -32 16 -8 4 -2 1 -1 ).
operator<<=
Przesuwa bity w lewo dla każdego elementu valarray
operandu określoną liczbę pozycji lub przez liczbę elementów mądry określoną przez sekundę valarray
.
valarray<Type>& operator<<=(const valarray<Type>& right);
valarray<Type>& operator<<=(const Type& right);
Parametry
right
Wartość wskazująca ilość przesunięcia w lewo lub valarray
których elementy wskazują mądry element przesunięcia w lewo.
Wartość zwracana
Element valarray
, którego elementy zostały przesunięte, pozostawiono kwotę określoną w elem right
.
Uwagi
Podpisane numery mają swoje znaki zachowane.
Przykład
// valarray_class_op_ls.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> vaL ( 8 ), vaR ( 8 );
for ( i = 0 ; i < 8 ; i += 2 )
vaL [ i ] = 1;
for ( i = 1 ; i < 8 ; i += 2 )
vaL [ i ] = -1;
for ( i = 0 ; i < 8 ; i++ )
vaR [ i ] = i;
cout << "The initial operand valarray is: ( ";
for ( i = 0 ; i < 8 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
cout << "The right valarray is: ( ";
for ( i = 0 ; i < 8 ; i++ )
cout << vaR [ i ] << " ";
cout << ")." << endl;
vaL <<= vaR;
cout << "The element-by-element result of "
<< "the left shift"
<< endl << "on the operand array is the valarray:"
<< endl << "( ";
for ( i = 0 ; i < 8 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
}
The initial operand valarray is: ( 1 -1 1 -1 1 -1 1 -1 ).
The right valarray is: ( 0 1 2 3 4 5 6 7 ).
The element-by-element result of the left shift
on the operand array is the valarray:
( 1 -2 4 -8 16 -32 64 -128 ).
operator*=
Mnoży elementy określonego valarray
elementu lub wartość typu elementu, element-wise, do operandu valarray
.
valarray<Type>& operator*=(const valarray<Type>& right);
valarray<Type>& operator*=(const Type& right);
Parametry
right
Wartość valarray
lub typu elementu identycznego z argumentem operandu valarray
, który ma być mnożący, mądry element, operand valarray
.
Wartość zwracana
Element valarray
, którego elementy są elementami mądry produkt operandu valarray
i right
.
Przykład
// valarray_op_emult.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> vaL ( 8 ), vaR ( 8 );
for ( i = 0 ; i < 8 ; i += 2 )
vaL [ i ] = 2;
for ( i = 1 ; i < 8 ; i += 2 )
vaL [ i ] = -1;
for ( i = 0 ; i < 8 ; i++ )
vaR [ i ] = i;
cout << "The initial valarray is: ( ";
for ( i = 0 ; i < 8 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
cout << "The initial Right valarray is: ( ";
for ( i = 0 ; i < 8 ; i++ )
cout << vaR [ i ] << " ";
cout << ")." << endl;
vaL *= vaR;
cout << "The element-by-element result of "
<< "the multiplication is the"
<< endl << "valarray: ( ";
for ( i = 0 ; i < 8 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
}
/* Output:
The initial valarray is: ( 2 -1 2 -1 2 -1 2 -1 ).
The initial Right valarray is: ( 0 1 2 3 4 5 6 7 ).
The element-by-element result of the multiplication is the
valarray: ( 0 -1 4 -3 8 -5 12 -7 ).
*/
operator+
Operator jednoargumentowy, który stosuje znak plus do każdego elementu w obiekcie valarray
. W przypadku normalnych wartości arytmetycznych ta operacja nie ma efektu.
valarray<Type> operator+() const;
Wartość zwracana
Element valarray
, którego elementy są jednoargumentowym plus wynikiem tablicy operandu.
Przykład
// valarray_op_eplus.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> vaL ( 10 );
valarray<int> vaPLUS ( 10 );
for ( i = 0 ; i < 10 ; i += 2 )
vaL [ i ] = -i;
for ( i = 1 ; i < 10 ; i += 2 )
vaL [ i ] = i-1;
cout << "The initial valarray is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
vaPLUS = +vaL;
cout << "The element-by-element result of "
<< "the operator+ is the"
<< endl << "valarray: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaPLUS [ i ] << " ";
cout << ")." << endl;
}
The initial valarray is: ( 0 0 -2 2 -4 4 -6 6 -8 8 ).
The element-by-element result of the operator+ is the
valarray: ( 0 0 -2 2 -4 4 -6 6 -8 8 ).
operator+=
Dodaje elementy określonego valarray
elementu lub wartość typu elementu, element-wise, do operandu valarray
.
valarray<Type>& operator+=(const valarray<Type>& right);
valarray<Type>& operator+=(const Type& right);
Parametry
right
Wartość valarray
lub typu elementu identycznego z argumentem operandu valarray
, który ma zostać dodany, element mądry, do operandu valarray
.
Wartość zwracana
Element valarray
, którego elementy są mądrą sumą operandu valarray
i right
.
Przykład
// valarray_op_eadd.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> vaL ( 8 ), vaR ( 8 );
for ( i = 0 ; i < 8 ; i += 2 )
vaL [ i ] = 2;
for ( i = 1 ; i < 8 ; i += 2 )
vaL [ i ] = -1;
for ( i = 0 ; i < 8 ; i++ )
vaR [ i ] = i;
cout << "The initial valarray is: ( ";
for (i = 0 ; i < 8 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
cout << "The initial right valarray is: ( ";
for (i = 0 ; i < 8 ; i++ )
cout << vaR [ i ] << " ";
cout << ")." << endl;
vaL += vaR;
cout << "The element-by-element result of "
<< "the sum is the"
<< endl << "valarray: ( ";
for (i = 0 ; i < 8 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
}
The initial valarray is: ( 2 -1 2 -1 2 -1 2 -1 ).
The initial right valarray is: ( 0 1 2 3 4 5 6 7 ).
The element-by-element result of the sum is the
valarray: ( 2 0 4 2 6 4 8 6 ).
operator-
Operator jednoargumentowy, który stosuje negację arytmetyczną do każdego elementu w obiekcie valarray
.
valarray<Type> operator-() const;
Wartość zwracana
A valarray
którego elementy są arytmetycznie negowane z elementów operandu valarray
.
Przykład
// valarray_op_eminus.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> vaL ( 10 );
valarray<int> vaMINUS ( 10 );
for ( i = 0 ; i < 10 ; i += 2 )
vaL [ i ] = -i;
for ( i = 1 ; i < 10 ; i += 2 )
vaL [ i ] = i-1;
cout << "The initial valarray is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
vaMINUS = -vaL;
cout << "The element-by-element result of "
<< "the operator- is the"
<< endl << "valarray: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaMINUS [ i ] << " ";
cout << ")." << endl;
}
The initial valarray is: ( 0 0 -2 2 -4 4 -6 6 -8 8 ).
The element-by-element result of the operator- is the
valarray: ( 0 0 2 -2 4 -4 6 -6 8 -8 ).
operator-=
Odejmuje elementy określonego valarray
elementu lub wartość typu elementu, element-wise, z operandu valarray
.
valarray<Type>& operator-=(const valarray<Type>& right);
valarray<Type>& operator-=(const Type& right);
Parametry
right
Wartość valarray
lub typu elementu identycznego z argumentem operandu valarray
, który ma być odejmowany, element-mądry, z operandu valarray
.
Wartość zwracana
Element, valarray
którego elementy są mądrą różnicą operandu valarray
i right
.
Przykład
// valarray_op_esub.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> vaL ( 8 ), vaR ( 8 );
for ( i = 0 ; i < 8 ; i += 2 )
vaL [ i ] = 10;
for ( i = 1 ; i < 8 ; i += 2 )
vaL [ i ] = 0;
for ( i = 0 ; i < 8 ; i++ )
vaR [ i ] = i;
cout << "The initial valarray is: ( ";
for (i = 0 ; i < 8 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
cout << "The initial right valarray is: ( ";
for ( i = 0 ; i < 8 ; i++ )
cout << vaR [ i ] << " ";
cout << ")." << endl;
vaL -= vaR;
cout << "The element-by-element result of "
<< "the difference is the"
<< endl << "valarray: ( ";
for ( i = 0 ; i < 8 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
}
The initial valarray is: ( 10 0 10 0 10 0 10 0 ).
The initial right valarray is: ( 0 1 2 3 4 5 6 7 ).
The element-by-element result of the difference is the
valarray: ( 10 -1 8 -3 6 -5 4 -7 ).
operator/=
Dzieli element operand valarray
mądry przez elementy określonego valarray
lub wartości typu elementu.
valarray<Type>& operator/=(const valarray<Type>& right);
valarray<Type>& operator/=(const Type& right);
Parametry
right
Wartość valarray
lub typu elementu identycznego z argumentem operandu valarray
, który ma być podzielony, element-mądry, na operand valarray
.
Wartość zwracana
A valarray
, których elementy są elementami mądry iloraz operandu valarray
podzielonego przez right
.
Przykład
// valarray_op_ediv.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<double> vaL ( 6 ), vaR ( 6 );
for ( i = 0 ; i < 6 ; i += 2 )
vaL [ i ] = 100;
for ( i = 1 ; i < 6 ; i += 2 )
vaL [ i ] = -100;
for ( i = 0 ; i < 6 ; i++ )
vaR [ i ] = 2*i;
cout << "The initial valarray is: ( ";
for (i = 0 ; i < 6 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
cout << "The initial Right valarray is: ( ";
for (i = 0 ; i < 6 ; i++ )
cout << vaR [ i ] << " ";
cout << ")." << endl;
vaL /= vaR;
cout << "The element-by-element result of "
<< "the quotient is the"
<< endl << "valarray: ( ";
for (i = 0 ; i < 6 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
}
The initial valarray is: ( 100 -100 100 -100 100 -100 ).
The initial Right valarray is: ( 0 2 4 6 8 10 ).
The element-by-element result of the quotient is the
valarray: ( inf -50 25 -16.6667 12.5 -10 ).
operator=
Przypisuje elementy do obiektu valarray
, którego wartości są określane bezpośrednio lub w ramach innych valarray
lub przez slice_array
element , gslice_array
, mask_array
lub indirect_array
.
valarray<Type>& operator=(const valarray<Type>& right);
valarray<Type>& operator=(valarray<Type>&& right);
valarray<Type>& operator=(const Type& val);
valarray<Type>& operator=(const slice_array<Type>& slicearray);
valarray<Type>& operator=(const gslice_array<Type>& gslicearray);
valarray<Type>& operator=(const mask_array<Type>& maskarray);
valarray<Type>& operator=(const indirect_array<Type>& indarray);
Parametry
right
Element valarray
do skopiowania do operandu valarray
.
val
Wartość, która ma zostać przypisana do elementów operandu valarray
.
slicearray
Element slice_array
do skopiowania do operandu valarray
.
gslicearray
Element gslice_array
do skopiowania do operandu valarray
.
maskarray
Element mask_array
do skopiowania do operandu valarray
.
indarray
Element indirect_array
do skopiowania do operandu valarray
.
Wartość zwracana
Pierwszy operator elementu członkowskiego zastępuje kontrolowaną sekwencję kopią sekwencji kontrolowanej przez right
element .
Drugi operator elementu członkowskiego jest taki sam jak pierwszy, ale z deklaratorem odwołania Rvalue: &&
.
Trzeci operator elementu członkowskiego zastępuje każdy element kontrolowanej sekwencji kopią wartości.
Pozostałe operatory składowe zastępują te elementy kontrolowanej sekwencji wybranej przez ich argumenty, które są generowane tylko przez operator[]
element .
Jeśli wartość elementu członkowskiego w kontrolowanej sekwencji zastępczej zależy od elementu członkowskiego w początkowej kontrolowanej sekwencji, wynik jest niezdefiniowany.
Uwagi
Jeśli długość kontrolowanej sekwencji zmienia się, zwykle wynik jest niezdefiniowany. Jednak w tej implementacji efekt polega jedynie na unieważnieniu wszelkich wskaźników lub odwołań do elementów w kontrolowanej sekwencji.
Przykład
// valarray_op_assign.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> va ( 10 ), vaR ( 10 );
for ( i = 0 ; i < 10 ; i += 1 )
va [ i ] = i;
for ( i = 0 ; i < 10 ; i+=1 )
vaR [ i ] = 10 - i;
cout << "The operand valarray va is:";
for ( i = 0 ; i < 10 ; i++ )
cout << " " << va [ i ];
cout << endl;
cout << "The operand valarray vaR is:";
for ( i = 0 ; i < 10 ; i++ )
cout << " " << vaR [ i ];
cout << endl;
// Assigning vaR to va with the first member function
va = vaR;
cout << "The reassigned valarray va is:";
for ( i = 0 ; i < 10 ; i++ )
cout << " " << va [ i ];
cout << endl;
// Assigning elements of value 10 to va
// with the second member function
va = 10;
cout << "The reassigned valarray va is:";
for ( i = 0 ; i < 10 ; i++ )
cout << " " << va [ i ];
cout << endl;
}
The operand valarray va is: 0 1 2 3 4 5 6 7 8 9
The operand valarray vaR is: 10 9 8 7 6 5 4 3 2 1
The reassigned valarray va is: 10 9 8 7 6 5 4 3 2 1
The reassigned valarray va is: 10 10 10 10 10 10 10 10 10 10
operator[]
Zwraca odwołanie do elementu lub jego wartości w określonym indeksie lub określonym podzestawie.
Type& operator[](size_t index);
slice_array<Type> operator[](slice slicearray);
gslice_array<Type> operator[](const gslice& gslicearray);
mask_array<Type> operator[](const valarray<bool>& boolarray);
indirect_array<Type> operator[](const valarray<size_t>& indarray);
Type operator[](size_t index) const;
valarray<Type> operator[](slice slicearray) const;
valarray<Type> operator[](const gslice& gslicearray) const;
valarray<Type> operator[](const valarray<bool>& boolarray) const;
valarray<Type> operator[](const valarray<size_t>& indarray) const;
Parametry
index
Indeks elementu, który ma zostać przypisany do wartości.
slicearray
valarray
Elementslice_array
, który określa podzbiór do wybrania lub zwrócony do nowego valarray
elementu .
gslicearray
valarray
Elementgslice_array
, który określa podzbiór do wybrania lub zwrócony do nowego valarray
elementu .
boolarray
valarray
Elementbool_array
, który określa podzbiór do wybrania lub zwrócony do nowego valarray
elementu .
indarray
valarray
Element indirect_array
określający podzbiór do wybrania lub zwrócony do nowego valarray
elementu .
Wartość zwracana
Odwołanie do elementu lub jego wartości w określonym indeksie lub określonym podzestawie.
Uwagi
Operator elementu członkowskiego jest przeciążony, aby zapewnić kilka sposobów wybierania sekwencji elementów spośród tych kontrolowanych przez *this
. Pierwsza grupa pięciu operatorów składowych współpracuje z różnymi przeciążeniami (i innymi operatorami operator=
przypisywania), aby umożliwić selektywne zastępowanie (fragmentowanie) kontrolowanej sekwencji. Wybrane elementy muszą istnieć.
W przypadku kompilacji przy użyciu _ITERATOR_DEBUG_LEVEL
zdefiniowanej jako 1 lub 2 błąd środowiska uruchomieniowego występuje, jeśli próbujesz uzyskać dostęp do elementu poza granicami valarray
. Aby uzyskać więcej informacji, zobacz Sprawdzono iteratory.
Przykład
Zapoznaj się z przykładami i slice::slice
gslice::gslice
przykładami sposobu deklarowania i używania elementu operator[]
.
operator^=
Uzyskuje bitową wyłączność lub (^
) valarray
elementu z określoną valarray
lub wartością typu elementu.
valarray<Type>& operator^=(const valarray<Type>& right);
valarray<Type>& operator^=(const Type& right);
Parametry
right
Wartość valarray
lub typu elementu identycznego z argumentem operandu valarray
, który ma być połączony przez operator bitowy wyłączny lub (XOR) (^
) z operandem valarray
.
Wartość zwracana
Element valarray
, którego elementy są bitowo wykluczające lub (XOR) operandu valarray
i right
.
Uwagi
Bitowe wyłączne lub, określane jako XOR i oznaczone przez operator ^
, ma następujące semantyki: Podane bity b1
i b2
, b1 ^ b2
jest 1, jeśli dokładnie jeden z elementów wynosi 1, i 0, jeśli oba elementy są 0 lub 1.
Przykład
// valarray_op_exor.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> vaL ( 10 ), vaR ( 10 );
for ( i = 0 ; i < 10 ; i += 2 )
vaL [ i ] = 1;
for ( i = 1 ; i < 10 ; i += 2 )
vaL [ i ] = 0;
for ( i = 0 ; i < 10 ; i += 3 )
vaR [ i ] = i;
for ( i = 1 ; i < 10 ; i += 3 )
vaR [ i ] = i-1;
for ( i = 2 ; i < 10 ; i += 3 )
vaR [ i ] = i-1;
cout << "The initial operand valarray is: ( ";
for (i = 0 ; i < 10 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
cout << "The right valarray is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaR [ i ] << " ";
cout << ")." << endl;
vaL ^= vaR;
cout << "The element-by-element result of "
<< "the bitwise XOR operator^= is the"
<< endl << "valarray: ( ";
for (i = 0 ; i < 10 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
}
The initial operand valarray is: ( 1 0 1 0 1 0 1 0 1 0 ).
The right valarray is: ( 0 0 1 3 3 4 6 6 7 9 ).
The element-by-element result of the bitwise XOR operator^= is the
valarray: ( 1 0 0 3 2 4 7 6 6 9 ).
operator|=
Uzyskuje bitowe OR (|
) elementów w tablicy z odpowiednimi elementami w określonym valarray
lub z wartością typu elementu.
valarray<Type>& operator|=(const valarray<Type>& right);
valarray<Type>& operator|=(const Type& right);
Parametry
right
Wartość valarray
lub typu elementu identycznego z argumentem operandu valarray
, który ma być połączony, element-mądry, przez bitowy OR (|
) z operandem valarray
.
Wartość zwracana
Element valarray
, którego elementy są elementami bitowe OR (|
) operandu valarray
przez right
.
Uwagi
Operację bitową można używać tylko do manipulowania bitami w całkowitych typach danych, takich jak char
i int
. Nie działa w przypadku float
bardziej złożonych typów danych , , void
double
long double
, , bool
lub innych.
Bitowe OR (|
) dotyczy typu danych na poziomie poszczególnych bitów. Podane bity b1
i b2
, b1 | b2
jest 1, jeśli co najmniej jeden z bitów wynosi 1; 0, jeśli oba bity mają wartość 0.
Przykład
// valarray_class_op_bitor.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> vaL ( 10 ), vaR ( 10 );
for ( i = 0 ; i < 10 ; i += 2 )
vaL [ i ] = 1;
for ( i = 1 ; i < 10 ; i += 2 )
vaL [ i ] = 0;
for ( i = 0 ; i < 10 ; i += 3 )
vaR [ i ] = i;
for ( i = 1 ; i < 10 ; i += 3 )
vaR [ i ] = i-1;
for ( i = 2 ; i < 10 ; i += 3 )
vaR [ i ] = i-1;
cout << "The initial operand valarray is:"
<< endl << "( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
cout << "The right valarray is:"
<< endl << "( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaR [ i ] << " ";
cout << ")." << endl;
vaL |= vaR;
cout << "The element-by-element result of "
<< "the bitwise OR"
<< endl << "operator|= is the valarray:"
<< endl << "( ";
for (i = 0 ; i < 10 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
}
The initial operand valarray is:
( 1 0 1 0 1 0 1 0 1 0 ).
The right valarray is:
( 0 0 1 3 3 4 6 6 7 9 ).
The element-by-element result of the bitwise OR
operator|= is the valarray:
( 1 0 1 3 3 4 7 6 7 9 ).
operator~
Operator jednoargumentowy, który uzyskuje bitowe uzupełnienie wartości każdego elementu w obiekcie valarray
.
valarray<Type> operator~() const;
Wartość zwracana
Wartości valarray
, które są jednoargumentowym uzupełnieniem bitowych wartości elementów operandu valarray
.
Uwagi
Operacja bitowa może manipulować tylko bitami w typach całkowitych, takich jak char
i int
. Nie działa w przypadku float
bardziej złożonych typów danych , , void
double
long double
, , bool
lub innych.
Jednoargumentowy operator ~
uzupełniania bitowego ma zastosowanie do typu danych na poziomie poszczególnych bitów. Podana wartość bitowa b
wynosi 1, ~b
jeśli b
ma wartość 0 i 0, jeśli b
ma wartość 1.
Przykład
// valarray_op_bitnot.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<unsigned short int> vaL1 ( 10 );
valarray<unsigned short int> vaNOT1 ( 10 );
for ( i = 0 ; i < 10 ; i += 2 )
vaL1 [ i ] = i;
for ( i = 1 ; i < 10 ; i += 2 )
vaL1 [ i ] = 5*i;
cout << "The initial valarray <unsigned short int> is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaL1 [ i ] << " ";
cout << ")." << endl;
vaNOT1 = ~vaL1;
cout << "The element-by-element result of "
<< "the bitwise NOT operator~ is the"
<< endl << "valarray: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaNOT1 [ i ] << " ";
cout << ")." << endl << endl;
valarray<int> vaL2 ( 10 );
valarray<int> vaNOT2 ( 10 );
for ( i = 0 ; i < 10 ; i += 2 )
vaL2 [ i ] = i;
for ( i = 1 ; i < 10 ; i += 2 )
vaL2 [ i ] = -2 * i;
cout << "The initial valarray <int> is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaL2 [ i ] << " ";
cout << ")." << endl;
vaNOT2 = ~vaL2;
cout << "The element-by-element result of "
<< "the bitwise NOT operator~ is the"
<< endl << "valarray: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaNOT2 [ i ] << " ";
cout << ")." << endl;
// The negative numbers are represented using
// the two's complement approach, so adding one
// to the flipped bits returns the negative elements
vaNOT2 = vaNOT2 + 1;
cout << "The element-by-element result of "
<< "adding one"
<< endl << "is the negative of the "
<< "original elements the"
<< endl << "valarray: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaNOT2 [ i ] << " ";
cout << ")." << endl;
}
The initial valarray <unsigned short int> is: ( 0 5 2 15 4 25 6 35 8 45 ).
The element-by-element result of the bitwise NOT operator~ is the
valarray: ( 65535 65530 65533 65520 65531 65510 65529 65500 65527 65490 ).
The initial valarray <int> is: ( 0 -2 2 -6 4 -10 6 -14 8 -18 ).
The element-by-element result of the bitwise NOT operator~ is the
valarray: ( -1 1 -3 5 -5 9 -7 13 -9 17 ).
The element-by-element result of adding one
is the negative of the original elements the
valarray: ( 0 2 -2 6 -4 10 -6 14 -8 18 ).
resize
Zmienia liczbę elementów w valarray
liczbie na określoną liczbę.
void resize(
size_t new_size);
void resize(
size_t new_size,
const Type val);
Parametry
new_size
Liczba elementów w zmienionym valarray
rozmiarze .
val
Wartość, która ma zostać nadana elementom o zmienionym valarray
rozmiarze .
Uwagi
Pierwsza funkcja składowa inicjuje elementy za pomocą ich konstruktora domyślnego.
Wszelkie wskaźniki lub odwołania do elementów w kontrolowanej sekwencji są unieważniane.
Przykład
W poniższym przykładzie pokazano użycie funkcji składowej valarray::resize
.
// valarray_resize.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main()
{
using namespace std;
int i;
size_t size1, sizeNew;
valarray<int> va1(10);
for (i = 0; i < 10; i+=1)
va1[i] = i;
cout << "The valarray contains ( ";
for (i = 0; i < 10; i++)
cout << va1[i] << " ";
cout << ")." << endl;
size1 = va1.size();
cout << "The number of elements in the valarray is: "
<< size1 << "." <<endl << endl;
va1.resize(15, 10);
cout << "The valarray contains ( ";
for (i = 0; i < 15; i++)
cout << va1[i] << " ";
cout << ")." << endl;
sizeNew = va1.size();
cout << "The number of elements in the resized valarray is: "
<< sizeNew << "." <<endl << endl;
}
The valarray contains ( 0 1 2 3 4 5 6 7 8 9 ).
The number of elements in the valarray is: 10.
The valarray contains ( 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 ).
The number of elements in the resized valarray is: 15.
shift
Przesuwa wszystkie elementy w obiekcie valarray
o określoną liczbę miejsc.
valarray<Type> shift(int count) const;
Parametry
count
Liczba miejsc, w których elementy mają być przesunięte do przodu.
Wartość zwracana
Nowy valarray
element, w którym wszystkie elementy zostały przeniesione count
pozycje w kierunku przodu valarray
, lub lewej, w porównaniu do ich pozycji w operand valarray
.
Uwagi
Dodatnia count
wartość przesunięcia elementów w pozostałych count
miejscach z zerowym wypełnieniem.
Ujemna count
wartość przesunięcia elementów w odpowiednich count
miejscach z zerowym wypełnieniem.
Przykład
// valarray_shift.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> va1 ( 10 ), va2 ( 10 );
for ( i = 0 ; i < 10 ; i += 1 )
va1 [ i ] = i;
for ( i = 0 ; i < 10 ; i += 1 )
va2 [ i ] = 10 - i;
cout << "The operand valarray va1(10) is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << va1 [ i ] << " ";
cout << ")." << endl;
// A positive parameter shifts elements left
va1 = va1.shift ( 4 );
cout << "The shifted valarray va1 is: va1.shift (4) = ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << va1 [ i ] << " ";
cout << ")." << endl;
cout << "The operand valarray va2(10) is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << va2 [ i ] << " ";
cout << ")." << endl;
// A negative parameter shifts elements right
va2 = va2.shift ( - 4 );
cout << "The shifted valarray va2 is: va2.shift (-4) = ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << va2 [ i ] << " ";
cout << ")." << endl;
}
The operand valarray va1(10) is: ( 0 1 2 3 4 5 6 7 8 9 ).
The shifted valarray va1 is: va1.shift (4) = ( 4 5 6 7 8 9 0 0 0 0 ).
The operand valarray va2(10) is: ( 10 9 8 7 6 5 4 3 2 1 ).
The shifted valarray va2 is: va2.shift (-4) = ( 0 0 0 0 10 9 8 7 6 5 ).
size
Znajduje liczbę elementów w obiekcie valarray
.
size_t size() const;
Wartość zwracana
Liczba elementów w operandzie valarray
.
Przykład
W poniższym przykładzie pokazano użycie funkcji składowej valarray::size
.
// valarray_size.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main()
{
using namespace std;
int i;
size_t size1, size2;
valarray<int> va1(10), va2(12);
for (i = 0; i < 10; i += 1)
va1[i] = i;
for (i = 0; i < 10; i += 1)
va2[i] = i;
cout << "The operand valarray va1(10) is: ( ";
for (i = 0; i < 10; i++)
cout << va1[i] << " ";
cout << ")." << endl;
size1 = va1.size();
cout << "The number of elements in the valarray va1 is: va1.size = "
<< size1 << "." <<endl << endl;
cout << "The operand valarray va2(12) is: ( ";
for (i = 0; i < 10; i++)
cout << va2[i] << " ";
cout << ")." << endl;
size2 = va2.size();
cout << "The number of elements in the valarray va2 is: va2.size = "
<< size2 << "." << endl << endl;
// Initializing two more elements to va2
va2[10] = 10;
va2[11] = 11;
cout << "After initializing two more elements,\n"
<< "the operand valarray va2(12) is now: ( ";
for (i = 0; i < 12; i++)
cout << va2[i] << " ";
cout << ")." << endl;
cout << "The number of elements in the valarray va2 is still: "
<< size2 << "." << endl;
}
The operand valarray va1(10) is: ( 0 1 2 3 4 5 6 7 8 9 ).
The number of elements in the valarray va1 is: va1.size = 10.
The operand valarray va2(12) is: ( 0 1 2 3 4 5 6 7 8 9 ).
The number of elements in the valarray va2 is: va2.size = 12.
After initializing two more elements,
the operand valarray va2(12) is now: ( 0 1 2 3 4 5 6 7 8 9 10 11 ).
The number of elements in the valarray va2 is still: 12.
sum
Określa sumę wszystkich elementów o valarray
długości niezerowej.
Type sum() const;
Wartość zwracana
Suma elementów operandu valarray
.
Uwagi
Jeśli długość jest większa niż jedna, funkcja składowa dodaje wartości do sumy, stosując operator+=
między parami elementów klasy Type
. Oznacza to, że operator musi być dostarczony dla elementów typu Type
.
Przykład
// valarray_sum.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
int sumva = 0;
valarray<int> va ( 10 );
for ( i = 0 ; i < 10 ; i+=1 )
va [ i ] = i;
cout << "The operand valarray va (10) is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << va [ i ] << " ";
cout << ")." << endl;
sumva = va.sum ( );
cout << "The sum of elements in the valarray is: "
<< sumva << "." <<endl;
}
The operand valarray va (10) is: ( 0 1 2 3 4 5 6 7 8 9 ).
The sum of elements in the valarray is: 45.
swap
Wymienia elementy dwóch valarray
obiektów.
void swap(valarray& right);
Parametry
right
Element valarray
dostarczający elementy do zamiany.
Uwagi
Funkcja składowa zamienia kontrolowane sekwencje między *this
i right
. Robi to w stałym czasie, nie zgłasza żadnych wyjątków i unieważnia żadnych odwołań, wskaźników lub iteratorów do elementów w dwóch kontrolowanych sekwencjach.
valarray
valarray
Tworzy określony rozmiar lub elementy określonej wartości lub jako kopię innego valarray
lub podzestawu innego valarray
.
valarray();
explicit valarray(
size_t count);
valarray(
const Type& val,
size_t count);
valarray(
const Type* ptr,
size_t count);
valarray(
const valarray<Type>& right);
valarray(
const slice_array<Type>& sliceArray);
valarray(
const gslice_array<Type>& gsliceArray);
valarray(
const mask_array<Type>& maskArray);
valarray(
const indirect_array<Type>& indArray);
valarray(
valarray<Type>&& tight);
valarray(
initializer_list<Type> iList);
Parametry
count
Liczba elementów, które mają być w elemecie valarray
.
val
Wartość, która ma być używana podczas inicjowania elementów w obiekcie valarray
.
ptr
Wskaźnik do wartości, które mają być używane do inicjowania elementów w obiekcie valarray
.
right
valarray
Istniejący do zainicjowania nowego valarray
elementu .
sliceArray
Element slice_array
, którego wartości elementów mają być używane podczas inicjowania elementów valarray
konstruowanych.
gsliceArray
Element gslice_array
, którego wartości elementów mają być używane podczas inicjowania elementów valarray
konstruowanych.
maskArray
Element mask_array
, którego wartości elementów mają być używane podczas inicjowania elementów valarray
konstruowanych.
indArray
Element indirect_array
, którego wartości elementów mają być używane podczas inicjowania elementów valarray
konstruowanych.
iList
Element initializer_list
zawierający elementy do skopiowania.
Uwagi
Pierwszy (domyślny) konstruktor inicjuje obiekt do pustego valarray
obiektu . Następne trzy konstruktory inicjują obiekt do elementu valarray
count
w następujący sposób:
Dla jawnego
valarray(size_t count)
, każdy element jest inicjowany przy użyciu konstruktora domyślnego.Dla
valarray(const Type& val, count)
elementu każdy element jest inicjowany za pomocąval
polecenia .W przypadku
valarray(const Type* ptr, count)
elementu na pozycjiI
element jest inicjowany za pomocąptr[I]
polecenia .
Każdy pozostały konstruktor inicjuje valarray<Type>
obiekt do obiektu określonego w podzestawie określonym w argumencie.
Ostatni konstruktor jest taki sam jak obok ostatniego, ale z deklaratorem odwołania Rvalue: &&
.
Przykład
// valarray_ctor.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main()
{
using namespace std;
int i;
// The second member function
valarray<int> va(10);
for (auto i : va){
va[i] = 2 * (i + 1);
}
cout << "The operand valarray va is:\n(";
for (auto i : va) {
cout << " " << va[i];
}
cout << " )" << endl;
slice Slice(2, 4, 3);
// The fifth member function
valarray<int> vaSlice = va[Slice];
cout << "The new valarray initialized from the slice is vaSlice =\n"
<< "va[slice( 2, 4, 3)] = (";
for (int i = 0; i < 3; i++) {
cout << " " << vaSlice[i];
}
cout << " )" << endl;
valarray<int> va2{{ 1, 2, 3, 4 }};
for (auto& v : va2) {
cout << v << " ";
}
cout << endl;
}
The operand valarray va is:
( 0 2 2 2 2 2 2 2 2 2 )
The new valarray initialized from the slice is vaSlice =
va[slice( 2, 4, 3)] = ( 0 0 0 )
1 2 3 4
value_type
Typ reprezentujący typ elementu przechowywanego w obiekcie valarray
.
typedef Type value_type;
Uwagi
Typ jest synonimem parametru Type
szablonu .
Przykład
// valarray_value_type.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> va ( 10 );
for ( i = 0 ; i < 10 ; i += 2 )
va [ i ] = i;
for ( i = 1 ; i < 10 ; i += 2 )
va [ i ] = -1;
cout << "The initial operand valarray is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << va [ i ] << " ";
cout << ")." << endl;
// value_type declaration and initialization:
valarray<int>::value_type Right = 10;
cout << "The declared value_type Right is: "
<< Right << endl;
va *= Right;
cout << "The resulting valarray is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << va [ i ] << " ";
cout << ")." << endl;
}
The initial operand valarray is: ( 0 -1 2 -1 4 -1 6 -1 8 -1 ).
The declared value_type Right is: 10
The resulting valarray is: ( 0 -10 20 -10 40 -10 60 -10 80 -10 ).