在C ++中将变量的名称转换为字符串?

时间:2012-11-18 02:54:27

标签: c++

主要功能

main(){

    foo x=1, y=1, z=1;

}

头/类

class foo{

public:
    double a, b, c;
    double fn, val;

    // set a,b, and c
    void set(){
        a=1;
        b=1;
        c=1;
    }

    // constructor
    foo(double &f){
        set();

        // what I want to do here is say if "name of variable f" = "x", then do something
        // else if "name of variable f" = "y", do something else
        // else if "name of variable f" = "z", do something else
    }
};

正如您在main函数中看到的,x,y和z都具有相同的值。我正在尝试编写一个处理这种情况的条件,并且我想出了一种检查变量名称的方法。因为我总是想为名为“x”的类foo的对象做同样的事情,并且总是对“y”执行相同的操作,依此类推,无论这些值是什么。

3 个答案:

答案 0 :(得分:1)

你不能在你的问题中做你想要的,有几种方法可以做类似的事情。

您可以使用继承。

class foo{

public:
    double a, b, c;
    double fn, val;

    // set a,b, and c
    void set(){
        a=1;
        b=1;
        c=1;
    }

    // constructor
    foo(double &f){
        set();
    }
};

class X : public foo {
{
public:
    X (double &f) : foo(f) {
        // do stuff for x
    }
};

class Y : public foo {
{
public:
    Y (double &f) : foo(f) {
        // do stuff for y
    }
};

class Z : public foo {
{
public:
    Z (double &f) : foo(f) {
        // do stuff for z
    }
};

main(){

    X x=1;Y y=1;Z z=1;

}

或者您可以使用枚举

class foo{
public:
    enum Mode{
        Mode_X,
        Mode_Y,
        Mode_Z
    };
    Mode mode;

    double a, b, c;
    double fn, val;

    // set a,b, and c
    void set(){
        a=1;
        b=1;
        c=1;
    }

    foo(Mode m, double &f) : mode(m) {
        set();

        switch(mode) {
        case Mode_X:
            // what I want to do here is say if "name of variable f" = "x", then do something
            break;
        case Mode_Y:
            // else if "name of variable f" = "y", do something else
            break;

        case Mode_Z:
            // else if "name of variable f" = "z", do something else
            break;
        }
    }
};

main(){

    foo x(foo::Mode_X,1), y(foo::Mode_Y,1), z(foo::Mode_Z,1);

}

您可以使用带有枚举版本的预处理器来使变量声明更接近您最初的要求,如下所示:

#define X(value) x(foo::Mode_X,(value))
#define Y(value) y(foo::Mode_Y,(value))
#define Z(value) z(foo::Mode_Z,(value))

main(){
    foo X(1), Y(1), Z(1);
}

许多人,包括我自己,会建议不要像这样使用预处理器。我只是说这是可能的。

答案 1 :(得分:0)

您尝试做的事情称为反射(Wikipedia)。由于C ++是一种编译的非托管语言,因此它不支持反射。

此外,当代码是用C ++编译的时候,编译器mangles the variable names所以你认为你创建的变量(x,y,z)并没有按你认为的那样和新的名称命名。名字毫无意义。

不幸的是,当您通过检查变量名称来尝试完成时,无法在C ++中完成。

答案 2 :(得分:0)

你在评论中提到你正在编写一个类来进行部分区分。这是一个建议的起点:

class Differentiator{
public:
    double a, b, c;
    double fn, val;
    void differentiateByX(double &f);
    void differentiateByY(double &f);
    void differentiateByZ(double &f);

    Differentiator(): a(1), b(1), c(1)
    {} // Note the syntax above for initializing members.
};

如果看起来有用,请随意更改差异功能的返回类型,或添加成员以便您可以

main(){
    Differentiator foo;
    foo.differentiateByX(1);
    // do something with the result
    foo.differentiateByY(2);
    // etc.
}

如果您知道自己总是希望通过X,Y和Z进行区分,那么您可以让一个Differentiator使用单个函数differentiate(double &x, double &y, double &z)执行所有三个操作,或者返回到在构造函数中完成所有工作:Differentiator foo(x, y, z);