Cappuccino : Local Variables & Performance

Patrick_DK 2003-01-17 03:14:20
/**
* File LocalVariablePerformancer.java
* Date 2003-1-17
* Time 14:56:29
*
*/
package org.jfml.cappuccino;

/**
* 如果您频繁存取变量,就需要考虑从何处存取这些变量。
* 变量是 static 变量,还是堆栈变量,或者是类的实例变量?
* 变量的存储位置对存取它的代码的性能有明显的影响?
*
* Method void stackAccess(int)
* 0 iconst_0 //将 0 压入堆栈。
* 1 istore_2 //弹出 0 并将它存储在局部分变量表中索引为 2 的位置 (j)。
* 2 iconst_0 //压入 0。
* 3 istore_3 //弹出 0 并将它存储在局部变量表中索引为 3 的位置 (i)。
* 4 goto 13 //跳至位置 13。
* 7 iinc 2 1 //将存储在索引 2 处的 j 加 1。
* 10 iinc 3 1 //将存储在索引 3 处的 i 加 1。
* 13 iload_3 //压入索引 3 处的值 (i)。
* 14 iload_1 //压入索引 1 处的值 (val)。
* 15 if_icmplt 7 //弹出 i 和 val。如果 i 小于 val,则跳至位置 7。
* 18 return //返回调用方法。
*
* Method void instanceAccess(int)
* 0 iconst_0 //将 0 压入堆栈。
* 1 istore_2 //弹出 0 并将它存储在局部变量表中索引为 2 的位置 (i)。
* 2 goto 18 //跳至位置 18。
* 5 aload_0 //压入索引 0 (this)。
* 6 dup //复制堆栈顶的值并将它压入。
* 7 getfield #19 <Field int instVar>
* //弹出 this 对象引用并压入 instVar 的值。
* 10 iconst_1 //压入 1。
* 11 iadd //弹出栈顶的两个值,并压入它们的和。
* 12 putfield #19 <Field int instVar>
* //弹出栈顶的两个值并将和存储在 instVar 中。
* 15 iinc 2 1 //将存储在索引 2 处的 i 加 1。
* 18 iload_2 //压入索引 2 处的值 (i)。
* 19 iload_1 //压入索引 1 处的值 (val)。
* 20 if_icmplt 5 //弹出 i 和 val。如果 i 小于 val,则跳至位置 5。
* 23 return //返回调用方法。
*
* Method void staticAccess(int)
* 0 iconst_0 //将 0 压入堆栈。
* 1 istore_2 //弹出 0 并将它存储在局部变量表中索引为 2 的位置 (i)。
* 2 goto 16 //跳至位置 16。
* 5 getstatic #25 <Field int staticVar>
* //将常数存储池中 staticVar 的值压入堆栈。
* 8 iconst_1 //压入 1。
* 9 iadd //弹出栈顶的两个值,并压入它们的和。
* 10 putstatic #25 <Field int staticVar>
* //弹出和的值并将它存储在 staticVar 中。
* 13 iinc 2 1 //将存储在索引 2 处的 i 加 1。
* 16 iload_2 //压入索引 2 处的值 (i)。
* 17 iload_1 //压入索引 1 处的值 (val)。
* 18 if_icmplt 5 //弹出 i 和 val。如果 i 小于 val,则跳至位置 5。
* 21 return //返回调用方法。
*/


public class LocalVariablePerformancer
{
private int instVar;
private static int staticVar;

//存取堆栈变量
void stackAccess(int val)
{
int j=0;
for (int i=0; i<val; i++)
{
j += 1;
}
}

//存取类的实例变量
void instanceAccess(int val)
{
for (int i=0; i<val; i++)
{
instVar += 1;
}
}

//存取类的 static 变量
void staticAccess(int val)
{
for (int i=0; i<val; i++)
{
staticVar += 1;
}
}

//@better 通过local变量来存取类的实例变量
void instanceAccessByLocalVariable(int val)
{
int j = instVar;

for (int i=0; i<val; i++)
{
j += 1;
}

instVar = j;
}

//@better 通过local变量来存取类的static变量
void staticAccessByLocalVariable(int val)
{
int j = staticVar;

for (int i=0; i<val; i++)
{
j += 1;
}

staticVar = j;
}

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

62,621

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧