web-dev-qa-db-ja.com

非メンバー関数での「this」の無効な使用

私はクラスで作業していて、すべてを同じ.cppファイルに書き始めました。しかし、しばらくするとクラスがどんどん大きくなっていくのが見えたので、.hファイルと.cppファイルに分割することにしました。

gaussian.hファイル:

class Gaussian{
    private:
        double mean;
        double standardDeviation;
        double variance;
        double precision;
        double precisionMean;
    public:
        Gaussian(double, double);
        ~Gaussian();
        double normalizationConstant(double);
        Gaussian fromPrecisionMean(double, double);
        Gaussian operator * (Gaussian);
        double absoluteDifference (Gaussian);
};

gaussian.cppファイル:

#include "gaussian.h"
#include <math.h>
#include "constants.h"
#include <stdlib.h>
#include <iostream>

Gaussian::Gaussian(double mean, double standardDeviation){
    this->mean = mean;
    this->standardDeviation = standardDeviation;
    this->variance = sqrt(standardDeviation);
    this->precision = 1.0/variance;
    this->precisionMean = precision*mean;
} 

//Code for the rest of the functions...

double absoluteDifference (Gaussian aux){
    double absolute = abs(this->precisionMean - aux.precisionMean);
    double square = abs(this->precision - aux.precision);
    if (absolute > square)
        return absolute;
    else
        return square;
}

しかし、これをコンパイルすることはできません。実行してみます:

g++ -I. -c -w gaussian.cpp

しかし、私は得ます:

gaussian.cpp: In function ‘double absoluteDifference(Gaussian)’:
gaussian.cpp:37:27: error: invalid use of ‘this’ in non-member function
gaussian.h:7:16: error: ‘double Gaussian::precisionMean’ is private
gaussian.cpp:37:53: error: within this context
gaussian.cpp:38:25: error: invalid use of ‘this’ in non-member function
gaussian.h:6:16: error: ‘double Gaussian::precision’ is private
gaussian.cpp:38:47: error: within this context

なんで使えないの? fromPrecisionMean関数で使用しており、コンパイルされます。その関数がガウス関数を返すからですか?追加の説明は本当にありがたいです、私はできる限り多くを学ぼうとしています!ありがとう!

12
coconut

absoluteDifferenceクラスの一部としてGaussianを宣言するのを忘れました。

変化する:

double absoluteDifference (Gaussian aux){

これに:

double Gaussian::absoluteDifference (Gaussian aux){

サイドノート:値ではなく参照で渡す方が良い場合があります:

double Gaussian::absoluteDifference (const Gaussian &aux){
26
Mysticial