版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、 压力测试报告XXXXX项目压力测试报告2015-10-16XXXXXX技术有限公司文档信息项目名称XX系统个人系统优化项目项目负责人文档名称压力测试报告批复信息负责人日期意见拟制审核批准版本记录日期作者版本变更说明1.0简介文档目的本测试报告为性能对比测试报告,目的在于总结测试的工作进展情况并分析测试结果,描述本阶段测试是否达到调优预期目标,符合需要要求。面向人员本文档主要面向XX系统用户、测试人员、开发人员、项目管理人员和需要阅读本报告的相关领导。参考文档术语1.每秒事务数(TPS):是指每秒钟完成的事务数,事务是事先在脚本中定义的统计单元;2.事务平均响应时间(ART):响应时间一般反映
2、了在并发情况下,客户端从提交请求到接受到应答所经历的时间;3.资源利用率:是指在不影响系统正常运行的情况下各服务器的CPU、内存等硬件资源的占用情况;4.最大并发用户数:系统所能承受的最大并发用户数;5.思考时间(Thinktime):用于模拟实际用户在不同操作之间等待的时间。例如,当用户收到来自服务器的数据时,可能要等待几秒钟查看数据,然后做出响应,这种延时就称为“思考时间”。第一轮测试目标根据项目情况,本次测试的目的主要是解决XX系统个人系统登录和理财交易的处理能力达到客户正常使用要求,根据测试结果评估系统性能,为生产运行提供参考。分析目前系统登录与理财的处理能力;提高登录和理财交易处理能
3、力,达到客户流畅使用的目的;第二轮测试安排对整体系统运行环境、系统自身交易功能进行全面分析。通过压力测试手段优化系统,提高运行效率,并给出未来三到五年资源配置计划,制定后续保障机制。计划从十月十九日开始方案讨论。测试概况系统测试路径压力测试机web服务器应用服务器数据库挡板。测试环境测试资源类型用途服务器硬件压力机loadrunner压力机2C ,2G应用应用服务器32C,256G一体机数据库oracle 4C ,8G测试工具工具描述工具名称访问主机工具SecureCRT 5.1.3/Xshell访问数据库工具PL/SQL Developer文档编辑工具Microsoft Office 201
4、3Oracle客户端OracleClient性能测试工具LoadRunner11.0资源监控nmon本次对比测试内容针对登录交易和登录+我的理财交易,在优化前后分别设置50、200个虚拟用户,采用15秒加10人梯度加压模式,持续执行十分钟压力测试,采用5秒减10人梯度减压模式。同时监控数据库服务器与应用服务器。并发优化前优化后50200测试数据基础数据为了使压力测试结果更具有参考性,本次系统系统性能测试数据主要来源于个人系统生产脱敏数据。测试策略本次性能测试对待测交易进行单一场景测试、混合场景测试,测试执行使用HP Loadrunner工具执行,使用nmon、topas、loadrunner,
5、weblogic console进行监控,在测试过程中屏蔽思考时间的方式处理,分别对测试交易并发加压,记录TPS及响应时间、数据库性能参数、应用服务器性能参数等数据。测试人员现场参与人员:差异本次性能测试和实际上线情况存在一定的差异,差异如下:软件差异:本次测试的交易,开发工程师为性能测试进行了相应的调整,和生产程序有略微区别。环境差异:本次测试是在测试环境,环境的配置与实际生产环境有差异。交易测试结果汇总以下为执行的测试结果汇总,如下表所示:优化情况场景前端性能指标应用服务器数据库服务器VuserTPSTRT事物成功率CPUMemoryCPUMemory(秒)优化前501.02344.761
6、00%-75.31%97.90%70.80%0.98657.278100%-72.37%97.30%71.1.%2000.35184.22720.1%-87.12%98.50%76%1.97284.96814.5%-84.32%89.70%80%优化后5044.4870.934100%-75.60%79.10%70.70%68.3550.914100%-78.66%81.60%72.40%20041.6623.333100%-89.30%79.70%60.10%51.3613.065100%-97.60%82.50%89%混合交易压测情况总结:1、50用户优化前:50用户并发执行10分钟,一共
7、完成1246笔事务交易,平均响应时间在37.936秒。失败为0笔。2、50用户优化后:50用户并发执行6分钟,一共完成37113笔事务交易,平均响应时间在1.334秒。失败为0笔。3、200用户优化前:200用户并发执行10分钟左右,一共完成877笔事务交易,平均响应时间在166.666秒。失败为5464笔。4、200用户优化后:200用户并发执行10分钟,一共完成46927笔事务交易,平均响应时间在4.605秒,失败为0笔。单交易场景压测情况总结:1、50用户优化前:50用户并发执行13分钟,一共完成800笔事务交易,平均响应时间在43.884秒。失败为0笔。2、50用户优化后:50用户并发
8、执行6分钟,一共完成10373笔事务交易,平均响应时间在0.96秒。失败为0笔。3、200用户优化前:200用户并发执行13分钟,一共完成275笔事务交易,平均响应时间在136.354秒。失败为518笔。4、200用户优化后:200用户并发执行13分钟,一共完成32705笔事务交易,平均响应时间在3.319秒。失败为0笔。混合交易测试图表优化前50个用户数结果概况已删除,下同 从概况可以看出,50用户并发执行10分钟,一共完成1246笔事务交易,平均响应时间在37.936秒。失败为0笔。每秒点击率并发数最小值平均值最大值506.2527.80950TRT并发数最小值平均值最大值504.8293
9、7.27850.729TPS并发数最小值平均值最大值500.51.9723.626吞吐量 优化后50并发数结果概况从概况可以看出,50用户并发执行6分钟,一共完成37113笔事务交易,平均响应时间在1.334秒。失败为0笔。每秒点击率并发数最小值平均值最大值50222494.7454185.875TRT复合交易中:并发数最小值平均值最大值500.1760.9141.39TPS复合交易中登录的值:并发数最小值平均值最大值5030.7568.355104.875吞吐量并发数最小值平均值最大值50044620233.82588990381.875优化前200用户数结果概况从概况可以看出,200用户并
10、发执行10分钟左右,一共完成877笔事务交易,平均响应时间在166.666秒。失败为5464笔。每秒点击率并发数最小值平均值最大值200048.877459.25TRT并发数最小值平均值最大值2001984.968117.988TPS并发数最小值平均值最大值20000.3839.563吞吐量并发数最小值平均值最大值20001542597.66420924068.375优化后200用户数结果概况从概况可以看出,200用户并发执行10分钟,一共完成46927笔事务交易,平均响应时间在4.605秒,失败为0笔。每秒点击率并发数最小值平均值最大值2001305.0631823.1362706.875T
11、RT并发数最小值平均值最大值2000.1493.0566.742TPS优化后200用户TPS:并发数最小值平均值最大值20036.31351.36177.436吞吐量并发数最小值平均值最大值20020097877.93833418796.41757827993.417单交易测试图表优化前50用户登录概况从概况可以看出,50用户并发执行13分钟,一共完成800笔事务交易,平均响应时间在43.884秒。失败为0笔。每秒点击率并发数最小值平均值最大值500.12518.41453.125吞吐量并发数最小值平均值最大值5003756798.02450488425TRT并发数最小值平均值最大值504.8
12、7544.48750.875TPS并发数最小值平均值最大值500.2030.9341.376优化前200用户登录概况从概况可以看出,200用户并发执行13分钟,一共完成275笔事务交易,平均响应时间在136.354秒。失败为518笔。每秒点击率并发数最小值平均值最大值2000749.924903.375吞吐量并发数最小值平均值最大值20003517939.257416439.688TRT并发数最小值平均值最大值2009.518184.227475.646TPS并发数最小值平均值最大值20000.351.125优化后50用户登录概况从概况可以看出,50用户并发执行6分钟,一共完成10373笔事务
13、交易,平均响应时间在0.96秒。失败为0笔。每秒点击率并发数最小值平均值最大值50144800.761001.25吞吐量并发数最小值平均值最大值5003756798.0245048842.5TRT并发数最小值平均值最大值2000.2030.9341.376TPS并发数最小值平均值最大值2004.87544.48750.875优化后200用户登录概况从概况可以看出,200用户并发执行13分钟,一共完成32705笔事务交易,平均响应时间在3.319秒。失败为0笔。每秒点击率并发数最小值平均值最大值20006.70628.313吞吐量并发数最小值平均值最大值200031659.424136500.5
14、TRT并发数最小值平均值最大值2000.2273.3335.986TPS并发数最小值平均值最大值200041.66250.438结论总结:附录资料:不需要的可以自行删除C语言编译器的设计与实现 我们设计的编译程序涉及到编译五个阶段中的三个,即词法分析器、语法分析器和中间代码生成器。编译程序的输出结果包括词法分析后的二元式序列、变量名表、状态栈分析过程显示及四元式序列程序,整个编译程序分为三部分:(1) 词法分析部分(2) 语法分析处理及四元式生成部分 (3) 输出显示部分一词法分析器设计 由于我们规定的程序语句中涉及单词较少,故在词法分析阶段忽略了单词输入错误的检查,而将编译程序的重点放在中间
15、代码生成阶段。词法分析器的功能是输入源程序,输出单词符号。我们规定输出的单词符号格式为如下的二元式: (单词种别,单词自身的值)#define ACC -2#define syl_if 0#define syl_else 1#define syl_while 2#define syl_begin 3#define syl_end 4#define a 5#define semicolon 6#define e 7#define jinghao 8#define s 9#define L 10#define tempsy 11#define EA 12#define EO 13#define p
16、lus 14#define times 15#define becomes 16#define op_and 17#define op_or 18#define op_not 19#define rop 20#define lparent 21#define rparent 22#define ident 23#define intconst 24函数说明 读取函数 readline( )、readch( )词法分析包含从源文件读取字符的操作,但频繁的读文件操作会影响程序执行效率,故实际上是从源程序文件” source.dat ”中读取一行到输入缓冲区,而词法分析过程中每次读取一个字符时则是通
17、过执行 readch( )从输入缓冲区获得的;若缓冲区已被读空,则再执行readline( )从 source.dat 中读取下一行至输入缓冲区。扫描函数 scan( ) 扫描函数 scan( )的功能是滤除多余空格并对主要单词进行分析处理,将分析得到的二元式存入二元式结果缓冲区。变量处理 find( )变量处理中首先把以字母开头的字母数字串存到 spelling 数组中,然后进行识别。识别过程是先让它与保留关键字表中的所有关键字进行匹配,若获得成功则说明它为保留关键字,即将其内码值写入二元式结果缓冲区;否则说明其为变量,这时让它与变量名表中的变量进行匹配( 变量匹配函数 find( ) ),
18、如果成功,则说明该变量已存在并在二元式结果缓冲区中标记为此变量( 值填为该变量在变量名表中的位置),否则将该变量登记到变量名表中,再将这个新变量存入二元式缓存数组中。数字识别 number( ) 数字识别将识别出的数字填入二元式结果缓存数组。显示函数 显示函数的功能在屏幕上输出词法分析的结果( 即二元式序列程序),同时给出二元式个数及源程序行数统计。二语法分析器设计 语法分析器的核心是三张 SLR 分析表以及针对这三张 SLR 分析表进行语义加工的语义动作。编译程序中语法分析处理及四元式生成部分主要是以二元式作为输入,并通过 SLR 分析表对语法分析处理过程进行控制,使四元式翻译的工作有条不紊
19、的进行,同时识别语法分析中的语法错误。在处理 if 和 while 语句时,需要进行真值或假值的拉链和返填工作,以便转移目标的正确填入。1. 控制语句的 SLR 分析表1 设计过程如下: 将扩展文法GS S1)S if e S else S2)S while e S3)S L 4)S a;5)L S6)L SL用_CLOSURE方法构造LR(0)项目规范簇为:I0: S SS if e S else SS while e S S L S a ;I1: S SI2: S ife S else SI3: S while e SI4: S L L S L SL S if e S else SS wh
20、ile e S S L S a ; I5: S a; I6: S if e S else S S if e S else SS while e S S L S a ; I7: S while e S S if e S else SS while e S S L S a ; I8: S L I9: L S L SL L SL L S S if e S else SS while e S S L S a ; I10: S a ; I11: S if e S else SI12: S while e S I13: S L I14: S SL I15: S if e S else S S if e S
21、 else SS while e S S L S a ; I16: S if e S else S 构造文法G中非终结符的FOLLOW集如下:FOLLOW(S) = # S if e S else S得FOLLOW(S) = else S L 得FOLLOW(L) = 3) S S 得FOLLOW(S) = else , # L S 因为FIRST(S) = ,所以FOLLOW(S) = else , #, 在()项目规范簇中,只有9有“移进归约”冲突,L SL SL因为FOLLOW(L) FIRST(L) = 所以可以用方法解决以上冲突,最后我们得到的分析表如下:ACTIONGOTO ifE
22、lsewhilea;e#SL0S2S3S4S511ACC2S63S74S2S3S4S5985S106S2S3S4S5117S2S3S4S5128S139S2S3S4R5S591410R4R4R4111512R2R2R213R3R3R314R615S2S3S4S51616R1R1R1static int action2011=/* 0 */ 2, -1, 3, 4, -1, 5, -1, -1, -1, 1, -1,/* 1 */ -1, -1, -1, -1, -1, -1, -1, -1,ACC, -1, -1,/* 2 */ -1, -1, -1, -1, -1, -1, -1, 6, -
23、1, -1, -1,/* 3 */ -1, -1, -1, -1, -1, -1, -1, 7, -1, -1, -1,/* 4 */ 2, -1, 3, 4, -1, 5, -1, -1, -1, 9, 8,/* 5 */ -1, -1, -1, -1, -1, -1, 10, -1, -1, -1, -1,/* 6 */ 2, -1, 3, 4, -1, 5, -1, -1, -1, 11, -1,/* 7 */ 2, -1, 3, 4, -1, 5, -1, -1, -1, 12, -1,/* 8 */ -1, -1, -1, -1, 13, -1, -1, -1, -1, -1, -1
24、,/* 9 */ 2, -1, 3, 4,105, 5, -1, -1, -1, 9, 14,/* 10*/ -1,104, -1, -1,104, -1, -1, -1,104, -1, -1,/* 11*/ -1, 15, -1, -1, -1, -1, -1, -1, -1, -1, -1,/* 12*/ -1,102, -1, -1,102, -1, -1, -1,102, -1, -1,/* 13*/ -1,103, -1, -1,103, -1, -1, -1,103, -1, -1,/* 14*/ -1, -1, -1, -1,106, -1, -1, -1, -1, -1, -
25、1,/* 15*/ 2, -1, 3, 4, -1, 5, -1, -1, -1, 16, -1,/* 16*/ -1,101, -1, -1,101, -1, -1, -1,101, -1, -1;其中,前 9 列为 action 值,后 2 列为 goto 值;016 表示 17 个移进状态( 即 Si);-1表示出错;ACC 表示分析成功;而 100106 对应 7 个归约产生式:S SS if e S else SS while e SS L S a;L SL SL2. 算术表达式的 LR 分析表 2 设计如下:S EE E+EE E*EE (E)E i (过程略)ACTIONGOTO
26、I+*()#E0S3S211S4S5ACC2S3S263R4R4R4R44S3S275S3S286S4S5S97R1R5R1R18R2R2R2R29R3R3R3R3static int action1107=/* 0 */ 3, -1, -1, 2, -1, -1, 1,/* 1 */ -1, 4, 5, -1, -1,ACC, -1,/* 2 */ 3, -1, -1, 2, -1, -1, 6,/* 3 */ -1,104,104, -1,104,104, -1,/* 4 */ 3, -1, -1, 2, -1, -1, 7,/* 5 */ 3, -1, -1, 2, -1, -1, 8,
27、/* 6 */ -1, 4, 5, -1, 9, -1, -1,/* 7 */ -1,101, 5, -1,101,101, -1,/* 8 */ -1,102,102, -1,102,102, -1,/* 9 */ -1,103,103, -1,103,103, -1;3.布尔表达式的 SLR 分析表3 设计如下:(过程略)S BB iB i rop iB ( B )B ! BA B &B ABO B |B OBACTIONGOTOiRop()!&|#BAO0S1S4S513781S2R1R1R1R12S33R2R2R2R24S1S4S511785S1S4S56786R4S9S10R47S1
28、S4S514788S1S4S515789R5R5R510R7R7R711S12S9S1012R3R3R3R313S9S10ACC14R6S9S10R615R8S9S10R8static int action21611=/* 0 */ 1, -1, 4, -1, 5, -1, -1, -1, 13, 7, 8,/* 1 */ 1, 2, -1,101, -1,101,101,101, -1, -1, -1,/* 2 */ 3, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,/* 3 */ -1, -1, -1,102, -1,102,102,102, -1, -1
29、, -1,/* 4 */ 1, -1, 4, -1, 5, -1, -1, -1, 11, 7, 8,/* 5 */ 1, -1, 4, -1, 5, -1, -1, -1, 6, 7, 8,/* 6 */ -1, -1, -1,104, -1, 9, 10,104, -1, -1, -1,/* 7 */ 1, -1, 4, -1, 5, -1, -1, -1, 14, 7, 8,/* 8 */ 1, -1, 4, -1, 5, -1, -1, -1, 15, 7, 8,/* 9 */ 105, -1,105, -1,105, -1, -1, -1, -1, -1, -1,/*10 */ 10
30、7, -1,107, -1,107, -1, -1, -1, -1, -1, -1,/*11 */ -1, -1, -1, 12, -1, 9, 10, -1, -1, -1, -1,/*12 */ -1, -1, -1,103, -1,103,103,103, -1, -1, -1,/*13 */ -1, -1, -1, -1, -1, 9, 10,ACC, -1, -1, -1,/*14 */ -1, -1, -1,106, -1, 9, 10,106, -1, -1, -1,/*15 */ -1, -1, -1,108, -1, 9, 10,108, -1, -1, -1;LR 分析表控
31、制语义加工的实现:当扫描 LR 分析表的当前状态为归约状态时,则在调用与该状态对应的产生式进行归约的同时,调用相应的语义子程序进行有关的翻译工作。现在对 LR 分析器的分析栈加以扩充,使得每个文法符号之后都跟着它的语义值。为了清晰起见,我们把这个栈的每一项看成由三部分组成:状态 state ,文法符号 syl 和语义值 val。编译程序实现算术表达式、布尔表达式及程序语句的语义加工时,都是按这种状态栈加工方式进行的。例如:( 5 + 3 ) * 6的分析过程序号STATEValsylinput10-#( 5 + 3 ) * 6 #202-#(5 + 3 ) * 6 #3023-#(5+ 3 )
32、 * 6 #4026-5#(E+ 3 ) * 6 #50264-5-#(E+3 ) * 6 #602643-5-#(E+3 ) * 6 #702647-5-3#(E+E) * 6 #8026-8#(E) * 6 #90269-8-#(E)* 6 #1001-8#E* 6 #11015-8-#E* 6 #120153-8-#E*6#130158-8-6#E*E#1401-48#E#15ACC在分析过程中,第(3)步操作后的状态栈为 023,根据栈顶状态“ 3”和现行输入符号“ +”( input 栏字符串的第一个字符)查分析表 ACTION3,+=R4,即按第(4)个产生式 En 来进行归约;由
33、于产生式右部仅含一项,故去掉状态栈栈顶“3”;此时 2 变为新的栈顶状态,再查( 2,E)的下一状态 s:GOTO2,E=6,即将状态 6 和文法符号 E 压栈,最后得到第( 4)步的状态。第( 7)步操作后也是如此,当前状态栈为 02647,根据栈顶状态 7 和现行输入符号“ )”查分析表 ACTION7,)=R1,即按第(1)个产生式 EE1+E2进行归约;由于产生式右部有三项,故去掉状态栈栈顶的 647 三项;此时 2 变为新的栈顶状态,再查( 2,E)的下一状态 s:GOTO2,E=6,即将状态 6 和文法符号 E 压栈,最后得到第(8)步的状态。三中间代码生成器设计:布尔表达式 布尔
34、表达式在程序语言中有两个基本作用:一是用作控制语句( 如 if -else 或 while语句)的条件式;二是用于逻辑演算,计算逻辑值。布尔表达式是由布尔算符( &、| 、!)作用于布尔变量( 或常数)或关系表达式而形成的。关系表达式的形式是 E1 rop E2,其中 rop 是关系符( 如或),E1和 E2是算术式。在这里,我们只考虑前面给定文法所产生的布尔表达式:BB &B | B | B | ! B | (B) | i rop i | i遵照我们的约定,布尔算符的优先顺序( 从高到低)为:!、&、|,并假定&和|都服从左结合规则。所有关系符的优先级都是相同的,而且高于任何布尔算符,低于任
35、何算术算符,关系算符不得结合。表达式的真、假出口的确定:考虑表达式 B1 | B2 ,若 B1为真,则立即知道 B 也为真;因此,B1的真出口也就是整个 B 的真出口。若 B1?为假,则 B2必须被计值,B2的第一个四元式就是 B1的假出口。当然,B2的真、假出口也就是整个 B的真、假出口。类似的考虑适用于对 B1 & B2的翻译,我们将 B1 | B2和 B1 & B2 的翻译用下图表示,在自下而上的分析过程中,一个布尔式的真假出口往往不能在产生四元式的同时就填上。我们只好把这种未完成的四元式的地址( 编号)作为 B 的语义值暂存起来,待到整个表达式的四元式产生完毕之后再来回填这个未填入的转
36、移目标。条件语句对条件语句 if e S1 else S2 中的布尔表达式 e,其作用仅在于控制对 S1和 S2的选择。因此,作为转移条件的布尔式e,我们可以赋予它两种“ 出口”:一是“ 真”出T口,出向 S1;一是“ 假”出口,出向 S2。于是,e的代码F条件语句可以翻译成如图的一般形式。非终结符 e 具有两项语义值 e _TC 和e_FC,它们分别指出了尚待回填真、S2的代码假出口的四元式串。e 的“ 真”出口只有在往回扫描到if时才能知道,而它图 3-2 条件语句的代码结构 的“ 假”出口则需到处理过 S1并且到达 else 才能明确。这就是说,必须把 e_FC 的值传下去,以便到达相应
37、的 else时才进行回填。另外,当 S1语句执行完时意味着整个 if-else 语句也已执行完毕;因此,在 S1的编码之后应产生一条无条件转移指令。这条转移指令将导致程序控制离开整个 if-else 语句。但是,在完成 S2的翻译之前,这条无条件转移指令的转移目标是不知道的。甚至,在翻译完 S2之后,这条转移指令的转移目标仍无法确定。这种情形是由于语句的嵌套性所引起的。例如下面的语句:if e1 if e2 S1 else S2 else S3 在 S1的代码之后的那条无条件转移指令不仅应跨越 S2而且应跨越 S3。这也就是说,转移目标的确定和语句所处的环境密切相关。条件循环语句条件循环语句
38、while e S 通常被翻译成图的代码结构。布尔式 e 的“ 真”出口出向 S 代码段的第一个四元式。紧接 S 代码段之后应产生一条转向测试 e 的无条件转移指令。e 的“ 假”出口将导致程序控制离开整个 while 语句。e 的“ 假”出口目标即使在整个 while 语句翻译完之后也未必明确。例如: if e1 while e2 S1 else S2这种情况仍是由于语句的嵌套性引起的。所以,我们只好把它作为语句的语义值 SCHAIN 暂留下来,以便在处理外层语句时再伺机回填。语法翻译实现方法 将上述语法翻译付诸实现过程中,我们仅保留了算术表达式和布尔表达式翻译的文法和语义动作;面对程序语句
39、的翻译,由于改造后含有较多的非终结符且语义动作又相对简单,故仍恢复为改造之前的程序语句文法。由于总体上构造一个 SLR 分析表来实现语法分析及语义加工将使得所构造的 SLR 分析表过大,所以将其分为下面三部分处理:对算术表达式单独处理,即为算术表达式构造一个 SLR 分析表,并将赋值语句A=E 与算术表达式归为一类处理,处理之后的赋值语句仅看作为程序语句文法中的一个终结符 a。对布尔表达式也单独处理,并为其构造一个 SLR 分析表,经 SLR 分析表处理后的布尔表达式看作为程序语句文法中的一个终结符 e。程序语句文法此时变为:S if e S else S | while e S | L |
40、a;L SL | S此时为程序语句构造相应的 SLR 分析表就简单多了。前面的程序语句文法中所添加的非终结符是为了能及时回填有关四元式转移目标而引入的,在取消了这些非终结符后又如何解决及时回填转移目标的问题呢?我们采取的解决方法是增加两个数组 labelmark 和 labeltemp 来分别记录语句嵌套中每一层布尔表达式( 如果有的话)e 的首地址以及每一层else( 如果有的话)之前的四元式地址( 即无条件转出此层 if 语句的四元式)。也即,对程序语句的翻译来说:在处理完布尔表达式 e 后,回填 if 或 while 语句的真值链;在归约完每一个语句 S 之后检查符号栈,看在 S 之前的
41、文法符号是否 if 或 while,若是则回填假值链( 假值入口为语句 S 所对应的四元式序列之后;对 if 语句,此时已在该序列之后加入了一条无条件转移的四元式);在 if 语句中,else 前面要加入一个无条件转移的四元式转向 if 语句末尾;在 while语句尾要有一个无条件转移四元式转向 while 语句开头。四数据结构说明 编译程序中涉及到的数据结构说明如下:char ch=0; /*从字符缓冲区中读取当前字符*/int count=0; /*词法分析结果缓冲区计数器*/static char spelling10= ; /*存放识别的字*/static char line81= ; /*一行字符缓冲区( 最多 80 个字符)*/char *pline; /*字符缓冲区指针*/static char ntab110010; /*变量名表:共100项,每项长度为10*/struct ntab int tc; /*真值*/ int fc; /*假值*/ ntab2200; /*在布尔表达式 ) 中保存有关布尔变量的真、假值*/int label=0; /*指向 ntab2 的指针*/struct
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 温州职业技术学院《创新创业能力训练》2023-2024学年第一学期期末试卷
- 二零二五版个人车位出租及车位租赁平台合作合同3篇
- 二零二五年度货物买卖合同涉及特定技术转让与售后服务2篇
- 2024版商场环保节能改造合同协议
- 二零二五版粉煤灰运输合同规范范本下载6篇
- 个性化房产代理合作协议样本(2024)版B版
- 2024版房地产经纪人与佣金合同3篇
- 二零二五年度适用于工程项目的自卸车租赁服务合同范本3篇
- 二零二五版基金代持及风险控制合作协议2篇
- 二零二五年餐饮店食品安全培训与认证协议2篇
- 船形乌头提取工艺优化
- 财务总监个人述职报告
- 居家养老护理人员培训方案
- 江苏省无锡市2024年中考语文试卷【附答案】
- 管理者的九大财务思维
- 四年级上册数学应用题练习100题附答案
- 2024年度中国电建集团北京勘测设计研究院限公司校园招聘高频难、易错点500题模拟试题附带答案详解
- 有关企业会计人员个人工作总结
- 人教版高中数学必修二《第十章 概率》单元同步练习及答案
- 干部人事档案专项审核工作情况报告(8篇)
- 智慧校园信息化建设项目组织人员安排方案
评论
0/150
提交评论