Ir ao conteúdo
  • Cadastre-se

C++ passar um vetor como parâmetro pra minha thread


Posts recomendados

#include <iostream>
#include <thread>
#include <stdio.h>

using namespace std;


void Matriz(int **);


int main()
{

     int nLinha = 0, nColuna = 0;
     std::cout << "Tamanho da Linha: ";
     std::cin >> nLinha;
     std::cout << "\nTamanho da coluna";
     std::cin >> nColuna;
     int a[nLinha][nColuna];


    std::thread pri(&Matriz, a);
    pri.join();

}
void Matriz(int **a){


}

Alguém sabe porque não consigo passar um vetor como parâmetro pra minha thread , ta

aparecendo esse erro ' : no matching function for call to 'std::thread::thread(void (*)(int**), int [nLinha][nColuna])'| 

 c;

Link para o comentário
Compartilhar em outros sites

37 minutos atrás, Korean Sabino disse:

Não entendi, como assim? a função ta declarada na thread.

 

Me expressei muito mal na pressa. É que a função está sem corpo. Mas o problema não é esse.

 

O erro nada em a ver com thread. Apenas o argumento esta errado.

 

Não precisa do & antes de Matriz. Ele é implícito porque matriz foi declarada como função. Mas acho que não faz mal. Seria como declarar 

    std::thread pri(&*&*&Matriz, a);

Mas declarou 

    void Matriz(int**);

e declarou 

    int a[nLinha][nColuna];

Isso não combina... int[][] não é int ** e aí o compilador vai reclamar mesmo.

 

Mais

    std::cout << "Tamanho da Linha: ";
    std::cin >> nLinha;
    std::cout << "\nTamanho da coluna";
    std::cin >> nColuna;
    int a[nLinha][nColuna];


Não funciona. nLinha e nColuna tem que ser constantes. Não pode ler os valores na hora. Para ler os valores na hora use new e delete. 

  

 

Link para o comentário
Compartilhar em outros sites

Em 07/04/2020 às 20:37, arfneto disse:

o argumento esta errado

 

Em 07/04/2020 às 20:37, arfneto disse:

Não precisa do & antes de Matriz

 

Em 07/04/2020 às 20:37, arfneto disse:

int[][] não é int **

 

Em 07/04/2020 às 20:37, arfneto disse:

nLinha e nColuna tem que ser constantes

 

1 hora atrás, Korean Sabino disse:

você disse disse e n deu resolução nenhuma...seja mais claro

 

Isso não está claro? (1) o argumento está errado (2) não precisa do & (3) int** não é int[][] (4) nLinha e nColuna tem que ser constantes. Onde está obscuro isso?

 

E isso lado a lado?

image.png.8f1658b9eea87f8843aa55348e44f8fb.png

 

Não deu pra ver que o argumento fornecido não corresponde à declaração? 

Por outro lado, fiquei curioso com sua intenção nesse programa. Declarar um único thread e chamar join() em seguida quer dizer o seguinte: seu programa vai parar. E a execução do thread continua. E aí quando ele acabar seu programa continua. Isso é join(). Então não vai fazer nada exceto transferir a execução para a função matriz() e depois continuar em seu programa. 
 

Será que você não pretendia usar start()?

 

Acho que você quer algo bem prontinho né?
 

Esse resultado 

Linhas: 2
Colunas: 5

Matriz em main()
   0    1    2    3    4
   5    6    7    8    9

Hello from Matriz[2x5]
   0    1    2    3    4
   5    6    7    8    9


Corresponde ao programa abaixo. Essa é a maneira comum de passar isso
 

#include <iomanip>
#include <iostream>
#include <stdio.h>
#include <thread>

using namespace std;


void Matriz(int*,unsigned const, unsigned const);


int main()
{
    int nLinha = 2;
    int nColuna = 4;

    std::cout << "Linhas: ";
    std::cin >> nLinha;

    std::cout << "Colunas: ";
    std::cin >> nColuna;

    int* a = new int[nLinha * nColuna * sizeof(int)];
    
    // colocando valores conhecidos na matriz
    int ix = 0;
    for (auto i = 0; i < nLinha; i += 1)
    {
        for (auto j = 0; j < nColuna; j += 1)
        {
            ix = i * nColuna + j;
            *(a + ix) = ix;
        };  // for
    };  // for

    // mostra aqui
    cout << "\nMatriz em main()" << endl;

    for (auto i = 0; i < nLinha; i += 1)
    {
        for (auto j = 0; j < nColuna; j += 1)
        {
            cout << setw(4) << *(a+ i*nColuna + j) << " ";
        };  // for
        cout << endl;
    };  // for

    std::thread pri(Matriz, a, nLinha, nColuna);
    pri.join();

    delete [] a;
}
void Matriz(int* m,  unsigned const l, unsigned const c)
{
    cout << "\nHello from Matriz[" <<
        l << "x" << c << "]" << endl;
    // mostra la
    for (auto i = 0; i < l; i += 1)
    {
        for (auto j = 0; j < c; j += 1)
        {
            cout << setw(4) << *(m + i * c + j) << " ";
        };  // for
        cout << endl;
    };  // for

    return;
}

Veja se ficou mais claro agora e volte a escrever com a versão atual de seu código.

 

Link para o comentário
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisa ser um usuário para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar agora

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...