官术网_书友最值得收藏!

Functions as types

The second argument for unordered_map is int (*)(int, int), which literally means a pointer to a function taking two integers and returning an integer. C++ supports the class template std::function as a general-purpose function wrapper allowing us to store callable objects including ordinary functions, lambda expressions, functions objects, and so on. The stored object is referred to as the target of std::function and if it doesn't have a target, it will throw the std::bad_function_call exception if invoked. This helps us both to make the operations hash table accept any callable object as its second parameter and to handle exceptional cases such as invalid character input, mentioned earlier.

The following code block illustrates this:

#include <functional>
#include <unordered_map>
// add, subtract, multiply and divide declarations omitted for brevity
int main() {
std::unordered_map<char, std::function<int(int, int)> > operations;
operations['+'] = &add;
// ...
}

Notice the argument for std::function; it has the form int(int, int) rather than int(*)(int, int). Using std::function helps us to handle exceptional situations. For example, calling operations['x'](num1, num2); will lead to, creation of the empty std::function mapped to the character x.

And calling it will throw an exception, so we can ensure the safety of the code by properly handling the call:

// code omitted for brevity
std::cin >> num1 >> num2 >> op;
try {
operations[op](num1, num2);
} catch (std::bad_function_call e) {
// handle the exception
std::cout << "Invalid operation";
}

Finally, we can use lambda expressions— unnamed functions constructed in place and able to capture variables in scope. For example, instead of declaring the preceding functions and then inserting them into the hash table, we can create a lambda expression right before inserting it into the hash table:

std::unordered_map<char, std::function<int(int, int)> > operations;
operations['+'] = [](int a, int b) { return a + b; }
operations['-'] = [](int a, int b) { return a * b; }
// ...
std::cin >> num1 >> num2 >> op;
try {
operations[op](num1, num2);
} catch (std::bad_functional_call e) {
// ...
}

Lambda expressions will be covered throughout the book.

主站蜘蛛池模板: 镇平县| 息烽县| 菏泽市| 达尔| 福鼎市| 靖边县| 盈江县| 南溪县| 定西市| 盐亭县| 清远市| 饶平县| 涡阳县| 夏津县| 鄂伦春自治旗| 元朗区| 个旧市| 松溪县| 彰化市| 长乐市| 勃利县| 黑河市| 黄石市| 大冶市| 大足县| 内江市| 电白县| 凯里市| 河北区| 额敏县| 沽源县| 慈溪市| 稷山县| 宝鸡市| 罗定市| 孟村| 合水县| 德清县| 城市| 景泰县| 朝阳县|