Ось приклад, що демонструє нетипове використання змінної, оголошеної в умові if .
Тип змінної - int &
це як конвертована булева, так і придатна для використання у тодішніх та інших гілках.
#include <string>
#include <map>
#include <vector>
using namespace std;
vector<string> names {"john", "john", "jack", "john", "jack"};
names.push_back("bill");
map<string, int> ages;
int babies = 0;
for (const auto & name : names) {
if (int & age = ages[name]) {
cout << name << " is already " << age++ << " year-old" << endl;
} else {
cout << name << " was just born as baby #" << ++babies << endl;
++age;
}
}
вихід є
john was just born as baby #1
john is already 1 year-old
jack was just born as baby #2
john is already 2 year-old
jack is already 1 year-old
bill was just born as baby #3
На жаль, змінна в умові може бути оголошена лише із синтаксисом декларації '='.
Це виключає інші, можливо, корисні випадки типів з явним конструктором.
Наприклад, наступний приклад використання std::ifstream
компіляції не буде ...
if (std::ifstream is ("c:/tmp/input1.txt")) {
std::cout << "true: " << is.rdbuf();
} else {
is.open("c:/tmp/input2.txt");
std::cout << "false: " << is.rdbuf();
}
Відредаговано в січні 2019 року ... тепер ви можете наслідувати те, що, як я пояснив, неможливо зробити ...
Це працює для рухомих класів, таких як ifstream в C ++ 11, і навіть для непридатних для копіювання класів, починаючи з C ++ 17 з копією elision.
Відредаговано в травні 2019: використовуйте авто для полегшення багатослівності
{
if (auto is = std::ifstream ("missing.txt")) {
std::cout << "true: " << is.rdbuf();
} else {
is.open("main.cpp");
std::cout << "false: " << is.rdbuf();
}
}
struct NoCpy {
int i;
int j;
NoCpy(int ii = 0, int jj = 0) : i (ii), j (jj) {}
NoCpy(NoCpy&) = delete;
NoCpy(NoCpy&&) = delete;
operator bool() const {return i == j;}
friend std::ostream & operator << (std::ostream & os, const NoCpy & x) {
return os << "(" << x.i << ", " << x.j << ")";
}
};
{
auto x = NoCpy();
if (auto nocpy = NoCpy (7, 8)) {
std::cout << "true: " << nocpy << std::endl;
} else {
std::cout << "false: " << nocpy << std::endl;
}
}