gpt4 book ai didi

c++ - 分配给类中函数指针的函数

转载 作者:塔克拉玛干 更新时间:2023-11-03 07:30:36 25 4
gpt4 key购买 nike

<分区>

我有一个处理多项式运算的程序。一个“运算符”类有一个指向输入字符串的字符指针,一个指向用于对参数执行操作的浮点(float, float)类型函数的指针。然后是一系列方法,setSymb(char *) 将opChar指向参数,将opFunc指针指向运算符字符对应的函数。但是,当我运行此方法时,在将函数分配给指针函数的那一行,当它尝试分配某种内存时,new.cpp 下出现未处理的异常。这让我很困惑。

#include "stckArrClassLib.h"
using namespace stacks;
using namespace conversion;

#define SIDE bool
#define LEFT 0
#define RIGHT 1

class oprt
{
public:
typedef float (oprt::*fp)(float, float);
private:
char *opSymb;
fp opFunc;
float *lOpnd;
float *rOpnd;
oprt *Lnext;
oprt *Rnext;
float rslt;
protected:
float add(float a, float b){return a+b;};
float mult(float a, float b){return a*b;};
float div(float a, float b){return a/b;};
float exp(float a, float b){return powf(a, b);};
float par(float a, float b){return a;};
public:
oprt (void) {opFunc=NULL;};
oprt &setSymb(char *);
oprt &setNext(SIDE, oprt *);
oprt &setOpnd(SIDE, float);
float evaluate();
char *getSymb();
fp getFunc();
float *getOpnd(SIDE);
oprt *getNext(SIDE);
};

oprt& oprt::setSymb(char *set)
{
CArray<char, 8> opStr;
opStr[0]=*(set), set;
int i;
for(i=1; i<7 && (!(set[i]>='0' && set[i]<='9') && !(set[i]=='+' || set[i]=='-' || opStr[i]=='*' || set[i]=='/' || set[i]=='^' || set[i]=='(')); i++)
opStr[i]=set[i];
opStr[i]=0;
if(strcmp((const char *)opStr.arr, "+")==0)
//problem is here
opFunc=&oprt::add;
else if(strcmp((const char *)opStr.arr, "*")==0)
//and here
opFunc=&oprt::mult;
else if(strcmp((const char *)opStr.arr, "/")==0)
//etc.
opFunc=&oprt::div;
else if(strcmp((const char *)opStr.arr, "^")==0)
opFunc=&oprt::exp;
else if(strcmp((const char *)opStr.arr, "(")==0 || strcmp((const char *)opStr.arr, ")")==0)
opFunc=&oprt::par;
return *this;
}

oprt& oprt::setNext(SIDE side, oprt *next)
{
if(side==LEFT)
{
Lnext=next;
lOpnd=&(next->rslt);
}
else if(side==RIGHT)
{
Rnext=next;
rOpnd=&(next->rslt);
}
return *this;
}

float oprt::evaluate()
{
return rslt=(this->*opFunc)(*getOpnd(LEFT), *getOpnd(RIGHT));
}

char *oprt::getSymb()
{
return opSymb;
}

oprt::fp oprt::getFunc()
{
return opFunc;
}

float *oprt::getOpnd(SIDE side)
{
if(!((side==LEFT)? (Lnext==this):(Rnext==this)))
(side==LEFT? Lnext:Rnext)->evaluate();
return (side==LEFT)? (lOpnd):(rOpnd);
}

oprt *oprt::getNext(SIDE side)
{
return (side==LEFT)? (Lnext):(Rnext);
}

oprt& oprt::setOpnd(SIDE side, float set)
{
(side==LEFT)? (*lOpnd=set):(*rOpnd=set);
return *this;
}

这是在 opFunc=&oprt::add 调用的 new.cpp 的摘录在函数中 oprt& oprt::setSymb(char *)

extern "C" void * __cdecl _nh_malloc_dbg (
size_t nSize,
int nhFlag,
int nBlockUse,
const char * szFileName,
int nLine
)
{
int errno_tmp = 0;
void * pvBlk = _nh_malloc_dbg_impl(nSize, nhFlag, nBlockUse, szFileName, nLine, &errno_tmp);

if ( pvBlk == NULL && errno_tmp != 0 && _errno())
{
errno = errno_tmp; // recall, #define errno *_errno()
}
return pvBlk;
}

调用malloc时报错

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com