C語言本身并不直接支持并發控制,但可以通過一些間接的方法來實現。在C語言中,可以使用多線程(如POSIX線程庫)或操作系統提供的進程管理功能來實現并發。在這些情況下,就需要進行并發控制,以確保數據的一致性和完整性。
并發控制通常涉及到同步和互斥的問題。同步是指多個線程或進程按照某種順序執行,而互斥是指一次只能有一個線程或進程訪問共享資源。常見的并發控制手段包括信號量、互斥鎖、條件變量等。
在C語言中,可以使用POSIX線程庫提供的互斥鎖(pthread_mutex_t)來實現互斥控制。例如,以下代碼展示了如何使用互斥鎖來保護共享變量:
#include <pthread.h>
#include <stdio.h>
pthread_mutex_t lock;
int shared_data = 0;
void* thread_func(void* arg) {
for (int i = 0; i < 100000; ++i) {
pthread_mutex_lock(&lock);
++shared_data;
pthread_mutex_unlock(&lock);
}
return NULL;
}
int main() {
pthread_t threads[4];
for (int i = 0; i < 4; ++i) {
pthread_create(&threads[i], NULL, thread_func, NULL);
}
for (int i = 0; i < 4; ++i) {
pthread_join(threads[i], NULL);
}
printf("Shared data: %d\n", shared_data);
return 0;
}
在這個例子中,我們使用互斥鎖來保護對共享變量shared_data
的訪問,確保每次只有一個線程可以對其進行修改。這樣就可以避免并發訪問導致的數據不一致問題。