What header defines NULL in C++?

According to C++ primer, <cstdlib> header defines NULL. cpluspplus says it is defined in <cstddef>.

Ultimately, if the right header is not included, I thought NULL can't be referenced.

From what i can see, however it can be referenced and produce programs and that compile and run without warnings or errors, after including only <iostream>

Please help me understand this.


Solution 1:

The C standard requires that NULL be defined in locale.h, stddef.h, stdio.h, stdlib.h, string.h, time.h, and wchar.h.

The C++ standard requires that NULL be defined in the c* header corresponding to each of those.

The C standard is very strict about the names a standard can define--each standard header must define precisely the names the standard requires that header to define. The only other names it can define are those that are reserved for the implementation, such as those starting with an underscore followed by another underscore or a capital letter.

The C++ standard is much more permissive in this respect--including any one standard header can have the same effect as including any or all other standard headers.

From a practical viewpoint, C++ implementations used to take quite a bit of advantage of this permissiveness--that is, including one standard header frequently defined the names from a number of other standard headers. More recent implementations tend to work more like the C standard requires, staying much closer to each header defining only the names required by to be defined by that header. They're still probably not as strict about it as the C standard requires, but much closer than they used to be (as a rule).

Solution 2:

C++03 section 18.1.2 says that NULL is defined in cstddef.

On some implementations, iostream may include cstddef, so including iostream would also give you NULL.