#include <iostream>
#include <mutex>
#include <vector>
class ConcurrentArray {
private:
std::vector<int> data;
std::mutex mutex;
public:
ConcurrentArray(int size) : data(size) {}
int& operator[](int index) {
std::lock_guard<std::mutex> lock(mutex);
return data[index];
}
void print() {
std::lock_guard<std::mutex> lock(mutex);
for (int i = 0; i < data.size(); i++) {
std::cout << data[i] << " ";
}
std::cout << std::endl;
}
void resize(int newSize) {
std::lock_guard<std::mutex> lock(mutex);
data.resize(newSize);
}
};
int main() {
ConcurrentArray arr(5);
arr[0] = 1;
arr[1] = 2;
arr[2] = 3;
arr.print();
arr.resize(10);
arr[5] = 5;
arr[6] = 6;
arr[7] = 7;
arr.print();
return 0;
}
这个ConcurrentArray
类使用std::mutex
来保护对数组的并发读写操作,确保在同一时间只有一个线程可以访问数组。通过重载operator[]
来提供对数组元素的访问,并且提供print()
和resize()
方法来打印数组内容和调整数组大小。在main()
函数中展示了如何使用ConcurrentArray
类进行并发读写操作。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。