仿函數和函數指針是兩種不同的東西,在 C++ 中可以用來做相似的事情,但也有一些區別。
仿函數是一種特殊的對象,它可以像函數一樣被調用,但是它帶有一些額外的狀態信息。例如,您可以寫一個仿函數來封裝一個算法,並在調用該算法時傳遞一些額外的參數。
函數指針是指向函數的指針。它可以用來做很多事情,例如在運行時選擇要調用的函數、將函數當作參數傳遞給其他函數、或者在某些情況下模擬函數重載。
在使用時,仿函數更加自然且易于理解,因為它們看起來像普通的函數,並且可以通過封裝複雜的算法來提高代碼的可讀性。相比之下,函數指針看起來有些麻煩,並且它們的使用有一定的限制。
因此,建議在可能的情況下使用仿函數,而在必須使用函數指針的情況下再考慮使用。
举两个例子 :
首先是仿函數的例子:
#include <iostream>
#include <algorithm>
#include <vector>
struct MyLess
{
bool operator()(int a, int b) const
{
return a < b;
}
};
int main()
{
std::vector<int> v = {3, 1, 4, 1, 5, 9};
std::sort(v.begin(), v.end(), MyLess());
for (int i : v)
std::cout << i << " ";
std::cout << std::endl;
return 0;
}
輸出:
1 1 3 4 5 9
接下來是函數指針的例子:
#include <iostream>
int add(int a, int b)
{
return a + b;
}
int subtract(int a, int b)
{
return a - b;
}
int multiply(int a, int b)
{
return a * b;
}
int do_math(int a, int b, int (*func)(int, int))
{
return func(a, b);
}
int main()
{
std::cout << do_math(5, 6, add) << std::endl;
std::cout << do_math(5, 6, subtract) << std::endl;
std::cout << do_math(5, 6, multiply) << std::endl;
return 0;
}
輸出:
11
-1
30
希望這些範例能幫助您理解仿函數和函數指針的使用。