不知道接下来要学哪方面的知识

[复制链接]
楼主: zhanglli
手机看帖
扫描二维码
随时随地手机跟帖
zhanglli|  楼主 | 2020-8-15 11:19 | 显示全部楼层
可以自己动手做做小东西,比如电子钟,温度计等等,自己画原理图开始一直到写完程序调试出结果,自己整个经历一遍过程。

使用特权

评论回复
wangzsa| | 2020-8-15 11:23 | 显示全部楼层
做些电设的题吧 不要漫无目的的去学习,面太广了 学不过来

使用特权

评论回复
zhuww| | 2020-8-15 11:26 | 显示全部楼层
LZ这种情形建议定个实际的目标,有可操作性,又略有挑战的方案,实际把他做出来,然后调试ok,达到自己预期的目标即可,相信经历过一个实际案子之后,后续该干什么,你就清楚了

使用特权

评论回复
lium| | 2020-8-15 11:29 | 显示全部楼层
大家说得都不错

使用特权

评论回复
llia| | 2020-8-15 11:35 | 显示全部楼层
AVR就算了,个人感觉一直是个**肋

使用特权

评论回复
lium| | 2020-8-15 11:40 | 显示全部楼层
要学的东西太多了,关键看你感兴趣不?如果是为了工作,那你要学的就真的更多了

使用特权

评论回复
guoyt| | 2020-8-15 11:43 | 显示全部楼层

如果是个学生,就看看电子竞赛吧...
上面的每一个回帖都不适合你

使用特权

评论回复
hanwe| | 2020-8-15 11:47 | 显示全部楼层
哥们你要**到底就行啊,找项目,积极参加竞赛吧。

使用特权

评论回复
zhanglli|  楼主 | 2020-8-15 11:52 | 显示全部楼层
多学多做,找个自己合适的方向,认真学,理论和实践都是很重要的,做东西的时候不会就百度,或者加一些相关的交流群,多问问,自然会进步,现在就需要真正有技术的人才

使用特权

评论回复
lium| | 2020-8-15 11:56 | 显示全部楼层
嗯,我知道啦

使用特权

评论回复
guoyt| | 2020-8-15 11:59 | 显示全部楼层
汇编如何实现16进制转10进制

使用特权

评论回复
hanwe| | 2020-8-15 12:02 | 显示全部楼层
通用的懒方法是先编C,再通过编译器开关得到汇编代码

使用特权

评论回复
yufe| | 2020-8-15 12:05 | 显示全部楼层
我想要将一个16进制的数 在液晶上以对应的10进制数显示出来,首先要先转化成10进制数,然后取10进制的百十个位数值 分别加上0x30H 可以在液晶上显示出来,但是遇到的问题是 在汇编里 如何将16进制转化成10进制数呢?

使用特权

评论回复
llia| | 2020-8-15 12:13 | 显示全部楼层
我想到一个问题,在汇编里 如何对一个数除以10求余,并把余数取出来?

使用特权

评论回复
wangpe| | 2020-8-15 12:17 | 显示全部楼层
优化:
char buf[20];
unsigned int num=1234;
sprintf(buf,"%0u",num);
或者
char buf[20];
unsigned int num=1234;
buf[0] = num/1000;
num = num%1000;
buf[1] = num/100;
num = num%100;
buf[2] = num/10;
buf[3] = num%10;

使用特权

评论回复
langgq| | 2020-8-15 12:21 | 显示全部楼层
减法处理(循环)

使用特权

评论回复
wangzsa| | 2020-8-15 12:24 | 显示全部楼层
网上大把的源代码

使用特权

评论回复
zwll| | 2020-8-15 12:38 | 显示全部楼层

51单片机的话就:(假如要显示的16进制数据放在 30H 单元)
程序如下(适用于不大于99的数据):
MOV A,30H
MOV B,#10
DIV  AB
MOV 40H,A  ;十位数字
MOV 41H,B  ;个位数字
...
....               ;显示程序

....

使用特权

评论回复
hanwe| | 2020-8-15 12:53 | 显示全部楼层

07H--->7
17H--->1*16+7=23
47H--->4*16+7=71
1228H--->1*16*16*16+2*16*16+2*16+8=4096+512+32+8=4648

------------看了原理,你应该想到方法了吧。
汇编总该有加法,乘法指令,那么现在主要就是分离出16进制各个BCD码,下面我就不说了,你应该懂的,不懂就看书,书上很多算法的。

使用特权

评论回复
yufe| | 2020-8-15 12:57 | 显示全部楼层

以前写的汇编的,你看有没有用:
;=================BIN--->BCD==========

BCDD  EQU   10H    ;
BIND  EQU   08H    ;需要被转换的二进制数地址
BYTES EQU   04H    ;暂存要转换的二进制数个数

;输入
;R3为二进制的个数
;08 09 0a 0b 0c  十六进制数据输入(0c 为高字节)
;输出
;10 11 12 13 14 15   十进制数  (15 为高字节)

hex_dec:
         MOV    R0,#0
         MOV    R1,#0
         MOV    R2,#0
BINB:
         MOV   BYTES,R3
         MOV   R1,#BCDD
         MOV   R2,BYTES
         INC   R2
         CLR   A
BB0:
         MOV   @R1,A
         INC   R1
         DJNZ  R2,BB0  ;完成十进制数据寄存器清0
         MOV   A,BYTES
         MOV   B,#08H
         MUL   AB      ;统计二进制数据位数
         MOV   R3,A
BB3:
         MOV   R1,#BIND
         MOV   R2,BYTES
         CLR   C
BB1:
         MOV   A,@R1
         RLC   A
         MOV   @R1,A  ;取出原始二进制数带CY左移1位,取出最高位放入CY中
         INC   R1
         DJNZ  R2,BB1
         MOV   R2,BYTES
         INC   R2
         MOV   R1,#BCDD
BB2:
         MOV   A,@R1
         ADDC  A,@R1
         DA    A       ;bcd 校正
         MOV   @R1,A
         INC   R1
         DJNZ  R2,BB2
         DJNZ  R3,BB3
         RET

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则