コールバック関数

コールバック関数 組込みエンジニアとしての活動

はじめに

 コールバック関数って何?どんな時に使うの?それに答えようと思います。

コールバック関数とは

 コールバック関数とは、他の関数に引数として渡されその関数内で特定のタイミングで呼び出される関数です。これにより、非同期処理や特定のイベント発生時に実行されるコードを柔軟に制御できます。ここでは、コールバック関数の基本的な概念と具体的な使用例について説明します。

コールバック関数の基本

  • 定義: コールバック関数は、他の関数に引数として渡され、その関数内で呼び出される関数です。
  • 役割: 非同期処理特定のイベント発生時に実行されるコードを制御するために使用されます。

コールバック使用例

qsort関数での使用

qsort関数は、配列をソートするために使用されます。この関数では、比較関数をコールバック関数として渡します。

#include <stdio.h>
#include <stdlib.h>

// コールバック関数(比較関数)
int compare(const void *a, const void *b) {
int x = *(int*)a;
int y = *(int*)b;
if (x < y) return -1;
if (x > y) return 1;
return 0;
}

int main() {
int arr[] = {5, 2, 8, 1, 9};
int n = sizeof(arr) / sizeof(arr[0]);

// qsort関数にコールバック関数を渡す
qsort(arr, n, sizeof(int), compare);

for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");

return 0;
}

bsearch関数での使用

bsearch関数は、ソートされた配列内で特定の要素を検索するために使用されます。この関数でも比較関数をコールバック関数として渡します。

c#include <stdio.h>
#include <stdlib.h>

// コールバック関数(比較関数)
int compare(const void *a, const void *b) {
    int x = *(int*)a;
    int y = *(int*)b;
    if (x < y) return -1;
    if (x > y) return 1;
    return 0;
}

int main() {
    int arr[] = {1, 2, 5, 8, 9};
    int n = sizeof(arr) / sizeof(arr[0]);
    int target = 5;

    // bsearch関数にコールバック関数を渡す
    int *result = bsearch(&target, arr, n, sizeof(int), compare);

    if (result != NULL) {
        printf("Found %d\n", *result);
    } else {
        printf("Not found\n");
    }

    return 0;
}

 関数ポインタを使用したコールバック

関数ポインタを使用して、任意の関数をコールバックとして渡すことができます。

c#include <stdio.h>

// コールバック関数1
void callback1(char *s) {
    printf("%s\n", s);
}

// コールバック関数2
void callback2(char *s) {
    printf("[%s]\n", s);
}

// コールバック関数を呼び出す関数
void func(char *s, void (*p)(char *)) {
    p(s);
}

int main() {
    // コールバック関数1を呼び出す
    func("Callback1", callback1);

    // コールバック関数2を呼び出す
    func("Callback2", callback2);

    return 0;
}

コールバック関数の利点

  • 柔軟性: 非同期処理やイベントハンドリングにおいて、コードの実行順序を柔軟に制御できます。
  • 再利用性: コールバック関数は再利用可能であり、異なる状況で同じ関数を使用できます。

コールバック関数は、特に非同期処理やイベント駆動のプログラミングにおいて非常に重要な役割を果たします。ただし、ネストが深くなることがあるため、コードの可読性を保つために注意が必要です。

まとめ

 コールバック関数について記述しました。書いてみるとそんなに難しくないですね。小さい積み重ねでなので大切ですね。次回もお楽しみに


コメント

タイトルとURLをコピーしました