According to this reference for operator new
:
Global dynamic storage operator functions are special in the standard library:
- All three versions of operator new are declared in the global namespace, not in the std namespace.
- The first and second versions are implicitly declared in every translation unit of a C++ program: The header does not need to be included for them to be present.
This seems to me to imply that the third version of operator new
(placement new
) is not implicitly declared in every translation unit of a C++ program and the header <new>
does need to be included for it to be present. Is that correct?
If so, how is it that using both g++ and MS VC++ Express compilers it seems I can compile code using the third version of new
without #include <new>
in my source code?
Also, the MSDN Standard C++ Library reference entry on operator new
gives some example code for the three forms of operator new
which contains the #include <new>
statement, however the example seems to compile and run just the same for me without this include?
// new_op_new.cpp
// compile with: /EHsc
#include<new>
#include<iostream>
using namespace std;
class MyClass
{
public:
MyClass( )
{
cout << "Construction MyClass." << this << endl;
};
~MyClass( )
{
imember = 0; cout << "Destructing MyClass." << this << endl;
};
int imember;
};
int main( )
{
// The first form of new delete
MyClass* fPtr = new MyClass;
delete fPtr;
// The second form of new delete
char x[sizeof( MyClass )];
MyClass* fPtr2 = new( &x[0] ) MyClass;
fPtr2 -> ~MyClass();
cout << "The address of x[0] is : " << ( void* )&x[0] << endl;
// The third form of new delete
MyClass* fPtr3 = new( nothrow ) MyClass;
delete fPtr3;
}
Could anyone shed some light on this, and when and why you might need to #include <new>
- maybe some example code that will not compile without #include <new>
?
The C++ Standard verse 3.7.4.2 says :-
The library provides default definitions for the global allocation and deallocation functions. Some global allocation and deallocation functions are replaceable (18.6.1). A C++ program shall provide at most one definition of a replaceable allocation or deallocation function. Any such function definition replaces the default version provided in the library (17.6.3.6). The following allocation and deallocation functions (18.6) are implicitly declared in global scope in each translation unit of a program.
void* operator new(std::size_t) throw(std::bad_alloc);
void* operator new[](std::size_t) throw std::bad_alloc);
void operator delete(void*) throw();
void operator delete[](void*) throw();
These implicit declarations introduce only the function names
operator new
,operator new[]
,operator delete
,operator delete[]
. [ Note: the implicit declarations do not introduce the namesstd
,std::bad_alloc
, andstd::size_t
, or any other names that the library uses to declare these names. Thus, a new-expression, delete-expression or function call that refers to one of these functions without including the header<new>
is well-formed. However, referring tostd
,std::bad_alloc
, andstd::size_t
is ill-formed unless the name has been declared by including the appropriate header. —end note]
Also, the std::nothrow
version of the operator new
requires the inclusion of the header (example).
The standard though does not specify implicit inclusion of the header files within other header files. So it is safe and portable to follow the standard when the names std::bad_alloc
etc are referred.