- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个函数应该遍历 3 个字符串 vector 。我实现的线程函数是这样的:
#include<iostream>
#include<pthread.h>
#include<vector>
#include<string>
#include<fstream>
using namespace std;
int i_array1=-1,i_array2=0,i_array3=0;
int total_array1,total_array2,total_array3;
vector<string> array1;
vector<string> array2;
vector<string> array3;
pthread_mutex_t count;
void *dostuf(void *threadid) {
string u,p;
string i;
while(1){
pthread_mutex_lock(&count);
if(i_array1<total_array1-1){
i_array1++;
i=array1[i_array1];
u=array2[i_array2];
p=array3[i_array3];
}else{
i_array1=0;
i=array1[0];
if(i_array3<total_array3-1){
i_array3++;
p=array3[i_array3];
u=array2[i_array2];
}else{
i_array3=0;
if(i_array2<total_array2-1){
i_array2++;
p=array3[0];
u=array2[i_array2];
//cout<<u<<endl;
}else{
pthread_mutex_unlock(&count);
break;
}
}
}
cout<<i_array1<<" "<<i_array2<<" "<<i_array3<<endl;
pthread_mutex_unlock(&count);
}
}
int main(int argc, char *argv[]){
string x;
int rc,i;
pthread_t *threads;
int num_threads=2;
pthread_attr_t attr;
ifstream file1(argv[1]);
while(getline(file1,x)){
//cout<<(char*)line.c_str();
array1.push_back(x);
}
file1.close();
total_array1=array1.size();
ifstream file2(argv[2]);
while(getline(file2,x)){
//cout<<(char*)line.c_str();
array2.push_back(x);
}
file2.close();
total_array2=array2.size();
ifstream file3(argv[3]);
while(getline(file3,x)){
//cout<<(char*)line.c_str();
array3.push_back(x);
}
file3.close();
total_array3=array3.size();
cout<<total_array1<<" "<<total_array2<<" "<<total_array3<<endl<<endl;
threads=new pthread_t[num_threads];
pthread_attr_init(&attr);
pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE);
pthread_mutex_init(&count,PTHREAD_PROCESS_PRIVATE);
for( i = 0; i < num_threads; i++ ) {
// cout << "main() : creating thread, " << i << endl;
rc = pthread_create(&threads[i], NULL, dostuf, NULL);
if (rc) {
cout << "Error:unable to create thread," << rc << endl;
}
}
for( i = 0; i < num_threads; i++ ) {
rc = pthread_join(threads[i], NULL);
}
cout << "Main: program exiting." << endl;
pthread_exit(NULL);
return 0;
//
}
`
这个程序应该从参数中读取 3 个文件将行加载到 vector 中并按此顺序显示元素,为了跟踪我只打印索引而不是值:
例如,如果我输入一个包含 1000 行的文件作为 array1,1 行到 array2,1 行到 array3,程序将显示 2000 行。问题是当我将线程数从 1 增加到 2 时,在显示 3000 行的地方,使用相同的文件作为输入。每添加一个线程,输出的行数就会增加 1000。我怀疑 i_array2 在线程匆忙时的某个时刻没有增加,但我使用了一个初始化的互斥体,正如我在其他问题中看到的那样。还是我错过了一些简单的事情,我知道它的实现一团糟。
0 0 0
0 0 1
0 0 2
0 1 0
0 1 1
0 1 2
1 0 0
.....
谢谢!
编辑:我刚刚发现问题不在互斥体中,我测试了程序,只在互斥体锁定和解锁之间打印和 sleep ,似乎线程正在互相等待。因此,随着索引的增加,问题有些奇怪。我不明白那里出了什么问题。
最佳答案
这段代码是错误的:
pthread_mutex_init(&count,PTHREAD_PROCESS_PRIVATE);
正确使用 pthread_mutex_init()
,根据 t he POSIX documentation , 是
int pthread_mutex_init(pthread_mutex_t *restrict mutex,
const pthread_mutexattr_t *restrict attr);
在你的代码中,这将是
pthread_mutex_init(&count,&attr);
启用编译器警告并注意它们。
关于c++ - 多线程与 pthread 小问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49837472/
我正在将一些 pthreads 代码添加到我使用 autotools 构建的 Linux 应用程序中。我收到关于未在 libpthreads 中链接的错误。所以我想在 autotools 中指定 pt
libpthread 库位于 Linux 系统的哪个目录中? 最佳答案 有多种方法可以找出这一点。 只需输入 find / -name 'libpthread.so' -print找到名为 libpt
pthread 属性对象是否需要在使用它们的对象的生命周期内存在,或者在使用它们后立即销毁它们是否安全?例如: // Create the mutex attributes. pthread_mute
到目前为止我读过的所有文档似乎都表明我的 vxWorks (6.8) 版本中存在 posix 线程支持,但是一个简单的测试应用程序无法按预期执行。来源如下: tTest.h #include cla
我试图找到指定 pthreads 标准的文档。我见过各种指向 IEEE 1003.1c-1995 的链接(即 Wikipedia 或 OpenGroup )。然而,当我在 IEEE 标准站点上搜索此文
我试图找到指定 pthreads 标准的文档。我见过各种指向 IEEE 1003.1c-1995 的链接(即 Wikipedia 或 OpenGroup )。然而,当我在 IEEE 标准站点上搜索此文
我在 MSVC 2010 上运行一个 pthread,我已经包含 pthreadVC2 .lib & .dll。来自以下网站 http://sourceware.org/pthreads-win32/
我的问题是: 如何在不更改其他 pthread 中的当前目录的情况下更改 pthread 中的当前目录,我找到了一个使用 openat() 函数的解决方案,但我没有找到任何解释它如何工作的示例。 使用
是否可以通过任何方式更改进程可以创建的 pthread 数量限制? 目前在我的 linux 系统上我可以创建大约 380 个线程,但我想增加它,只要内存可用。 最佳答案 减少用户的堆栈大小' ulim
问候。我正在尝试创建一个 autoconf 配置脚本,该脚本自动检查要使用的 pthread 选项,并且理想情况下,在使用 gcc 编译时指定 -pthread。 我希望 AX_PTHREAD 能够工
如何知道 pthread 是否死亡? 有办法检查 pthread 状态吗? 最佳答案 if(pthread_kill(the_thread, 0) == 0) { /* still runni
我正在从一个由互斥锁控制的固定大小的全局池中分配我的 pthread 线程特定数据。 (有问题的代码不允许动态分配内存;它允许使用的所有内存都由调用者作为单个缓冲区提供。pthreads 可能会分配内
在阅读了一些 MPI 规范后,我了解到,当使用 MPI_THREAD_SERIALIZED 进行初始化时,程序必须确保发生在不同线程中的 MPI_Send/Recv 调用不能重叠。换句话说,您需要一个
我尝试根据 this guide 安装 pthread win32 . 我将 pthreadVC2.dll 文件添加到 C:\Windows 并将 pthreadVC2.lib 文件添加到 C:\Pr
我有一个 pthreads 程序。我必须使用 Linux 中的 gcc -pthread(-pthreads 是无法识别的选项)和 Sun 中的 gcc -pthreads(-pthread 是无法识
我有一个包含文件名列表的文件,我想在其中搜索一个词并替换它我稍微修改了代码只是为了在这里只显示相关部分问题是如果我在该列表中只有一个文件,它不会用多线程处理它,因为线程只有在我有多个文件时才工作所以我
我正在编写一个 SMT 程序,并且正在尝试解决一个有趣的问题。 我需要所有函数一起退出,但是有些线程卡在障碍物上,即使我不希望它们这样做。 我的问题是:当我删除障碍时会发生什么?卡在屏障处的线程会释放
我阅读了有关 pthread 及其相关 API 的所有内容,以创建、锁定和同步不同的线程。但我经常发现线程池、消费者/生产者等词提示。我理解这些是 pthread 实现的模型。 任何人都可以让我知道
我在 man pthread_join 中读到,多个 pthread 不能加入一个已经加入的 pthread。还有另一种方法可以达到相同的结果吗?多个 pthread 挂起自己,直到某个特定的 pth
我知道 OpenMP 实际上只是一组编译成 pthread 的宏。有没有办法在编译的其余部分发生之前查看 pthread 代码?我正在使用 GCC 进行编译。 最佳答案 首先,OpenMP 不是一组简
我是一名优秀的程序员,十分优秀!