Что напечатает программа?
Anonymous Quiz
22%
1
12%
12
12%
2
14%
21
35%
Не скомпилируется
6%
Неопределенное поведение
👎1
👆Пояснение к предыдущему вопросу
👨🏻💻 Так как f находится в двух разных namespace, обычно такие вещи не компилируются, но тут нас ждёт страшный зверь под названием ADL.
Из-за ADL argument-dependent name lookup a.k.a. "Koenig lookup", поведение вполне нормальное.
С этой технологией, для lookup выбираются все namespace, которые перечислены в аргументах. Поэтому в данном случае мы рассмотрим только namespace x. Это сделано в основном для operator= и операторов сравнения, чтобы не надо было указывать namespace операторов, но к сожалению ведёт к достаточно сложным последствиям, если использование неправильно.
Задачи и тесты по программированию | proghub
👨🏻💻 Так как f находится в двух разных namespace, обычно такие вещи не компилируются, но тут нас ждёт страшный зверь под названием ADL.
Из-за ADL argument-dependent name lookup a.k.a. "Koenig lookup", поведение вполне нормальное.
С этой технологией, для lookup выбираются все namespace, которые перечислены в аргументах. Поэтому в данном случае мы рассмотрим только namespace x. Это сделано в основном для operator= и операторов сравнения, чтобы не надо было указывать namespace операторов, но к сожалению ведёт к достаточно сложным последствиям, если использование неправильно.
Задачи и тесты по программированию | proghub
Укажите performance проблему с этим кодом из представленных вариантов.
Anonymous Quiz
16%
push_back сделает копию возвращаемых значений. Надо использовать emplace_back
3%
Код содержит неопределенное поведение, так как ConvertData генерирует временный объект
24%
push_back сделает копию возвращаемых значений. Надо написать std::move(ConvertData(item))
39%
Размер вектора будет расти во время цикла, стоит сделать .reserve перед циклом
8%
Аргумент ConvertData будет скопирован при каждом вызове. Нужен аргумент, принимающий указатель
11%
Код оптимален, простых оптимизаций нет
👆Пояснение к предыдущему вопросу
👨🏻💻 В этом коде две проблемы -- первая, что в цикле
Во всём остальном оптимально. RVO (return value optimization) применяется во всех функциях, копирования при вызове Convert не происходит, а произойдёт просто навешивание ссылки.
👨🏻💻 В этом коде две проблемы -- первая, что в цикле
OtherData будет копироваться, лучше сделать const OtherData& item, вторая -- то, что вектор будет расти во время push_back и стоит сделать reserve перед, чтобы не было слишком много аллокаций. Поэтому надо было выбрать второй вариант, так как первый отсутствовал.Во всём остальном оптимально. RVO (return value optimization) применяется во всех функциях, копирования при вызове Convert не происходит, а произойдёт просто навешивание ссылки.
push_back создаст объект на месте, так как оно будет Rvalue.
Задачи и тесты по программированию | proghub👍1
👆Пояснение к предыдущему вопросу
👨🏻💻 Правильный ответ, что e будет являться временным объектом, так как итератор в std::map возвращает std::pair<const int, int>, поэтому произойдёт копирование пары, e будет временным объектом, который будет разрушаться и это является неопределённым поведением. См. value_type в https://en.cppreference.com/w/cpp/container/map
Все остальные ответы неправильные. const int* является константным по данным и присваивание корректно, если нет return statement из main, то оно по умолчанию ноль, а также main может быть без аргументов.
Задачи и тесты по программированию | proghub
👨🏻💻 Правильный ответ, что e будет являться временным объектом, так как итератор в std::map возвращает std::pair<const int, int>, поэтому произойдёт копирование пары, e будет временным объектом, который будет разрушаться и это является неопределённым поведением. См. value_type в https://en.cppreference.com/w/cpp/container/map
Все остальные ответы неправильные. const int* является константным по данным и присваивание корректно, если нет return statement из main, то оно по умолчанию ноль, а также main может быть без аргументов.
Задачи и тесты по программированию | proghub
👍1
Какой контейнер типа Container нельзя передавать в функцию EraseIf?
Anonymous Quiz
17%
std::unordered_set
10%
std::list
38%
все варианты верные
10%
std::map
14%
std::vector
10%
std::unordered_multimap
Что выведет программа?
Anonymous Quiz
34%
fg
8%
gf
12%
gg
8%
ff
26%
Неопределенное поведение
12%
Unspecified, то есть нельзя заключить из кода
Что выведет программа?
Anonymous Quiz
7%
неопределенное поведение
20%
d
20%
di
29%
i
11%
implementation defined
13%
не скомпилируется
Корректно ли функция посчитает и выведет что все элементы корректно обработаны?
Anonymous Quiz
32%
Нет, std::vector не гарантирует, что различные элементы не пересекаются по памяти
19%
Нет, successes каждый раз копируются в lambda, функция всегда вернёт false
24%
Нет, переменная i была захвачена по ссылке и будет изменяться, что приведет к UB
14%
Нет, функция имеет неопределенное поведение, так как std::all_of на пустом векторе не определена
11%
Да, всё корректно, различные элементы в векторе не пересекаются по памяти, data race не будет