• 【C/C++学习】之三、const_cast


    用法:const_cast<type_id> (expression)


    此运算符是用来消除类型的const和volatile属性的。


    看到const_cast的你应该知道,他是用来转换掉表达式的const性质的。对也,只有使用我们的const_cast才能将const性质转换掉!

    ok,我们来看一段代码:

    	const char m = 't';
    	const char *cm = &m;
    	char *n = const_cast<char*>(cm);
    	*n = 'a';
    	cout << *n << endl;

    很好,代码编译通过,你应该能看的出来,他的结果不应该是‘t'吧,对的  最后的输出结果是’a',我们给n指针所指向的变量重新变了值了~  很好,这就是我们的const_cast的功劳!


    但是如果是这样:

    	const char m = 't';
    	const char *cm = &m;
    	char *n = cm;
    	*n = 'a';
    	cout << *n << endl;

    很悲剧,无法编译通过!


    看到上面两段代码大家应该稍微有点明白了吧,但是再看下面:

    	const char m = 't';
    	const char *cm = &m;
    	char *n = (char*)cm;
    	*n = 'a';
    	cout << *n << endl;

    oh。。编译也是通过的,而且最后的结果还是a~~,这是为什么呢 ?

    其实,在C++中,指针之间的转换是不检查类型的,他们是任意转换的,什么指针都可以转换!

    就是这样!


    哦 对了,const_cast是不能用来执行任何类型的转换的,这样都会引起编译错误的!

    	const char m = 't';
    	const char *cm = &m;
    	int *n = const_cast<int*>(cm);
    	*n = 'a';
    	cout << *n << endl;

    很不幸,这段代码报错了,看一下错误提示:


    oh~ 确实是这样的!



    说到这里我想说一下,绝对不要去修改const变量的值,  但是这样说的话要const_cast有什么用呢?

    在这里《C++Primer 第四版》中有一个例子,假设有一个函数s,他有一个唯一的参数是char*类型的,我们对他只读,不写! 在访问这个函数的时候,我们最好的选择是修改它让它接受const char*类型的参数!  但是如果不行的话 我们就要用const_cast,用一个const值调用s函数了!

    void s(char *)
    {
    	cout << 'a' << endl;
    }
    
    	char a = 's';
    	const char *ss = &a;
    	s(const_cast<char*> (ss));

    ok,我们编译通过了!



    不过我在写代码的时候const_cast 用的很少!





    -----------2012/8/4

    -----------jofranks 于南昌


  • 相关阅读:
    Serverless 动态博客开发趟“坑”记
    tsv与csv文件
    zypper
    source、sh、./三种执行方式对脚本变量的影响
    linux nm
    ldconfig
    cpio
    License简介
    rpm之spec文件
    使用rpmbuild制作rpm包
  • 原文地址:https://www.cnblogs.com/java20130723/p/3211438.html
Copyright © 2020-2023  润新知