我正在寫一個程序,用於生成模擬讀寫器問題的線程數量。一些線程被分配給讀取器的任務,其中一些是寫入器線程。標記數組保持爲確保爲每個循環迭代分配不同的寫入器線程。 RW是我爲讀寫操作編寫的類。程序工作正常,直到循環的第一次迭代結束時爲止。但在並行段程序結束時掛起。openmp程序掛在塊的末尾
#include<iostream>
#include<fstream>
#include<omp.h>
using namespace std;
class RW
{
string text,dsp,path;
fstream f,r;
public: RW(string p)
{
path=p;
}
public: void reader()
{
//cout<<"in reader\n";
{
r.open(path.c_str(),ios::in);
r>>dsp;
cout<<dsp<<endl;
r.close();
}
}
public: void writer()
{
f.open(path.c_str(),ios::out);
cout<<"Enter text to be written: ";
cin>>text;
cout<<endl;
f<<text;
//cout<<"end -- write \n";
f.close();
}
};
int main()
{
omp_lock_t lk;
omp_init_lock(&lk);
int flag[10];
RW rw("a.txt");
string dsp;
int th_no,no_th;
int wn,rn;
cout<<"Enter no of writer threads: ";
cin>>wn;
cout<<"\nEnter no of reader threads: ";
cin>>rn;
for(int i=0;i<10;i++){flag[i]=0;}
//omp_set_nested(1);
for(int i=0;i<wn;i++)
{
cout<<i<<": loop"<<endl;
#pragma omp parallel default(shared) private(th_no) num_threads(wn+rn)
{
th_no = omp_get_thread_num();
cout<<omp_get_thread_num()<<endl;
#pragma omp barrier
if(th_no<wn && flag[th_no]==0)
{
#pragma omp sections
{
#pragma omp section
{
cout<<"thread no: "<<omp_get_thread_num()<<endl;
omp_set_lock(&lk);
rw.writer();
flag[omp_get_thread_num()]=1;
omp_unset_lock(&lk);
}
}
}
#pragma omp barrier
if(omp_get_thread_num()>=wn)
{
omp_set_lock(&lk);
cout<<"thread no:"<<omp_get_thread_num()<<endl;
rw.reader();
omp_unset_lock(&lk);
}
#pragma omp barrier
#pragma omp flush
th_no=0;
}
}
return 0;
}
請不要把'public:'放在一切之前。這不是常見的做法,也不是C#或Java。 – DeiDei
我是剛剛開始編碼的新手,但我會記住這一點,thanx –