Chinaunix首页 | 论坛 | 博客
  • 博客访问: 103950
  • 博文数量: 18
  • 博客积分: 1425
  • 博客等级: 上尉
  • 技术积分: 236
  • 用 户 组: 普通用户
  • 注册时间: 2008-04-21 20:38
文章分类
文章存档

2011年(6)

2009年(10)

2008年(2)

我的朋友

分类: C/C++

2009-03-31 09:50:56

C++ Language Note:

POD Types

Walter E. Brown
September 29, 1999; last updated November 29, 1999

1.  Purpose

This note documents the definition of a POD type according to the International Standard for the C++ Programming Language [ISO/IEC 14882, first edition, 1998-09-01].  Related definitions are also provided, as is interpretive commentary on the significance of a POD-type.  All references herein are to the Standard.

2.  Definitions

The term POD is an acronym.  It stands for "plain old data" [p. 5, footnote 4], and is intended to suggest areas of substantive compatibility between comparable data types in C and C++.  The terms POD and POD object are often used interchangeably to refer to an object of POD type.

The term POD types collectively refers to the following categories of C++ types, and encompasses both cv-qualified versions of these as well as arrays of these [§3.9, ¶10; §9, ¶4]:

  • scalar types, and
  • POD class types.
The term scalar types collectively refers to the following categories of C++ types, and encompasses cv-qualified versions of these [§3.9, ¶10]:
  • arithmetic types,
  • enumeration types,
  • pointer types, and
  • pointer-to-member types.
The term arithmetic types collectively refers to the following categories of C++ types [§3.9.1, ¶8]:
  • integral (also known as integer) types, and
  • floating (also known as floating point) types.
The term integral types collectively refers to the following C++ types [§3.9.1, ¶7]:
  • signed integer types (signed char, short, int, long),
  • unsigned integer types (unsigned char, unsigned short, unsigned int, unsigned long),
  • char and wchar_t, and
  • bool.
The term floating types collectively refers to the C++ types float, double, and long double [§3.9.1, ¶8].

The term enumeration types collectively refers to distinct types, known as enumerations, that comprise sets of named constant values [§3.9.1, ¶1; §7.2, ¶1].

The term pointer types collectively refers to the following categories of C++ types [§3.9.2, ¶1]:

  • pointer-to-void (void *),
  • pointer-to-object and pointer-to-static-member-data (both of the form T* when pointing to an object of type T), and
  • pointer-to-function and pointer-to-static-member-function (both of the form T (*)(...) when pointing to a function that returns an object of type T).
The term pointer-to-member types collectively refers to the following C++ types [§3.9.2, ¶1]:
  • pointer-to-nonstatic-member-data (of the form T C::* when pointing to one of class C's data members that has type T), and
  • pointer-to-nonstatic-member-functions (of the form T (C::*)(...) when pointing to one of class C's member functions that returns an object of type T).
The term POD class types collectively refers to aggregate classes (POD-struct types) and aggregate unions (POD-union types) that have none of the following as members [§9, ¶4]:
  • non-static data (including arrays) of any pointer-to-member type,
  • non-static data (including arrays) of any non-POD class type,
  • non-static data of any reference type,
  • user-defined copy assignment operator, nor
  • user-defined destructor.
The term aggregate refers to an array or class that has none of the following characteristics [§8.5.1, ¶1]:
  • user-declared constructors,
  • private or protected non-static data members,
  • base classes, nor
  • virtual functions.
  • 3.  Commentary

    POD types have primary significance as an important source of compatibility with ANSI C code.  As such, objects of these types share several characteristics with their C equivalents.  These characteristics include initialization, copying, layout, and addressing.

    As an example of the sometimes-subtle distinction between POD and non-POD types, consider the initializations implied by each of the following new-expressions [§5.3.4, ¶15]:
     

    expression POD type T non-POD type T
     new T not initialized default-initialized
     new T() always default-initialized
     new T(x) always initialized via a constructor

    Thus, an object (or an array) of non-POD type is always guaranteed initialization, while an instance (or an array) of a POD type may be left uninitialized.

    Other POD-related C++ characteristics include the following:

    1. Layout
      • The bytes constituting a POD object are contiguous [§1.8, ¶5].
      • "POD-struct ... types are layout-compatible if they have the same number of members, and corresponding members (in order) have layout-compatible types" [§9.2, ¶14].
      • POD-union ... types are layout-compatible if they have the same number of members, and corresponding members (in any order) have layout-compatible types" [§9.2, ¶15].
    2. Initialization
      • A non-const POD object declared with no initializer has an "indeterminate initial value" [§8.5, ¶9].
      • Default initialization of a POD object is zero initialization [§8.5, ¶5].
      • A static POD object declared with an initializer is given its initial value:
        • if local, "before its block is first entered" [§6.7, ¶4]; else
        • if non-local, "before any dynamic initialization takes place" [§3.6.2, ¶1].
    3. Copying
      • The bytes constituting a POD object can be copied (e.g., via memcpy())
        • to a sufficiently large array of char or unsigned char and back again without changing the object's value [§3.9, ¶2], or
        • to another object of the same POD-type, in which case the second object's value will be the same as that of the first [§3.9, ¶3].
      • Any POD type may be used as the "character" type in the standard's templated string classes [§21, ¶1].
    4. Addressing
      • The address of a POD object can be an address constant expression (or part of one) [§5.19, ¶4], while a reference to a POD member can be a reference constant expression [§5.19, ¶5].
      • "A pointer to a POD-struct object, suitably converted using a reinterpret_cast, points to its initial member ... and vice versa" [§9.2, ¶17].
    阅读(1337) | 评论(0) | 转发(0) |
    给主人留下些什么吧!~~