2、每个程序只有一个main函数。(如果在类里看到了main函数那个不是通常意义上的main函数。只是一个名字叫做main的自定函数)。main函数会接受系统传入的参数。参数是固定的。(但是类里如果见到main函数,肯定是自己定义的参数)。
程序参考网上的资源,在此谢谢这些无私奉献的朋友!!!\x0d\ ;/\x0d\ / 实验目的:1掌握键盘扫描的原理以及十/十六进制的转换\x0d\ 2了解单片机输入和输出的过程,以及如何对数据进行采集的\x0d\ 实验内容:键盘上对应有16个按键,从0到F,按下相应的键会在数码管上显示相应的数字,\x0d\ 其中K0到K15是采用44的方式连接的\x0d\ /\x0d\ ;\x0d\ ; 0 1 2 3 ---P20\x0d\ ; 4 5 6 7 ---P21\x0d\ ; 8 9 A B ---P22\x0d\ ; C D E F ---P23\x0d\ ; | | | |\x0d\ ; P24 P25 P26 P27\x0d\ ;\x0d\\x0d\ORG 0000h\x0d\LJMP MAIN\x0d\ORG 0030h\x0d\MAIN:\x0d\MOV DPTR,#TAB ;将表头放入DPTR\x0d\LCALL KEY ;调用键盘扫描程序\x0d\MOVC A,@A+DPTR ;查表后将键值送入ACC\x0d\MOV P0,A ;将Acc值送入P0口\x0d\CLR P13 ;开显示\x0d\LJMP MAIN ;返回调用子程序反复循环显示\x0d\\x0d\KEY: LCALL KS ;调用检测按键子程序\x0d\ JNZ K1 ;有键按下继续\x0d\ LCALL DELAY2 ;无键按下调用延时去抖动程序\x0d\ AJMP KEY ;返回继续检测有无按键按下\x0d\K1: LCALL DELAY2\x0d\ LCALL DELAY2 ;有键按下继续延时去抖动\x0d\ LCALL KS ;再一次调用检测按键程序\x0d\ JNZ K2 ;确认有按下进行下一步\x0d\ AJMP KEY ;无键按下返回继续检测\x0d\K2: MOV R2,#0EFH ;将扫描值送入 R2暂存\x0d\ MOV R4,#00H ;将第一列的列值00H送入R4暂存,R4用于存放列值。\x0d\K3: MOV P2,R2 ;将R2的值送入P2口\x0d\L6: JB P20,L1 ;P20等于1跳转到L1\x0d\ MOV A,#00H ;将第一行的行值00H送入ACC\x0d\ AJMP LK ;跳转到键值处理程序\x0d\L1: JB P21,L2 ;P21等于1跳转到L2\x0d\ MOV A,#04H ;将第二行的行值送入ACC\x0d\ AJMP LK ;跳转到键值理程序进行键值处理\x0d\L2: JB P22,L3 ;P12等于1跳转到L3\x0d\ MOV A,#08H ;将第三行的行值送入ACC\x0d\ AJMP LK ;跳转到键值处理程序\x0d\L3: JB P23,NEXT ;P23等于1跳转到NEXT处\x0d\ MOV A,#0cH ;将第四行的行值送入ACC\x0d\LK: ADD A,R4 ;行值与列值相加后的键值送入A\x0d\ PUSH ACC ;将A中的值送入堆栈暂存\x0d\K4: LCALL DELAY2 ;调用延时去抖动程序\x0d\ LCALL KS ;调用按键检测程序\x0d\ JNZ K4 ;按键没有松开继续返回检测\x0d\ POP ACC ;将堆栈的值送入ACC\x0d\ RET\x0d\\x0d\NEXT:\x0d\ INC R4 ;将列值加一\x0d\ MOV A,R2 ;将R2的值送入A\x0d\ JNB ACC7,KEY ;扫描完成跳至KEY处进行下一回合的扫描\x0d\ RL A ;扫描未完成将A中的值右移一位进行下一列的扫描\x0d\ MOV R2,A ;将ACC的值送入R2暂存\x0d\ AJMP K3 ;跳转到K3继续\x0d\KS: MOV P2,#0FH ;将P2口高四位置0低四位值1\x0d\ MOV A,P2 ;读P2口\x0d\ XRL A,#0FH ;将A中的值与A中的值相异或\x0d\ RET ;子程序返回\x0d\DELAY2: ;40ms延时去抖动子程序8FA2=40ms\x0d\ MOV R5,#08H\x0d\L7: MOV R6,#0FAH\x0d\L8: DJNZ R6,L8\x0d\ DJNZ R5,L7\x0d\ RET\x0d\\x0d\TAB:\x0d\ DB 0C0H;0\x0d\ DB 0F9H;1\x0d\ DB 0A4H;2\x0d\ DB 0B0H;3\x0d\ DB 099H;4\x0d\ DB 092H;5\x0d\ DB 082H;6\x0d\ DB 0F8H;7\x0d\ DB 080H;8\x0d\ DB 090H;9\x0d\ DB 088H;A\x0d\ DB 083H;b\x0d\ DB 0C6H;C\x0d\ DB 0A1H;d\x0d\ DB 086H;E\x0d\ DB 08EH;F\x0d\END
程序参考网上的资源,在此谢谢这些无私奉献的朋友!!!
;/
/ 实验目的:1掌握键盘扫描的原理以及十/十六进制的转换
2了解单片机输入和输出的过程,以及如何对数据进行采集的
实验内容:键盘上对应有16个按键,从0到F,按下相应的键会在数码管上显示相应的数字,
其中K0到K15是采用44的方式连接的
/
;
; 0 1 2 3 ---P20
; 4 5 6 7 ---P21
; 8 9 A B ---P22
; C D E F ---P23
; | | | |
; P24 P25 P26 P27
;
ORG 0000h
LJMP MAIN
ORG 0030h
MAIN:
MOV DPTR,#TAB ;将表头放入DPTR
LCALL KEY ;调用键盘扫描程序
MOVC A,@A+DPTR ;查表后将键值送入ACC
MOV P0,A ;将Acc值送入P0口
CLR P13 ;开显示
LJMP MAIN ;返回调用子程序反复循环显示
KEY: LCALL KS ;调用检测按键子程序
JNZ K1 ;有键按下继续
LCALL DELAY2 ;无键按下调用延时去抖动程序
AJMP KEY ;返回继续检测有无按键按下
K1: LCALL DELAY2
LCALL DELAY2 ;有键按下继续延时去抖动
LCALL KS ;再一次调用检测按键程序
JNZ K2 ;确认有按下进行下一步
AJMP KEY ;无键按下返回继续检测
K2: MOV R2,#0EFH ;将扫描值送入 R2暂存
MOV R4,#00H ;将第一列的列值00H送入R4暂存,R4用于存放列值。
K3: MOV P2,R2 ;将R2的值送入P2口
L6: JB P20,L1 ;P20等于1跳转到L1
MOV A,#00H ;将第一行的行值00H送入ACC
AJMP LK ;跳转到键值处理程序
L1: JB P21,L2 ;P21等于1跳转到L2
MOV A,#04H ;将第二行的行值送入ACC
AJMP LK ;跳转到键值理程序进行键值处理
L2: JB P22,L3 ;P12等于1跳转到L3
MOV A,#08H ;将第三行的行值送入ACC
AJMP LK ;跳转到键值处理程序
L3: JB P23,NEXT ;P23等于1跳转到NEXT处
MOV A,#0cH ;将第四行的行值送入ACC
LK: ADD A,R4 ;行值与列值相加后的键值送入A
PUSH ACC ;将A中的值送入堆栈暂存
K4: LCALL DELAY2 ;调用延时去抖动程序
LCALL KS ;调用按键检测程序
JNZ K4 ;按键没有松开继续返回检测
POP ACC ;将堆栈的值送入ACC
RET
NEXT:
INC R4 ;将列值加一
MOV A,R2 ;将R2的值送入A
JNB ACC7,KEY ;扫描完成跳至KEY处进行下一回合的扫描
RL A ;扫描未完成将A中的值右移一位进行下一列的扫描
MOV R2,A ;将ACC的值送入R2暂存
AJMP K3 ;跳转到K3继续
KS: MOV P2,#0FH ;将P2口高四位置0低四位值1
MOV A,P2 ;读P2口
XRL A,#0FH ;将A中的值与A中的值相异或
RET ;子程序返回
DELAY2: ;40ms延时去抖动子程序8FA2=40ms
MOV R5,#08H
L7: MOV R6,#0FAH
L8: DJNZ R6,L8
DJNZ R5,L7
RET
TAB:
DB 0C0H;0
DB 0F9H;1
DB 0A4H;2
DB 0B0H;3
DB 099H;4
DB 092H;5
DB 082H;6
DB 0F8H;7
DB 080H;8
DB 090H;9
DB 088H;A
DB 083H;b
DB 0C6H;C
DB 0A1H;d
DB 086H;E
DB 08EH;F
END
模块化程序设计即模块化设计,简单地说就是程序的编写不是开始就逐条录入计算机语句和指令,而是首先用主程序、子程序、子过程等框架把软件的主要结构和流程描述出来,并定义和调试好各个框架之间的输入、输出链接关系。逐步求精的结果是得到一系列以功能块为单位的算法描述。以功能块为单位进行程序设计,实现其求解算法的方法称为模块化。模块化的目的是为了降低程序复杂度,使程序设计、调试和维护等 *** 作简单化。
简单的说就是用函数封装一个完成某个特定功能的程序块,主函数通过调用这些函数使得编程的整体框架清晰,整个程序的代码量看上去应该像一个三角形,最顶上的是主函数,代码量比大部分调用函数都要少。模块化编程的另一个好处就是功能的复用,比如你的程序里反复需要用到求数组里所有元素的和的 *** 作,就可以建立一个数组求和的函数来反复调用此函数求和。
1、应该分开写,一个在头文件,一个在c文件。如果分要一起,可以用c,但是一定要使用包含include
2、#define uint unsigned int
#define uchar unsigned char
都是宏定义,使用unsighde int替换uint
使用unsigned char 替换uchar。写的不正规,建议采用大写来定义宏。例如:UINT UCHAR
3、中断子程序的内部方法一样,但是调用是由系统做的,所以,你要有开中断语句。或者你自己轮询检测中断标志位也可以。至于开中断语句要具体看你是什么中断。
4、第一个出错原因是中断函数不可以放在头文件中,头文件的内容是在连接的时候一起并入程序的。第二个错误,你可能单词拼写错误,yue这个词。你可以用ctrl+F进行查找。
5、应该注意,不要重复包含。头文件要右#ifndef #define #endif
并入函数尽量只写函数声明,在c里面写函数体。
在c语言里是可以改成c的,但是采用,一个头文件一个定义文件比较好。
意思就是:多余部分,忽视覆盖过程
大哥,你这么折腾,我们都要废了。不能超过20的原因可能是你的FIFO转存器的大小就这么大。超过就溢出了呗
FIFO就是转存器,其实就是存储器,用来缓冲数据的。如果不是溢出问题,那就真不可能了。
首先main()是主函数,order()是被调用的函数,注意order()是个函数!当调用order(x,y);就可以得到ab的顺序。当你把 printf("两个数由小到大的顺序是%d %d\n",x,y);移到主函数中,那么order(x,y);就不是一个完整的函数了,所以才得不到ab的顺序!
至于返回值,只要函数名前加有void 就表示无返回值,其它都有
以上就是关于c语言子程序的写法,子函数main函数写哪,还用写吗全部的内容,包括:c语言子程序的写法,子函数main函数写哪,还用写吗、c语言怎么编写子程序、c语言怎么编写子程序!等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)