测试程序可以单独写,也可以做为模块整合在源程序中。
像我们熟知的debug语句,就是测试的最简单例子。在没有“断电查看”这一功能之前,为了监测程序每步执行后变量的结果,往往加入一些输出关键变量的语句。
例如以下程序:
#incldue<iostream>
using namespace std
#define DEBUG
int main(){
int n
#ifdef DEBUG
cout<<n<<endl
#endif
n = 3
cout<<n<<endl
return 0
}
此处DEBUG的作用是查看未初始化的变量n的值。通常会显示-89******00(0xcccccccc).
一般这样的语句还会出现在对指针进行 *** 作之后,用debug语句输出指针所指向内存的内容等。
这只是测试程序的一个功能。正如前面提到的,测试程序应该提供数据以检测程序的健壮性和安全性,以及用海量数据对执行效率进行检验等。
测试数据的选择有以下几个要点,分别检测程序的不同特性:
@ 尽可能包括输入集合内所有可能出现的元素,观察程序能否给出正确结果。(Authenticity)
比如:有一个程序输入给定迷宫平面图,要测试出最短路径长度。那么输入的迷宫应该包括各种可能:有通路的和没有通路的,有死胡同的和没有的,有回路的(避免搜索时出现死循环),出口在左上角,右上角的等,都要考虑进去。程序应该对每种情况都做出正确的反应。
@ 注意测试极端情况以及临界情况。(Security)
这是为了检测程序的健壮性,用户不可避免地会做出不合法的举动,程序需要有足够的防护强度来应对这些意外。
比如:如果编写了一个简易的计算器,那么一定要检查除数为0的情况;一个程序的功能是将一片文档的内容链接到另一个文档内,那么一定要检查自己链接自己的情况;等等。
@ 注意输入数据的规模以及随机性。(Efficiency)
衡量程序效率的标准应该考虑大规模数据下的表现。数据需要有足够的随机性以避免意外情况。
比如:比较几种不同排序算法的效率时,选用的数据应该是随机顺序的。在顺序数据的情况下:冒泡算法显然比快排还快,但这是偶然情况。
@ 如果有可能,还可以检测程序的通用性及扩展性(Versatility &Compatibility)
好的程序应该易于扩展,可利用价值高。大多数软件都在不停的打补丁,而不是推倒重写。
测试程序一般无法直接检测这两种特性。然而,测试中出现的错误有时可以帮助我们提升程序的质量。
我曾经写过一个类似于美图秀秀的图像处理程序,C++写的,相当粗糙。输入还要用命令行控制。当时我用各种图片进行了测试,包括纯色的,有明显背景色调的,以及完全混乱的噪声点。前面的图片表现都很好,但处理最后一张图片时程序抛出了异常——经过检验发现,我的处理程序是基于24位图片写的,而最后一张图片是32位的。类似的情况还有32位系统和64位系统下程序运行的问题等,在此就不赘述了。
要编写测试程序,一般分为两个模块:数据生成和结果检测。
测试程序的第一部分将生成的数据写入一个文件,让程序读取文件并运行后,再将结果写入另一个文件,之后由测试程序的第二部分比对输出文件和标准答案。
对于检测健壮性的测试程序,只需有第一部分即可,待检测程序在处理数据时如果发生异常,就根据结果作相应的修改。
测试效率的程序,可以在待检程序内加入计时模块。具体写法如下:
#include<ctime>
#define CHECK_TIME
int main(){
//....intput
#ifdef CHECK_TIME
clock t start = clock()
#endif
#ifdef CHECK_TIME
cout <<"Execution Time: " <<clock() - start <<" ms." <<endl
#endif
嗯,就是这么多啦,希望对你有帮助!
你好,如果你需要开发一个心里测试的C++,首先你需要一个设计。1、需要设计你的程序界面,有哪些菜单,有哪些测试类型等等。
2、需要提供一整套完整的心理测试题。并将这些测试数据编写成合适的数据结构。
3、利用程序读取这些测试题。
4、用户进行测试。可能部分测试有比较复杂的跳转关系。这部分内容可以在数据结构上使用自己改造链表实现。
5、输出测试结果。
然后根据1~5的顺序,进行程序的开发,设计好函数名。
具体的代码需要你自己实现。如果你是新手的话,预计这些内容需要1~2天的时间进行编写完善。
我想没有哪个网友会花费1天的时间,帮你写程序。有这个时间,都能回答至少100道题了。
即使1道题只获得系统奖励的20基本,也是2000多积分。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)