Considerare this code:std :: make_shared() usa gli allocatori personalizzati?
#include <memory>
#include <iostream>
class SomeClass {
public:
SomeClass() {
std::cout << "SomeClass()" << std::endl;
}
~SomeClass() {
std::cout << "~SomeClass()" << std::endl;
}
void* operator new(std::size_t size) {
std::cout << "Custom new" << std::endl;
return ::operator new(size);
}
void operator delete(void* ptr, std::size_t size) {
std::cout << "Custom delete" << std::endl;
::operator delete(ptr);
}
};
int main() {
std::shared_ptr<SomeClass> ptr1(new SomeClass);
std::cout << std::endl << "Another one..." << std::endl << std::endl;
std::shared_ptr<SomeClass> ptr2(std::make_shared<SomeClass>());
std::cout << std::endl << "Done!" << std::endl << std::endl;
}
Qui è la sua uscita:
Custom new
SomeClass()
Another one...
SomeClass()
Done!
~SomeClass()
~SomeClass()
Custom delete
Chiaramente, std::make_shared()
non ha chiamato l'operatore new
- sta usando un allocatore personalizzato. È questo il comportamento standard per std::make_shared()
?
'std :: allocate_shared (const A &, Args && ...)' vale anche una menzione. Il primo argomento è l'allocatore per chiamare 'A :: allocate' on. –