8

So I know any header from the C Compatability Headers:

Places in the global namespace each name that the corresponding cxxx header would have placed in the std namespace

I also know that these C headers were deprecated as of , in favor of their compatibility "cxxx" counterparts.

Now, I believe that size_t is defined exclusively by the Standard Defines Header. So I presume this technically means that the definition of size_t in the global namespace has been deprecated?

I've been using it for years as just size_t and I'd just like a confirmation before I move to using std::size_t.

YSC
  • 38,212
  • 9
  • 96
  • 149
Jonathan Mee
  • 37,899
  • 23
  • 129
  • 288
  • `Now, I believe that size_t is defined exclusively by the Standard Defines Header` is not exactly correct, since many of the C compatibility library headers besides `cstddef` define it. – eerorika Jul 24 '18 at 14:09
  • 3
    @François I'm not sure this is a duplicate. OP wants to know if `::size_t` is deprecated. – YSC Jul 24 '18 at 14:15
  • @YSC The duplicate does address that `::size_t` is not required to be define. I would reason that it addresses the part about deprecation because the standard can't deprecate something it doesn't define. – François Andrieux Jul 24 '18 at 14:18

4 Answers4

6

I presume this technically means that the definition of size_t in the global namespace has been deprecated?

Yes... but.

The Standard only mandates that std::size_t must be defined1 by <cstddef>, it does not disallow an implementation to define ::size_t2, but if the implementation does, the two definitions must match3.

As a conclusion, you should use std::size_t and should neither rely on ::size_t to be defined nor define it.

The following are UB:

// DON'T
using size_t = std::size_t;        // UB
using size_t = decltype(sizeof 1); // UB

1) [cstddef.syn]

namespace std {
    using ptrdiff_­t = see below;
    using size_­t = see below;
    using max_­align_­t = see below;
    using nullptr_­t = decltype(nullptr);

[...]
The contents and meaning of the header <cstddef> are the same as the C standard library header <stddef.h>, except that it does not declare the type wchar_­t, that it also declares the type byte and its associated operations ([support.types.byteops]), and as noted in [support.types.nullptr] and [support.types.layout].

2)[extern.types]/1

For each type T from the C standard library (These types are [...] size_­t,[...].), the types ​::​T and std​::​T are reserved to the implementation[.]

3)[extern.types]/1

[...] when defined, ​::​T shall be identical to std​::​T.

Community
  • 1
  • 1
YSC
  • 38,212
  • 9
  • 96
  • 149
3

C-style header names like <stddef.h> are deprecated. However, C++-style headers like <cstddef> are allowed to declare their names in global namespace and then redeclare the same names in namespace std through using-declarations (http://eel.is/c++draft/organization#headers-4). This approach to declaring standard names is not deprecated. And many implementations do exactly that, for which reason it is not unusual to see name size_t accessible as a name from global namespace. But this is not guaranteed. So, in portable C++ code that includes <cstddef> you should use std::size_t and never rely on ::size_t's availability.

AnT stands with Russia
  • 312,472
  • 42
  • 525
  • 765
1

The standard says [expr.sizeof]:

The result of sizeof and sizeof... is a constant of type std​::​size_­t. [ Note: std​::​size_­t is defined in the standard header <cstddef> ([cstddef.syn], [support.types.layout]). — end note ]

Maxim Egorushkin
  • 131,725
  • 17
  • 180
  • 271
0

Where is size_t Defined?

::size_t is guaranteed to be defined in <stddef.h> and few other C standard library headers that are inherited by c++. It may be defined by the implementation whether anything is included or not, since it is reserved, but relying on such non guaranteed definition would not be wise.

So I presume this technically means that the definition of size_t in the global namespace has been deprecated?

Indeed. More precisely, all standard headers that are guaranteed to define ::size_t are now deprecated in C++17. Same applies to all other non-macro C library names such as ::FILE.

eerorika
  • 232,697
  • 12
  • 197
  • 326