第十章-程序设计语言
- 格式:docx
- 大小:257.82 KB
- 文档页数:72
程序设计语言
程序设计语言是计算机系统中用于定义计算机程序结构和执行的语言。
程序设
计语言可以分为高级语言和低级语言两种类型,每种语言都有其独特的特点和用途。
高级语言是一种结构化的语言,通常使用容易理解和编写的语法和符号。
常见
的高级语言包括C、C++、Java、Python等。
高级语言的优点是可以更加抽象地描
述问题和解决方案,提高了程序员的工作效率和程序可读性。
高级语言的程序需要通过编译器或解释器将其转换成机器语言,才能在计算机上执行。
与高级语言相反,低级语言直接面向计算机硬件,使用更接近机器指令的语法
和结构。
汇编语言是一种典型的低级语言,它直接映射到计算机的指令集架构。
低级语言具有更高的执行效率和更强的控制能力,通常用于系统编程和性能要求严格的应用领域。
程序设计语言的选择取决于应用领域、开发需求和个人偏好。
不同的语言有不
同的适用场景和优缺点,程序员需要根据具体情况选择最合适的语言来完成任务。
随着技术的发展和需求的变化,新的程序设计语言不断涌现,为开发人员提供更多的选择和灵活性。
总的来说,程序设计语言是程序员和计算机交流的桥梁,它的选择和使用对于
程序的开发和性能至关重要。
程序员应该根据需求和技术要求选择最合适的语言,并不断学习和掌握新的编程技能,以适应不断变化的计算机领域。
第10章多态性与虚函数一、单项选择题1.实现运行时的多态性要使用(D)。
A.重载函数B.构造函数C.析构函数D.虚函数2.通过运算符重载,可以改变运算符原有的(A)。
A.操作数类型B.操作数个数C.优先级D.结合性3.将运算符重载为类成员函数时,其参数表中没有参数,说明该运算符是(B)。
A.不合法的运算符B.一元运算符C.无操作数的运算符D.二元运算符4.在重载一个运算符时,其参数表中没有任何参数,说明该运算符是(B)。
A.作为友元函数重载的一元运算符B.作为成员函数重载的一元运算符C.作为友元函数重载的二元运算符D.作为成员函数重载的二元运算符5.如果表达式++a中的"++"是作为成员函数重载的运算符,若采用运算符函数调用格式,则可表示为(D)。
A.a.operator++(1)B.operator++(a)C.operator++(a,1)D.a.operator++()6.如果表达式a>=b中的">="是作为非成员函数重载的运算符,则可以等效地表示为(C)。
A.a.operator>=(b)B.b.operator>=(a)C.operator>=(a,b)D.perator>=(b,a)7.有如下程序:#include<iostream>using namespace std;class A{public:virtual void funl (){cout<<"A1";}void fun2 (){cout<<"A2";}};class B: public A{public:void funl (){cout<<"Bl";}void fun2 (){cout<<"B2";}};int main(){A*p=new B;p->funl ();p->fun2();return 0;}程序执行后,输出结果为(C)。
/程序设计语言您现在的位置:希赛网> 云阅读> 软件设计师考试试题分类精解(2018版)> 试题1(2017年下半年试题20)第 10 章:程序设计语言作者:希赛软考学院来源:希赛软考学院2017年11月21日试题1(2017年下半年试题20)更适合用来开发操作系统的编程语言是()。
(20)A.C/C++试题分析现行操作系统均由C/C++开发。
试题答案,(20)A试题2(2017年下半年试题21)以下关于程序设计语言的叙述中,不正确的是()。
(21)A.脚本语言中不使用变量和函数B.标记语言常用于描述格式化和链接C.脚本语言采用解释方式实现D.编译型语言的执行效率更高试题分析脚本语言中使用变量和函数来完成程序。
试题答案(21)A!试题3(2017年下半年试题22)将高级语言源程序通过编译或解释方式进行翻译时,可以先生成与源程序等价的某种中间代码。
以下关于中间代码的叙述中,正确的是()。
(22)A.中间代码常采用符号表来表示B.后缀式和三地址码是常用的中间代码C.对中间代码进行优化要依据运行程序的机器特性D.中间代码不能跨平台试题分析B只是类似于三地址码, CD与具体的机器无关。
试题答案(22)A%试题4(2017年下半年试题48)编译过程中进行的语法分析主要是分析()。
(48)A.源程序中的标识符是否合法B.程序语句的含义是否合法C.程序语句的结构是否合法D.表达式的类型是否合法试题分析语法分析主要是分析数据类型是否合法。
试题答案(48)D试题5(2017年下半年试题49)—某确定的有限自动机(DFA)的状态转换图如下图所示(0是初态,4是终态),则该DFA能识别()。
(49)A.aaab试题分析B项从0到1然后走不了了,C项在3状态结束,不对;D项也只到1状态。
试题答案(49)A@试题6(2017年下半年试题50)函数main()、f()的定义如下所示。
调用函数f()时,第一个参数采用传值(call by value)方式,第二个参数采用传引用(call by reference)方式,则函数main()执行后输出的值为()。
(50)A.10试题分析x = 2*10-1=19;a=a+x=10+19=29;a是引用传递,所以结果为29。
试题答案(50)D¥试题7(2017年上半年试题20)在高级语言源程序中,常需要用户定义的标识符为程序中的对象命名,常见的命名对象有()①关键字(或保留字)②变量③函数④数据类型⑤注释(20)A.①②③B.②③④C.①③⑤D.②④⑤试题分析关键字和注释不能作为标识符给对象命名。
试题答案(20)B<试题8(2017年上半年试题21)在仅由字符a、b构成的所有字符串中,其中以b结尾的字符串集合可用正规式表示为()。
(21)A.(b|ab)*bB.(ab*)*b*b*bD.(a|b)*b试题分析正规式(a|b)*对应的正规集为{ε,a,b,aa,ab,…,所有由a和b组成的字符串},结尾为b。
试题答案(21)D试题9(2017年上半年试题22)。
在以阶段划分的编译过程中,判断程序语句的形式是否正确属于()阶段的工作。
(22)A.词法分析B.语法分析C.语义分析D.代码生成试题分析检查单个词是否正确,属于词法阶段的工作。
而识别判断程序语句形式是否正确属于语法分析的工作。
试题答案(22)B试题10(2017年上半年试题48)某确定的有限自动机(DFA) 的状态转换图如下图所示(A 是初态,D、E 是终态),则该DFA 能识别()。
(48)A.00110\试题分析选项中,只有C选项的字符串能被DFA解析。
解析路径为:ACEEBDD。
试题答案(48)C试题11(2017年上半年试题49)函数main()、f()的定义如下所示,调用函数们f()时,第一个参数采用传值 (call by value) 方式,第二个参数采用传引用 (call by reference) 方式, main() 函数中 "print(x)" 执行后输出的值为()。
(49)A.11试题分析?当值传递的时候,将原来的参数复制了一份,但是引用传递的时候是将变量本身传了出去,因此,a代表的其实就是x本身,f函数里面的x是另一个变量,只有a的变化才能导致main函数里面的x值的变化。
试题答案(49)B试题12(2017年上半年试题50)下图为一个表达式的语法树,该表达式的后缀形式为()。
(50)A. x 5 y +* a / b -B. x 5 y a b*+ /-C. -/ *+ x 5 y a bD. x 5+* y+ a/b-试题分析要得到题目中的表达式语法树后缀形式,只需要对树进行后序遍历即可,后序遍历的结果为:x5y+*a/b-。
@试题答案(50)A试题13(2017年上半年试题57)以下关于字符串的叙述中,正确的是()。
(57)A.包含任意个空格字符的字符串称为空串B. 字符串不是线性数据结构C. 字符串的长度是指串中所含字符的个数D. 字符串的长度是指串中所含非空格字符的个数试题分析空格也是一个字符,所以包含空格的字符串不能称为空串,所以字符串的长度是指字符串所有字符个数的总和(包括空格);字符串是线性结构。
试题答案{(57)C试题14(2016年下半年试题21)常用的函数参数传递方式有传值与传引用两种。
()。
(21)A.在传值方式下,形参与实参之间互相传值B.在传值方式下,实参不能是变量C.在传引用方式下,修改形参实质上改变了实参的值。
D.在传引用方式下,实参可以是任意的变量和表达式。
试题分析传值调用最显著的特征就是被调用的函数内部对形参的修改不影响实参的值。
引用调用是将实参的地址传递给形参,使得形参的地址就是实参的地址。
试题答案(21)C、试题15(2016年下半年试题48)由字符a、b构成的字符串中,若每个a后至少跟一个b,则该字符串集合可用正规式表示为()。
(48)A.(b|ab)*B.(ab*)*C.(a*b*)*D.(a|b)*试题分析A的方式可以保证a后面必定是b试题答案(48)A@试题16(2016年下半年试题49)乔姆斯基(Chomsky)将文法分为4种类型,程序设计语言的大多数语法现象可用其中的()描述。
(49)A.上下文有关文法B.上下文无关文法C.正规文法D.短语结构文法试题分析上下文无关文法:形式语言理论中一种重要的变换文法,用来描述上下文无关语言,在乔姆斯基分层中称为2型文法。
由于程序设计语言的语法基本上都是上下文无关文法,因此应用十分广泛。
试题答案(49)B试题17(2016年下半年试题50)&运行下面的C程序代码段,会出现()错误。
int k=0;for(;k<100;);{k++;}(50)A.变量未定义B.静态语义C.语法D.动态语义试题分析在本题中,for语句后有“;”号,说明该循环语句的语句体为空,此时,循环会是一个死循环,所以存在语义错误。
试题答案(50)D试题18(2016年上半年试题20)以下关于高级程序设计语言实现的编译和解释方式的叙述中,正确的是()。
(20)A.编译程序不参与用户程序的运行控制,而解释程序则参与B.编译程序可以用高级语言编写,而解释程序只能用汇编语言编写C.编译方式处理源程序时不进行优化,而解释方式则进行优化D.编译方式不生成源程序的目标程序,而解释方式则生成$试题分析编译程序的功能是把用高级语言书写的源程序翻译成与之等价的目标程序。
编译过程划分成词法分析、语法分析、语义分析、中间代码生成、代码优化和目标代码生成6个阶段。
目标程序可以独立于源程序运行。
解释程序是一种语言处理程序,在词法、语法和语义分析方面与编译程序的工作原理基本相同,但在运行用户程序时,它是直接执行源程序或源程序的内部形式(中间代码)。
因此,解释程序并不产生目标程序,这是它和编译程序的主要区别。
试题答案(20)A试题19(2016年上半年试题21)以下关于脚本语言的叙述中,正确的是()。
(21)A.脚本语言是通用的程序设计语言B.脚本语言更适合应用在系统级程序开发中C.脚本语言主要采用解释方式实现D.脚本语言中不能定义函数和调用函数(试题分析脚本语言(Script languages,scripting programming languages,scripting languages)是为了缩短传统的编写-编译-链接-运行(edit-compile-link-run)过程而创建的计算机编程语言。
此命名起源于一个脚本“screenplay”,每次运行都会使对话框逐字重复。
早期的脚本语言经常被称为批处理语言或工作控制语言。
一个脚本通常是解释运行而非编译。
试题答案(21)C试题20(2016年上半年试题22)将高级语言源程序先转化为一种中间代码是现代编译器的常见处理方式。
常用的中间代码有后缀式、()、树等。
(22)A.前缀码B.三地址码C.符号表D.补码和移码试题分析!中间代码的表达形式有语法树,后缀式,三地址代码。
试题答案(22)B试题21(2016年上半年试题48)移进--归约分析法是编译程序(或解释程序)对高级语言源程序进行语法分析的一种方法,属于()的语法分析方法。
(48)A.自顶向下(或自上而下)B.自底向上(或自下而上)C.自左向右D.自右向左试题分析归约分析是自底向下方法中的典型。
[试题答案(48)B试题22(2016年上半年试题49)某确定的有限自动机(DFA)的状态转换图如下图所示(A是初态,C是终态),则该DFA能识别()。
(49)A.aabb试题分析'选项中的abab能被解释,其顺序参看图中的序号。
试题答案(49)B试题23(2016年上半年试题50)函数main()、f()的定义如下所示,调用函数f()时,第一个参数采用传值(call by value)方式,第二个参数采用传引用(call by reference)方式,main函数中“print(x)”执行后输出的值为()。
(50)A.1?试题分析本题考查传址与传值的相关知识,可以使用手动执行程序的方式来进行。
在主函数中,调用f(5,x)之后:f()函数中的x=5,a=1。
x=2*x+1,则x=11。
a=a+x,则a=12。
由于a是以传址的方式传入的参数,所以主函数中的x与其值相同,也为12。
打印结果应为12。
试题答案(50)D试题24(2015年下半年试题20-21)编译器和解释器是两种基本的高级语言处理程序。
编译器对高级语言源程序的处理过程可以划分为词法分析、语法分析、语义分析、中间代码生成、代码优化、目标代码生成等阶段,其中,()并不是每个编译器都必需的,与编译器相比,解释器()。