そのクラスのオブジェクトのアドレスを保持するポインター配列を作成したいので、スキャナー関数を呼び出すと、pcodeが読み取られ、オブジェクトの検索で同じpcodeが使用されます。配列が間違っていると宣言していますか?または私は静的な概念を誤解しましたか?または、他の何か ?
とにかく私はコード全体を投稿する必要があると思います
#include <string>
using namespace std;
class product{
public:
product();
product(long&,string&);
void setCode();
void getCode(long);
void static scanner();
void const printer();
static product *point[3];
static int a;
private:
string pname;
long pcode;
};/*
class PrepackedFood:public product{
public:
PrepackedFood(long&, string&,double);
private:
double uPrice;
};
class FreshFood:public product{
public:
FreshFood(long&,string&,double,double);
private:
double weight;
double pricepk;
};*/
#include "product.h"
#include <iostream>
product::product(){pcode=0;pname="unknown";
point[a]= this;
a++;}
product::product(long& c,string&n){pcode=c;pname=n;
}
//void const product::printer(){cout<<getCode()}
void product::setCode(){ cout<<"enter product name\n ";cin>>pname;
cout<<"enter product code _____\b\b\b\b\b";cout<<"\a";
cin>>pcode;cout<<endl;
cout<<pname<<endl;
cout<<pcode<<endl;
}
void product::getCode(long s){
if ((*this).pcode=s){
printer();
}
}
void product::scanner(){
long a;
cout<<"SCANNING!\a_____\b\b\b\b\b";cin>>a;
int i=0;
while(i<3){
if (point[i]->pcode==a){point[i]->printer();
break;
}
i++;
//(i==3)?cout<<"try again\n":"\a";
}
}
void const product::printer(){
cout<<pname<<endl;
cout<<pcode<<endl;
}
#include "product.h"
int main(){
product a[3];
int i=0;
while(i<3){
a[i].setCode();
i++;
}
product::scanner();
return 0;
}
私はそれがもっと簡単にできることを知っています。私はただ学んでいるので、スキャナー機能を修正したいだけです。コンパイルされません
1> product.obj:エラーLNK2001:未解決の外部シンボル "public:static class product * * product :: point"(?point @ product @@ 2PAPAV1 @ A)1> product.obj:エラーLNK2001:未解決の外部シンボル "public :static int product :: a "(?a @ product @@ 2HA)