Пространства имён
Варианты
Действия

value initialization

Материал из cppreference.com
< cpp‎ | language

 
 
Язык С++
Общие темы
Управление программой
Операторы условного выполнения
Операторы повторения
Операторы перехода
Функции
объявление функции
объявление лямбда-функции
шаблон функции
спецификатор inline
спецификаторы исключений (устарело)
спецификатор noexcept (C++11)
Исключения
Пространства имён
объявление пространства имён
псевдонимы пространства имён
Типы
спецификатор decltype (C++11)
Спецификаторы
cv-спецификаторы
спецификаторы продолжительности хранения
спецификатор constexpr (C++11)
спецификатор auto (C++11)
спецификатор alignas (C++11)
Инициализация
Литералы
Выражения
Утилиты
Типы
typedef-объявление
объявление псевдонима типа (C++11)
атрибуты (C++11)
Приведения типов
неявные преобразования
const_cast-преобразование
static_cast-преобразование
dynamic_cast-преобразование
reinterpret_cast-преобразование
C-подобное и функциональное приведение типов
Выделение памяти
Классы
Особые свойства классовых функций
Специальные функции-члены
Шаблоны
шаблон класса
шаблон функции
специализация шаблона
упакованные параметры (C++11)
Разное
Ассемблерные вставки
 
Обеспечивает по умолчанию начальное значение нового объекта.
Оригинал:
Provides the default initial value to a new object.
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

Содержание

[править] Синтаксис

T object {}; (1) (начиная с C++11)
T();

T{};

(2)
(начиная с C++11)
new T ();

new T {};

(3)
(начиная с C++11)

[править] Объяснение

Значение инициализации осуществляется в трех ситуациях:
Оригинал:
Value initialization is performed in three situations:
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
1)
При именем переменной (автоматические, статические, или поток-местный) объявляется с помощью инициализатора, состоящий из пары фигурных скобок. (начиная с C++11)
Оригинал:
when a named variable (automatic, static, or thread-local) is declared with the initializer consisting of a pair of braces. (начиная с C++11)
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
2)
При безымянных временный объект создается с инициализатор, состоящий из пустых пару круглые или фигурные скобки.
Оригинал:
when a nameless temporary object is created with the initializer consisting of an empty pair of parentheses or braces.
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
3)
когда объект с динамическим срок хранения создано новое выражение инициализатора, состоящий из пустых пару круглые или фигурные скобки.
Оригинал:
when an object with dynamic storage duration is created by a new-expression with the initializer consisting of an empty pair of parentheses or braces.
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
Влияние значения инициализации являются:
Оригинал:
The effects of value initialization are:
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
  • Если T это класс крайней мере с одним пользователем при условии, конструктор любого рода, конструктор по умолчанию называется.
    Оригинал:
    If T is a class type with at least one user-provided constructor of any kind, the конструктор по умолчанию is called.
    Текст был переведён автоматически через Google Translate.
    Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
  • Если T это не состоящих в профсоюзе типа класса без предоставленные пользователем конструкторов, то объект нулю инициализирован, а затем неявно объявлен вызывается конструктор по умолчанию (если это не тривиально)
    Оригинал:
    If T is an non-union class type without any user-provided constructors, then the object is нулю инициализирован and then the implicitly-declared default constructor is called (unless it's trivial)
    Текст был переведён автоматически через Google Translate.
    Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
  • Если T является типом массива, каждый элемент массива является значение инициализации
    Оригинал:
    If T is an array type, each element of the array is value-initialized
    Текст был переведён автоматически через Google Translate.
    Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
  • В противном случае, объект равен нулю инициализирован.
    Оригинал:
    Otherwise, the object is zero-initialized.
    Текст был переведён автоматически через Google Translate.
    Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

[править] Заметки

Синтаксис T object(); не инициализирует объект, он заявляет, что функция не принимает аргументов и возвращает T. Путь к значению инициализации переменной перед именем C + +11 была T object = T();, значение которого инициализирует временный, а затем копирования инициализирует объект: большинство компиляторов оптимизации из копии в данном случае.
Оригинал:
The syntax T object(); does not initialize an object; it declares a function that takes no arguments and returns T. The way to value-initialize a named variable before C++11 was T object = T();, which value-initializes a temporary and then copy-initializes the object: most compilers optimize out the copy in this case.
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
Литература не может быть инициализирован значением.
Оригинал:
References cannot be value-initialized.
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
Все стандартные контейнеры (std::vector, std::list, и т.д.) стоимость инициализации их элементов, когда построена с одним аргументом size_type или когда выросла на вызов resize().
Оригинал:
All standard containers (std::vector, std::list, etc) value-initialize their elements when constructed with a single size_type argument or when grown by a call to resize().
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

[править] Пример

#include <string>
#include <vector>
#include <iostream>
 
struct T1 {
    int mem1;
    std::string mem2;
}; // no constructors
struct T2 {
    int mem1;
    std::string mem2;
    T2(const T2&) {} // a constructor, but no default
};
struct T3 {
    int mem1;
    std::string mem2;
    T3() {} // user-provided default ctor
};
 
std::string s{}; // calls default ctor, the value is "" (empty string)
int main()
{
    int n{};     // non-class value-initialization, value is 0
    double f = double(); // non-class value-init, value is 0.0
    int* a = new int[10](); // array of 10 zeroes
 
    T1 t1{}; // no ctors: zero-initialized
             // t1.mem1 is zero-initialized
             // t1.mem2 is default-initialized
//    T2 t2{}; // error: has a ctor, but no default ctor
    T3 t3{}; // user-defined default ctor:
             // t3.mem1 is default-initialized (the value is indeterminate)
             // t3.mem2 is default-initialized
 
    std::vector<int> v(3); // value-initializes three ints
 
    std::cout << s.size() << ' ' << n << ' ' << f << ' ' << a[9] << ' ' << v[2] << '\n';
    std::cout << t1.mem1 << ' ' << t3.mem1 << '\n';
    delete[] a;
}

Вывод:

0 0 0 0 0
0 4199376

[править] См. также