0

阅读此线程后 ,显式关键字在 C++ 中的含义是什么?

我编了这个程序

class MyClass
{
  public:
  explicit MyClass(int a)
  {
    cout<<"Int was called"<<endl;
    val = a;
  }

  MyClass(char *a)
  {
    cout<<"Char was called"<<endl;
    val = atoi(a);
  }

  MyClass(const MyClass& copy)
  {
    cout<<"Copy Const was called"<<endl;
    this->val = copy.val;
  }

  inline const int getval() const
  { return val; }

  private:
  int val ;
};

主要代码

int main()
{
  int x=4;
  char y='4';
  char *z = &y;

  MyClass a(x);
  MyClass b(z);
  MyClass c(a);
  MyClass d('4');

  cout<<a.getval()<<endl;
  cout<<b.getval()<<endl;
  cout<<c.getval()<<endl;
  cout<<d.getval()<<endl;

  return 0;
}

输出是:

Int was called
Char was called
Copy Const was called
Int was called
4
4
4
52

现在,根据上面的线程,它应该在对象 d 上的构造函数调用之后抛出错误,但它没有。

g++ 版本信息

Using built-in specs.
Target: i486-linux-gnu
Configured with: ../src/configure -v --with-pkgversion='Ubuntu 4.4.3-4ubuntu5' --with-bugurl=file:///usr/share/doc/gcc-4.4/README.Bugs --enable-languages=c,c++,fortran,objc,obj-c++ --prefix=/usr --enable-shared --enable-multiarch --enable-linker-build-id --with-system-zlib --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --with-gxx-include-dir=/usr/include/c++/4.4 --program-suffix=-4.4 --enable-nls --enable-clocale=gnu --enable-libstdcxx-debug --enable-plugin --enable-objc-gc --enable-targets=all --disable-werror --with-arch-32=i486 --with-tune=generic --enable-checking=release --build=i486-linux-gnu --host=i486-linux-gnu --target=i486-linux-gnu
Thread model: posix
gcc version 4.4.3 (Ubuntu 4.4.3-4ubuntu5) 

我不确定我在上面的代码中是否做错了什么。请帮忙

4

7 回答 7

4

显式构造函数不允许您执行“隐式转换”之类的操作,例如在初始化对象时:

MyClass d = 4;

或者在调用带参数的函数时:

void foo( const MyClass& param);

... 

foo( 4);

在您的情况下,在调用显式构造函数之前有从 char 到 int 的转换,这是设计的。

于 2010-09-15T12:20:25.840 回答
1

实际上,构造d是使用int构造函数完成的。您的char( '4') 被隐式转换为int. 这在 C/C++ 中是合法的,因为它们都是整数,int且宽度至少为char

object 的输出d是字符“4”的 ASCII 码。

于 2010-09-15T12:17:38.313 回答
1

关键字定义构造explicit函数不可用于隐式转换,但在您的代码中,您明确地请求从值构造对象。

如果您将代码更改为:

MyClass d = 'a';
MyClass x = 5;

然后转换是隐式的,你会得到一个错误。

请注意,重要的转换不是 from 'a'toint而是 from intto MyClass。允许编译器执行从'a'to的转换int,因为MyClass(int)在您的原始代码中明确请求了构造函数。

于 2010-09-15T12:20:15.153 回答
0

'4' 是一个 char,可以自由转换为 int。52 是 '4' 的字符代码

于 2010-09-15T12:19:37.387 回答
0

“char”(如 'd')在 C++ 中具有 int 值。事实上,52 是 'd' 的整数 ASCII 值。

于 2010-09-15T12:22:08.487 回答
0

没有错误 - 它只是使用整数值“4”调用您的 int 构造函数,实际上是 U+0034(十六进制)或数字 52。C/C++ 中的所有 char 常量在内部存储为 int

于 2010-09-15T12:22:34.337 回答
0

任何char文字都是一个int,你可以说int i = 'a;`

于 2010-09-15T12:23:48.737 回答