C++函數(shù)對(duì)象(也稱為仿函數(shù)或functor)在STL(Standard Template Library)中有廣泛的應(yīng)用
std::sort
、std::find_if
和std::transform
等算法都接受函數(shù)對(duì)象作為參數(shù)。std::vector<int> vec = {3, 1, 4, 1, 5, 9};
std::sort(vec.begin(), vec.end(), std::greater<int>()); // 使用greater<int>()函數(shù)對(duì)象對(duì)向量進(jìn)行降序排序
std::map
和std::set
)需要比較元素以確定它們的順序。通過(guò)使用自定義函數(shù)對(duì)象,可以為這些容器提供不同的比較方式。std::map<std::string, int, std::greater<std::string>> my_map; // 使用greater<std::string>()函數(shù)對(duì)象創(chuàng)建一個(gè)降序的字符串映射
std::bind
、std::mem_fn
和std::function
等,它們可以將函數(shù)、成員函數(shù)指針或Lambda表達(dá)式轉(zhuǎn)換為函數(shù)對(duì)象。這些適配器在需要將函數(shù)作為參數(shù)傳遞給STL算法時(shí)非常有用。auto add = [](int a, int b) { return a + b; };
std::vector<int> vec = {1, 2, 3, 4, 5};
std::transform(vec.begin(), vec.end(), vec.begin(), add); // 使用Lambda表達(dá)式作為函數(shù)對(duì)象對(duì)向量中的每個(gè)元素進(jìn)行加法操作
class MyCounter {
public:
int count = 0;
void increment() { ++count; }
};
std::vector<int> vec = {1, 2, 3, 4, 5};
MyCounter counter;
std::for_each(vec.begin(), vec.end(), [&counter](int) { counter.increment(); }); // 使用包含狀態(tài)信息的函數(shù)對(duì)象對(duì)向量中的每個(gè)元素進(jìn)行操作
總之,C++函數(shù)對(duì)象在STL中的應(yīng)用非常廣泛,它們提供了一種靈活且高效的方式來(lái)處理各種問(wèn)題。通過(guò)使用函數(shù)對(duì)象,可以根據(jù)不同的需求定制算法的行為,從而提高代碼的可讀性和可維護(hù)性。