std::deque::emplace_front
#include <deque>
template <class... Args>
void emplace_front(Args&&... args);
Xây dựng một phần tử mới trực tiếp tại đầu deque, tránh việc sao chép hoặc di chuyển không cần thiết.
Tham số
args
- Danh sách các đối số (có thể trống) được sử dụng để khởi tạo phần tử mới. Các đối số này sẽ được truyền đến constructor của kiểu phần tử
value_type
của deque.
Giá trị trả về
Không có giá trị trả về
Đặc điểm
emplace()
tạo một phần tử mới ngay tại vị trí được trỏ bởi iteratorpos
bằng cách sử dụng các đối sốargs
để khởi tạo phần tử. Nó tương tự nhưinsert()
, nhưng thay vì nhận vào một đối tượng đã được tạo,emplace()
nhận các đối số để xây dựng đối tượng ngay tại chỗ.emplace()
tạo phần tử mới trực tiếp trong bộ nhớ của deque, tránh việc tạo ra các đối tượng tạm thời không cần thiết, tối ưu hiệu suất.- Bằng cách xây dựng phần tử tại chỗ,
emplace()
giúp tránh việc sao chép (copy) hoặc di chuyển (move) các đối tượng, đặc biệt hiệu quả khi làm việc với các đối tượng lớn hoặc phức tạp. emplace()
sử dụng variadic template (Args&&... args), cho phép nó nhận số lượng đối số tùy ý, phù hợp với constructor của kiểu phần tử.- Việc chèn phần tử vào deque có thể làm thay đổi (invalidate) các iterator khác đang trỏ đến các phần tử trong deque.
insert()
sẽ tạo bản sao hoặc di chuyển phần tử được truyền vào trong khi đóemplace()
sẽ xây dựng phần tử tại chỗ trong deque, cho phép dùngemplace()
ngay cả khi kiểu phần tử không hỗ trợ copy/move constructor.- Độ phức tạp: Độ phức tạp của
emplace()
tương tự nhưinsert()
.- Chèn một phần tử:
O(n)
trong trường hợp xấu nhất (khi chèn vào đầu),O(1)
trong trường hợp tốt nhất (khi chèn vào cuối), với n là số phần tử trong deque. Trung bình làO(min(n, N-n))
với n là khoảng cách từpos
tới đầu deque và N-n là khoảng cách từpos
đến cuối deque.
- Chèn một phần tử:
Ví dụ
#include <iostream>
#include <deque>
#include <string>
int main() {
std::deque<std::pair<int, std::string>> myDeque;
// Thêm một phần tử mới vào đầu deque, sử dụng emplace_front()
myDeque.emplace_front(10, "Hello");
// Thêm một phần tử mới vào đầu deque, sử dụng emplace_front()
myDeque.emplace_front(20, "World");
// In ra các phần tử trong deque
std::cout << "myDeque:";
for (const auto& p : myDeque) {
std::cout << " (" << p.first << ", " << p.second << ")";
}
std::cout << '\n'; // Output: myDeque: (20, World) (10, Hello)
return 0;
}
Với class không hỗ trợ copy/move constructor
#include <iostream>
#include <deque>
class NonCopyable {
public:
NonCopyable(int val) : data(val) {}
NonCopyable(const NonCopyable&) = delete;
NonCopyable& operator=(const NonCopyable&) = delete;
// Move constructor/assignment are not necessary but good practice
NonCopyable(NonCopyable&&) = default;
NonCopyable& operator=(NonCopyable&&) = default;
int data;
};
int main() {
std::deque<NonCopyable> myDeque;
// myDeque.push_front(NonCopyable(10)); // Error: Copy constructor is deleted
myDeque.emplace_front(10); // OK: Constructs the element in-place
myDeque.emplace_front(20); // OK: Constructs the element in-place
std::cout << "myDeque:";
for (const auto& obj : myDeque) {
std::cout << " " << obj.data;
}
std::cout << '\n'; // Output: myDeque: 20 10
return 0;
}
Các hàm liên quan
emplace_back | Xây dựng một phần tử mới trực tiếp tại cuối deque |
push_front | Thêm một phần tử mới vào đầu deque |
emplace | Xây dựng một phần tử mới trực tiếp tại một vị trí cụ thể trong deque |
erase | Xóa một hoặc nhiều phần tử khỏi deque tại một vị trí cụ thể hoặc trong một phạm vi |
assign | Gán các phần tử mới cho deque, thay thế nội dung hiện tại của nó |