Recipiente de vetor em C++ STL
-
Use
std::vector
para construir um array dinâmica em C++ -
Use
std::vector
para armazenar objetosstruct
em C++ -
Use a função
std::vector::swap
para trocar elementos do vetor em C++
Este artigo apresentará vários métodos sobre como usar um contêiner vetorial
em C++.
Use std::vector
para construir um array dinâmica em C++
std::vector
é parte da biblioteca de contêineres e implementa um array redimensionável dinamicamente que armazena elementos em um armazenamento contíguo. Os elementos vector
são geralmente adicionados no final com as funções integradas push_back
ou emplace_back
. O contêiner vector
pode ser facilmente construído com a lista de inicializadores, conforme mostrado no código de exemplo a seguir - objeto arr
. Além disso, é possível armazenar valores de lista de inicializadores estáticos na expressão macro e expressar concisamente a operação de inicialização quando necessário.
#include <iostream>
#include <vector>
using std::cin;
using std::cout;
using std::endl;
using std::string;
using std::vector;
#define INIT \
{ "Neque", "porro", "quisquam", "est", "qui", "dolorem", "ipsum", "quia" }
template <typename T>
void printVector(vector<T> &vec) {
for (const auto &item : vec) {
cout << item << ", ";
}
cout << endl;
}
int main() {
vector<string> arr = {"Neque", "porro", "quisquam", "est",
"qui", "dolorem", "ipsum", "quia"};
printVector(arr);
cout << endl;
vector<string> arr2 = INIT;
printVector(arr2);
cout << endl;
return EXIT_SUCCESS;
}
Use std::vector
para armazenar objetos struct
em C++
std::vector
pode ser utilizado para armazenar estruturas definidas de forma personalizada e inicializá-las com a notação de lista entre chaves semelhante ao exemplo anterior. Observe que, ao adicionar um novo elemento struct
usando a função push_back
, o valor deve ser passado como uma lista entre chaves e, se houver várias estruturas aninhadas dentro de uma struct
, a notação correspondente deve ser usada.
#include <iostream>
#include <vector>
using std::cin;
using std::cout;
using std::endl;
using std::string;
using std::vector;
struct cpu {
string wine;
string country;
int year;
} typedef cpu;
int main() {
vector<cpu> arr3 = {{"Chardonnay", "France", 2018}, {"Merlot", "USA", 2010}};
for (const auto &item : arr3) {
cout << item.wine << " - " << item.country << " - " << item.year << endl;
}
arr3.push_back({"Cabernet", "France", 2015});
for (const auto &item : arr3) {
cout << item.wine << " - " << item.country << " - " << item.year << endl;
}
return EXIT_SUCCESS;
}
Use a função std::vector::swap
para trocar elementos do vetor em C++
std::vector
fornece múltiplas funções embutidas para operar em seus elementos, uma das quais é swap
. Ele pode ser chamado a partir do objeto vector
e tomar outro vetor
como argumento para trocar seu conteúdo. Outra função útil é size
, que recupera a contagem atual do elemento no objeto vector
fornecido. Porém, observe que existe uma função semelhante chamada capacity
que retorna o número de elementos armazenados no buffer alocado atualmente. O último às vezes é alocado em tamanho maior para evitar chamadas não essenciais para os serviços do sistema operacional. O código de exemplo a seguir demonstra o cenário em que as duas funções retornam valores diferentes.
#include <iostream>
#include <vector>
using std::cin;
using std::cout;
using std::endl;
using std::vector;
template <typename T>
void printVector(vector<T> &vec) {
for (const auto &item : vec) {
cout << item << ", ";
}
cout << endl;
}
int main() {
vector<int> arr4 = {1, 12, 45, 134, 424};
vector<int> arr5 = {41, 32, 15, 14, 99};
printVector(arr4);
arr4.swap(arr5);
printVector(arr4);
cout << "arr4 capacity: " << arr4.capacity() << " size: " << arr4.size()
<< endl;
for (int i = 0; i < 10000; ++i) {
arr4.push_back(i * 5);
}
cout << "arr4 capacity: " << arr4.capacity() << " size: " << arr4.size()
<< endl;
arr4.shrink_to_fit();
cout << "arr4 capacity: " << arr4.capacity() << " size: " << arr4.size()
<< endl;
return EXIT_SUCCESS;
}
Resultado:
1, 12, 45, 134, 424,
41, 32, 15, 14, 99,
arr4 capacity: 5 size: 5
arr4 capacity: 10240 size: 10005
arr4 capacity: 10005 size: 10005
Founder of DelftStack.com. Jinku has worked in the robotics and automotive industries for over 8 years. He sharpened his coding skills when he needed to do the automatic testing, data collection from remote servers and report creation from the endurance test. He is from an electrical/electronics engineering background but has expanded his interest to embedded electronics, embedded programming and front-/back-end programming.
LinkedIn Facebook