调用Dice :: Dice(类构造函数)没有匹配函数

问题描述 投票:1回答:1

我正在创建一个骰子游戏。我正在构建文件,但得到以下错误:

没有用于调用Dice :: Dice的匹配函数

main.cpp中:

#include "Dice.h"
#include <iostream>
using namespace std;

int main (){
    Dice d(1,6);
    cout << d.getRoll() << endl;

    return 0;
}

Dice.h:

#ifndef DICE_H
#define DICE_H

class Dice
{
public:
    Dice();
    void getRoll(int m, int n);
};

#endif 

Dice.cpp:

#include "Dice.h"
#include <ctime>
#include <iostream>
using namespace std;

Dice::Dice()
{}

void Dice::getRoll(int m, int n) {
    srand(time(0));
    (rand() % n)+m;
}
c++
1个回答
3
投票

我看到代码有几个问题。这是我的修复和提示:

首先,你的Dice的构造和方法调用将无法编译:

Dice d(1,6);                  // you give arguments to the constructor
cout << d.getRoll() << endl;  // your method call has no arguments

但你定义了:

Dice();                       // constructor takes no arguments
void getRoll(int m, int n);   // method takes arguments

其次,srand只需要完成一次,而不是每次调用roll - 也许在主函数中:

srand( (unsigned)time( NULL ) );

这会使发生器播种,这样每次程序运行时都应该得到不同的随机数。在第一次掷骰子之前,只召唤一次。

第三,你的getRoll函数什么都不返回,这意味着你没有得到任何价值。您应该根据它们在现实或您的规范中表达的想法来命名变量:

int Dice::getRoll(int maxEyes) {     // Still no good abstraction
    (rand() % maxEyes) + 1;
}

真正的骰子不会在运行时更改其maxEyes。为什么不尝试一些面向对象而不是函数库类。想想一个真正的骰子对象!这是一个骰子抽象开始:

main.cpp中

#include "Dice.h"

#include <iostream>

using namespace std;

int main()
{
    Dice::randomize(); // Try commenting this out and run the program several times, check the result, then comment it back in

    Dice diceWith6Sides(6);
    cout << "The 6 sided dice rolls a " << diceWith6Sides.getRoll() << endl;
    cout << "The 6 sided dice rolls a " << diceWith6Sides.getRoll() << endl;
    cout << "The 6 sided dice rolls a " << diceWith6Sides.getRoll() << endl;

    Dice diceWith20Sides(20);
    cout << "The 20 sided dice rolls a " << diceWith20Sides.getRoll() << endl;
    cout << "The 20 sided dice rolls a " << diceWith20Sides.getRoll() << endl;
    cout << "The 20 sided dice rolls a " << diceWith20Sides.getRoll() << endl;
    return 0;
}

Dice.h

#ifndef DICE_H
#define DICE_H

class Dice
{
public:
    Dice(int sides);
    int getRoll();

    static void randomize(); // Call only once

private:
    int sides;
};

#endif

Dice.cpp

#include "Dice.h"

#include <time.h>
#include <stdlib.h>

Dice::Dice(int sides) :
    sides(sides)
{

}

int Dice::getRoll()
{
    return ((rand() % sides) + 1);
}

void Dice::randomize()
{
    srand((unsigned)time(NULL));
}

希望这是一个很好的起点。玩得很开心!

© www.soinside.com 2019 - 2024. All rights reserved.