软件工程理论与实践 (吕云翔) 第十一章: 软件编程课后习题及其答案解析
第十一章: 软件编程
1.判断题
(1)C语言是一种纯面向对象语言。(×)
(2)进行程序设计语言的选择时,首先考虑的是应用领域。(√)
(3)良好的设计风格就是高的编程技巧。(×)
解释:良好的设计风格并不仅仅取决于编程技巧的高低。它还包括代码的可读性、可维护性、可扩展性等方面的因素
(4)项目的应用领域是选择程序设计语言的关键因素。(√ )
(5)FORTRAN、Pascal、C语言和汇编语言都是科学工程计算可选用的语言。(×)
2.选择题
(1)软件实现是软件产品由概念到实体的一个关键过程,它将(B)的结果翻译成用某种程序设计语言编写的并且最终可以运行的程序代码。虽然软件的质量取决于软件设计,但是规范的程序设计风格将会对后期的软件维护带来不可忽视的影响。
A.软件设计
B.详细设计
C.架构设计
D.总体设计
解析:软件实现是将详细设计的结果翻译成用某种程序设计语言编写的并且最终可以运行的程序代码。虽然软件的质量取决于软件设计,但规范的程序设计风格将对后期的软件维护带来重要影响。
(2)(B)是一种纯面向对象语言。
A.CI
C.Eiffel
B.C++
D.Lisp
解析:C++是一种面向对象编程语言,它支持类、对象、继承、多态等面向对象的概念和特性。
(3)第一个体现结构化编程思想的程序设计语言是(C)。
A.FORTRAN
B.C
C.Pascal
D.Cobol
解析:Pascal是第一个体现结构化编程思想的程序设计语言,它在上世纪70年代末和80年代初广泛使用,推动了结构化编程的发展。
(4)面向对象设计的结果,实现时(A)。
A.只能使用面向对象语言
B.只能使用非面向对象语言
C.可以使用第四代语言
D.既可使用面向对象语言,也可使用非面向对象语言
3.简答题
(1)在选择编程语言时,通常要考虑哪些因素?
- 待开发系统的应用领域,即项目的应用范围。
- 用户的需求。
- 将使用何种工具进行软件开发。
- 软件开发人员的喜好和能力。
- 软件的可移植性要求。
- 算法和数据结构的复杂性。
- 平台支持。
(2)请简述编程风格的重要性。要形成良好的编程风格可以从哪些方面做起?
- 版权和版本声明
- 程序排版
- 注释
- 命名规则
- 数据说明
- 语句构造
- 输入/输出
- 效率
(3)编程语言主要有哪几类?总结每类语言的优缺点。
机器语言,汇编语言,高级语言,超高级语言。
-
机器语言:
优点:- 直接与计算机硬件交互,具有最高的执行效率。
- 可以对硬件进行精确的控制。
缺点:
- 编写复杂且容易出错,因为需要手动编写二进制指令。
- 不具备可移植性,因为机器语言与特定的硬件架构相关。
-
汇编语言:
优点:- 比机器语言更易读写,使用助记符代替了二进制指令。
- 具有较高的执行效率和对硬件的控制能力。
缺点:
- 仍然需要了解底层硬件架构和指令集。
- 编写和调试相对复杂,可移植性较差。
-
高级语言:
优点:- 更易学习和使用,具备更高层次的抽象能力。
- 语法更接近自然语言,提供更好的可读性和可维护性。
- 提供丰富的库和工具支持,加快开发速度。
缺点:
- 相对于低级语言,执行效率较低。
- 对底层硬件的控制能力较弱。
- 某些高级语言可能存在较大的内存消耗和运行时开销。
-
超高级语言:
优点:- 针对特定领域提供了专门的工具和库,加快开发速度。
- 提供更高级别的抽象和功能,使问题域更易于表达和解决。
缺点:
- 通用性较差,只适用于特定领域或问题。
- 学习和掌握超高级语言可能需要额外的学习和培训成本。
(4)对标识符命名时,要注意哪些原则?
1)按照标识符的实际意义命名,使其名称具有直观性,能够体现标识符的语义。这样可以帮助开发人员对标识符进行理解和记忆。
2)标识符的长度应当符合“最小长度与最大信息量”原则。
3)命名规则尽量与所采用的操作系统或开发工具的风格保持一致。比如,缩写的使用,字母大小写的选择,以及对常量和变量命名的区分等。例如,在有些软件开发项目的命名规则里,常量名称选用大写字母,变量名称选用小写字母。一般不推荐使用单词缩写进行命名,因为使用缩写在阅读时容易产生歧义。例如,表示班级名称的变量class Name不宜改成e Name。
4)变量名不要过于相似,这样容易引起误解。
5)在定义变量时,最好对其含义和用途做出注释。
6)程序中不要出现仅靠大小写区分的相似的标识符。
7)尽量避免名称中出现数字编号,除非逻辑上的确需要编号。
(5)为什么要对源程序进行注释?
注释阐述了程序的细节,是软件开发人员之间,以及开发人员和用户之间进行交流的重要途径。做好注释工作有利于日后的软件维护。
4.应用题
(1)请对下面代码的布局进行改进,使其符合规范,更容易理解。
for(i=1;i<=n-1;i++)I
t=i;
for(j=i+1;j<=n;j++)
if(al[j]<a[r)])t=j;
if(t!=i)
temp=a[t];
a[t]=a[i];
a[i]=temp;
for(i = 1; i < n; i++)
for(j =n-1;j >= i; j--){
if(a[j]<a[i]){
temp = a[i];
a[i] = a[j];
a[j] = temp;
}
}
(2)使用Microsoft Visual Studio2013和C#对求两个整数的最大公约数这一问题进行编程。
using System;
namespace GCDExample
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine("请输入两个整数:");
int num1 = Convert.ToInt32(Console.ReadLine());
int num2 = Convert.ToInt32(Console.ReadLine());
int gcd = CalculateGCD(num1, num2);
Console.WriteLine("最大公约数是:" + gcd);
Console.ReadLine();
}
static int CalculateGCD(int a, int b)
{
// 辗转相除法求最大公约数
while (b != 0)
{
int remainder = a % b;
a = b;
b = remainder;
}
return a;
}
}
}