1、首先打开vc6.0,新建一个项目。
2、然后我们在编辑框里输入代码添加assert.h头文件。
3、然后我们在编辑框里输入代码添加stdio.h头文件,添加stdlib.h头文件。
4、然后我们在编辑框里输入代码定义结构体ITEM,定义additem函数。
5、然后我们在编辑框里输入代码添加main函数体。
6、然后我们在编辑框里输入代码调用additem函数。
7、运行程序看看结果,此时可以看到程序已经终止了。
最常见的原因:程序发生了空指针调用。\x0d\x0a如果你刚入门,请检查:\x0d\x0ascanf("%d",&i)有没有加上“&”号,scanf必须在变量前加“&”(取地址符)。\x0d\x0a如果没有加&, scanf会把变量当作地址来用,而你的程序中又没有以变量为地址的变量,操作系统不允许程序读写程序规定范围以外的空间。出于安全起见,操作系统将其紧急中止。就发生了“***.exe已停止工作”的效果。\x0d\x0a如果你正在学习数组,请检查:\x0d\x0a数组是否越界。定义为int a[10]的数组,如果写a[10]=0; 相当于对a数组里的第11个元素赋值。事实上,a数组里并没有第11个元素。如果该元素的位置指向一个程序以外的内存,操作系统同样会果断将其终止。\x0d\x0a如果你正在学习指针,请检查:\x0d\x0a指针是否赋值;\x0d\x0a在给指针赋值时,有没有在非指针变量前加取地址符“&”;\x0d\x0aint * p = &i //正确!\x0d\x0aint * p = i //错误!\x0d\x0a这与在sccanf里没有加上“&”号的原因大致相同。\x0d\x0a指针问题属于程序逻辑错误,很多时侯编译器只会给你一个警告。要注意警告发生的位置自己是否有把握。如果你多次编译或忽视编译警告而进行链接,编译器会认为你对这些警告是有把握的,完全地信任了你,也就没有警告了。可以通过system 函数,调用dos命令taskkill实现关闭正在运行的应用程序。如
system("taskkill /im notepad.exe")
会关闭记事本应用。
system("taskkill \F /pid 1234 \T")
会强制结束pid为1234的进程及其子进程。
关于taskkill的详细描述如下:
TASKKILL [/S system [/U username [/P [password]]]] { [/FI filter] [/PID processid | /IM imagename] } [/F] [/T]
参数列表:
/S system 指定要连接到的远程系统。
/U [domain\]user 指定应该在哪个用户上下文
执行这个命令。
/P [password] 为提供的用户上下文指定密码。如果忽略,提示输入。
/F 指定要强行终止的进程。
/FI filter 指定筛选进或筛选出查询的的任务。
/PID process id 指定要终止的进程的PID。
/IM image name 指定要终止的进程的图像名。通配符 '*'可用来指定所有图像名。
/T Tree kill: 终止指定的进程和任何由此启动的子进程。
/? 显示帮助/用法。
筛选器:
筛选器名 有效运算符 有效值
----------- --------------- --------------
STATUS eq, ne 运行 | 没有响应
IMAGENAME eq, ne 图像名
PID eq, ne, gt, lt, ge, le PID 值
SESSION eq, ne, gt, lt, ge, le 会话编号
CPUTIME eq, ne, gt, lt, ge, le CPU 时间,格式为
hh:mm:ss。
hh - 时,
mm - 钟,ss - 秒
MEMUSAGE eq, ne, gt, lt, ge, le 内存使用,单位为 KB
USERNAME eq, ne 用户名,格式为
[domain\]user
MODULES eq, ne DLL 名
SERVICES eq, ne 服务名
WINDOWTITLE eq, ne 窗口标题
注意: 只有带有筛选器的情况下,才能跟 /IM 切换使用通配符 '*'。
注意: 远程进程总是要强行终止,
不管是否指定了 /F 选项。