Recipiente de vetor em C++ STL
-
Use
std::vectorpara construir um array dinâmica em C++ -
Use
std::vectorpara armazenar objetosstructem C++ -
Use a função
std::vector::swappara 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