但你的程序中存在着几个潜在的错误,这种错误不是任何编译器都能容忍的
一、先看程序的全局变量定义部分,定义了一个无符号整型数值型变量 DA_data
即 int 类型的变量
二、之后的自定义函数中又定义了一个无符号长整型数值型变量 DA_date_buf
即 long 类型变量
三、然而这个函数中,又调用了其它函数,并指定了数据类型为无符号字符型变量
即 char 类型变量
四、在函数中,又对数值型的变量进行了位 *** 作,即右移 *** 作,DA_date_buf>>8
这种类型上的区别,某些编译器可以通过,但某些编译器不能通过,不能通过的编译器,则会发生数据类型错误,有时候编译器是无法判断出问题所在的,即不能提示出具体错在哪里。
解决办法则是:
一、数据要是不大的话,可以全部使用 char 字符型变量,因为只有字符型变量才支持左移和右移的位 *** 作,字符型变量转换成十进制表示,最小数值到最大数值是 0 ~ 254 共255个单位
二、数值比较大的时候,就不要进行位 *** 作,即左移与右移的 *** 作,可以用数值表达式予以替换,即 DA_date_buf=(DA_date_buf + 8)或 DA_date_buf=(DA_date_buf - 8)
我正好最近刚申请了16位DA用于电赛。DAC8552 -
DAC8552:16 位双路电压输出数模转换器
DAC8411 -
采用 SC70 封装的 16 位、单通道、80uA、1.8V-5.5V DAC
DAC8563 -
具有 2.5V、4ppm/°C 基准的 16 位、双路、低功耗、超低短时脉冲波形干扰、缓冲电压输出 DAC
PORTEQU
0CFA0H
定义DAC接口地址
CSEG
AT
4000H
LJMP
START
CSEG
AT
4100H
START:
MOV
DPTR,#PORT+1DAC输出寄存器端口地址送DPTR
MOV
A,#00H
给A赋初值
LOOP:
MOV
B,#0FFH
置计数初值与B
LOOP1:
MOV
DPTR,#PORT
DAC输入寄存器端口地址
MOVX
@DPTR,A
送出数据
INC
DPTR
地址加一
MOVX
@DPTR,A
启动转换
INC
A
数据加一
CJNE
A,#0FFH,LOOP1
如果没到峰值,循环转换
MOV
A,#00H
赋A=0
DJNE
B,LOOP
x显示锯齿波
RET
这是51单片机的
和8086差不多
可根据这个程序修改
纯手打的
包括注释
希望楼主采纳
!!O(∩_∩)O
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)