Что выведет программа?
Anonymous Quiz
4%
A
15%
B
42%
AB
13%
BA
25%
Не скомпилируется
2%
Неопределенное поведение
Что напечатает программа?
Anonymous Quiz
22%
1
12%
12
10%
2
14%
21
36%
Не скомпилируется
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 генерирует временный объект
22%
push_back сделает копию возвращаемых значений. Надо написать std::move(ConvertData(item))
41%
Размер вектора будет расти во время цикла, стоит сделать .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
18%
std::unordered_set
11%
std::list
39%
все варианты верные
7%
std::map
14%
std::vector
11%
std::unordered_multimap
Что выведет программа?
Anonymous Quiz
35%
fg
6%
gf
12%
gg
8%
ff
27%
Неопределенное поведение
12%
Unspecified, то есть нельзя заключить из кода
Что выведет программа?
Anonymous Quiz
7%
неопределенное поведение
20%
d
18%
di
30%
i
11%
implementation defined
14%
не скомпилируется
Корректно ли функция посчитает и выведет что все элементы корректно обработаны?
Anonymous Quiz
33%
Нет, std::vector не гарантирует, что различные элементы не пересекаются по памяти
19%
Нет, successes каждый раз копируются в lambda, функция всегда вернёт false
22%
Нет, переменная i была захвачена по ссылке и будет изменяться, что приведет к UB
14%
Нет, функция имеет неопределенное поведение, так как std::all_of на пустом векторе не определена
11%
Да, всё корректно, различные элементы в векторе не пересекаются по памяти, data race не будет