id,summary,reporter,owner,description,type,status,milestone,component,version,severity,resolution,keywords,cc 13165,inplace_ptr,gast128@…,Peter Dimov,"Boost.Optional uses in place object creation. In many cases it could used as a drop in repelacment of scoped_ptr with the benefit of circumventing a memory allocation and locality of memory access. However its semantics is 'optional' and not like a fast replacement of scoped_ptr. Wouldn't it be an idea to add something like this to the smart_ptr library? Names can be e.g. inplace_ptr, value_ptr, etc. We could also use Boost.Optional but colleagues might get confused, since you do not use the 'optional' aspect but its performance aspect. Note that people might wonder why not use value based directly, but there are still some use cases: * for pimpl idiom / hide expansive headers (e.g. multi index) in client * 2 phase construction, where information is not yet available at parent constructor time. Only drawback is that you lose polymorphism. https://stackoverflow.com/questions/22636407/why-not-use-boostoptional-as-a-better-scoped-ptr",Feature Requests,new,To Be Determined,smart_ptr,Boost 1.64.0,Not Applicable,,,