C 中的回呼函數
何時以及如何使用回呼函數:
函數是作為參數傳遞給另一個函數的函數指標或物件。然後在被呼叫函數中呼叫這些回調函數,以根據提供的回調邏輯自訂其行為。
使用回調函數的常見場景:
C 中 Callable 的類型(11):
回呼功能可以使用多種類型的可調用物件來實現,包括:
寫回調:
編寫回呼類型的語法會因所使用的可呼叫類型而異。以下是概述:
1。函數指標:
typedef int (*f_int_t)(int); int (* foo_p)(int);
2.指向成員函數的指標:
typedef int (C::* f_C_int_t)(int); int (C::* C_foo_p)(int);
3. std:::
std::function<int(int)> stdf_foo = &foo; std::function<int(const C&, int)> stdf_C_foo = &C::foo;
4。模板化回呼類型:
template<class R, class T> void stdf_transform_every_int_templ(int * v, unsigned const n, std::function<R(T)> fp)
呼叫回調:
呼叫回調的語法會根據可呼叫類型的不同而有所不同。以下是概述:
1。函數指標:
int b = foobar(a, foo);
2.指向成員函數的指標:
int b = C_foobar(a, my_c, &C::foo);
3. std:::
int b = stdf_foobar(a, stdf_foo);
4。模板化回呼類型:
stdf_transform_every_int_templ(&a[0], 5, &foo);
範例:
考慮以下使用回呼轉換數組中每個整數的函數範例:
void tranform_every_int(int * v, unsigned n, int (*fp)(int)) { for (unsigned i = 0; i < n; ++i) { v[i] = fp(v[i]); } }
該函數可以與不同的回調函數配合使用,實現不同的功能行為:
// Using a function pointer int double_int(int x) { return 2*x; } int a[5] = {1, 2, 3, 4, 5}; tranform_every_int(&a[0], 5, double_int); // Transform the array using the double_int callback // Using lambda expression tranform_every_int(&a[0], 5, [](int x) -> int { return x/2; }); // Transform the array using an anonymous function that divides each element by 2 // Using std::bind int nine_x_and_y (int x, int y) { return 9*x + y; } std::placeholders::_1; tranform_every_int(&a[0], 5, std::bind(nine_x_and_y, _1, 4)); // Transform the array using std::bind with nine_x_and_y
總之,回調函數提供了一種強大而靈活的機制,用於自定義函數的行為並在C 中啟用動態執行時間行為。它們可以使用各種可調用函數來實現,並且它們的語法也相應不同。
以上是我應該何時以及如何使用 C 中的回呼函數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!