摘自http://zhidao.baidu.com/question/120216130.html的const若干使用问题

本文通过几个测试案例探讨了C++中const变量的行为特性,特别是当尝试通过指针改变其值时的情况。揭示了编译器对const变量的优化方式及其潜在的影响。

#include
#include

using std::cout;
using std::endl;
void changeValue( const int *a );

int main()
{
//test 1
        const int test = 9;
    changeValue( &test );
    cout<<

//test 2
        int test31 = 10;
    const int test3 = test31;
    changeValue( &test3 );
    cout<<

//test 3
        int test1 = 10;
    changeValue( &test1 );
    cout<<

//test4
        int s = 30;
    const int tag = s;
    const int *cp = &tag;
    *(int*)cp = 10;
    cout<<<","<<*cp<

//test 5
        const int tag1 = 30;
    const int *cp1 = &tag1;
    *(int*)cp1 = 10;
    cout<<<","<<*cp1<

        return 0;
}

void changeValue( const int *a )
{
    *(int*)a = 0;
}

output:

9
0
0
10,10
30,10

下面是解释:

你把一个变量声明成const类型,就意味着你不会更改它的值,编译器能保证其不被直接修改,可能就放松了对它的控制。比如第一次访问时读到寄存器里,下次在访问时如果还在寄存器中,就不会再从内存中读取。const类型的变量不是在只读内存里的,他也是栈或者堆或者全局的可读写内存里的,如果中间你通过间接的手段改动了内存中的值(程序可读写内存里面的东西,一般没有保护,可以通过指针随便改的),编译器可能觉察不到,仍是用寄存器中的值,就会产生一些微妙的现象。

证实:

通过调试都可以看出来,const类型变量内存中值是改了的。

通过程序也可以看出,通过取地址然后复引用,输出的结果就是更改之后的:
#include

using namespace std;

int main()
{
 {
  const int i = 0;
  *(int*)&i = 1;
  cout << i << "/t" << *(int*)&i << endl;
 }
 {
  const int i = 0;
  const int j = i;
  *(int*)&j = 1;
  cout << j << "/t" << *(int*)&j << endl;
 }
 {
  const int i = 0;
  const int* j = &i;
  *(int*)j = 1;
  cout << i << "/t" << *j << endl;
 }
    return 0;
}

通过汇编可以看出,编译器直接把常变量的值替换成了常量,而没有读到寄存器或者从内存中读取,而普通变量,是从内存中读取的:

8:            const int i = 0x12345678;
004017A8   mov         dword ptr [i],12345678h
9:            int j = i;
004017AF   mov         dword ptr [j],12345678h
10:           int k = i + j;
004017B6   mov         eax,dword ptr [j]       //here
004017B9   add         eax,12345678h          //here
004017BE   mov         dword ptr [k],eax 
内容概要:本文围绕“基于交流潮流的电力系统多元件N-k故障模型研究”展开,深入探讨了利用Matlab代码实现电力系统在发生多个关键元件同时故障(即N-k故障)情况下的交流潮流计算与故障分析方法。该模型不仅考虑了传统潮流方程的非线性特性,还引入了故障约束条件,能够精确模拟复杂多样的故障场景,如短路、断线等,进而评估电网在极端运行条件下的稳态与动态行为。研究通过构建典型电力系统算例,验证了所提模型在故障筛选、脆弱性识别及系统恢复策略制定方面的有效性,为电力系统安全评估、风险预警和防御体系构建提供了坚实的理论依据和技术支撑。此外,模型具备良好的扩展性,可进一步应用于连锁故障传播分析、恶意攻击模拟等高级安全分析领域。; 适合人群:具备电力系统分析基础理论知识和Matlab编程能力的高校研究生、科研院所研究人员以及电力公司从事电网规划、运行与安全管理的技术人员,特别适用于开展电力系统安全稳定、可靠性评估与应急响应机制研究的专业人士。; 使用场景及目标:①开展电力系统在多重故障条件下的交流潮流仿真,评估系统电压稳定性、线路过载风险及负荷损失程度;②识别电网中的关键薄弱环节与脆弱元件,支撑电网加固改造与防御资源配置;③用于科研项目中的故障场景建模与算法验证,或作为教学案例帮助学生理解复杂故障下的系统响应机制。; 阅读建议:此资源以Matlab代码为核心实现手段,建议读者结合理论推导与代码实现进行对照学习,重点关注故障建模过程中雅可比矩阵的修正方法、故障注入方式及收敛性处理策略,建议在仿真中逐步增加故障数量与复杂度,深入理解N-k故障对系统潮流分布的影响规律,并尝试将其拓展至含新能源接入的现代电力系统场景中进行验证与优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值