STM32的C与汇编语言混合编程

一.创建项目

创建一个Keil5项目,并新建.c和.s文件,在此不多做赘述。
在这里插入图片描述

分别写入下列代码

  • main.c
# include<stdio.h>

extern void	Init_1(void);

int main(){
	
	Init_1();
	
	return 0;
}


  • Func.s

	AREA	MY_FUNCTION,CODE,READONLY
	EXPORT 	Init_1  ; 与在c文件中定义的Init_1函数关联起来


; 高级语言中的声明和使用变量其实是对板子寄存器的使用,所以我们只需要直接使用寄存器即可

Init_1

	MOV R1,#0     ; 设R1寄存器为i
	MOV R2,#0	  ; 设R2寄存器为j
	
LOOP	; 写在最左边的是程序段的段名,执行跳转程序时用到
	CMP R1,#10	  ; 比较R1和10的大小
	BHS LOOP_END  	  ; 如果R1大于等于10,则跳转到LOOP_END程序段,反之忽略该语句,直接执行下面的语句
	ADD R2,#1	  ; j++
	ADD R1,#1     ; i++
	B LOOP		  ; 循环
	
LOOP_END
	NOP	
	
	END  ; 必须空格后再写END,不然会被认为是段名,表示程序结束

选择魔法棒,选择Debug,勾选Use Simulator,将左下角的Dialog DLL中的内容改为DARMSTM.DLL,将Parameter的内容改为-pSTM32F103C8:
在这里插入图片描述

二.无参数调试

然后点击调试按钮,进入调试页面:

在这里插入图片描述
然后点击单步运行,一边点击一边观察。
在这里插入图片描述
R1和R2的最终值固定在十六进制的A,相当于十进制的10。与预先估计值相同。

三.有参数调试

修改代码:

  • main.c
# include<stdio.h>

extern int Init_1(int x);

int main(){
	
	int xx = Init_1(10);
	printf("%d", xx);
	
	return 0;
}

  • Func.s

	AREA	MY_Function,CODE,READONLY
	EXPORT 	Init_1  ; 与在c文件中定义的Init_1函数关联起来


; 高级语言中的声明和使用变量其实是对板子寄存器的使用,所以我们只需要直接使用寄存器即可

Init_1
	ADD R0,#100     ; 将传入的值+100
	MOV PC,LR		; 返回R0
	
	
LOOP	; 写在最左边的是程序段的段名,执行跳转程序时用到
	CMP R1,#10	  ; 比较R1和10的大小
	BHS LOOP_END  	  ; 如果R1大于等于10,则跳转到LOOP_END程序段,反之忽略该语句,直接执行下面的语句
	ADD R2,#1	  ; j++
	ADD R1,#1     ; i++
	B LOOP		  ; 循环
	
LOOP_END
	NOP	
	
	
	END  ; 必须空格后再写END,不然会被认为是段名,表示程序结束

在ARM中,子函数的参数值传递按顺序存放在r0,r1,r2,r3里,超过4个参数值传递放栈帧里。

因此Init_1(10)传入的10放到了R0,由MOV PC,LR返回110.

单击单步调试,在单击一次后,R0的初始值为A。

在这里插入图片描述
点击几次后,R0变成了6E,符合预期。
在这里插入图片描述

三、汇编语言调用C函数

修改代码:

  • main.c
# include<stdio.h>

extern void	Init_1(void);

int get5(void);

int main(){
	
	printf("Begin...\n");
	Init_1();

	
	return 0;
}

int get5(){
	return 5;
}


  • Func.s

	AREA	MY_Function,CODE,READONLY
	EXPORT 	Init_1  ; 与在c文件中定义的Init_1函数关联起来
	IMPORT  get5    ; 声明get5 为外部引用


; 高级语言中的声明和使用变量其实是对板子寄存器的使用,所以我们只需要直接使用寄存器即可

Init_1

	MOV R1,#0     ; 设R1寄存器为i
	MOV R2,#0	  ; 设R2寄存器为j
	
LOOP	; 写在最左边的是程序段的段名,执行跳转程序时用到
	CMP R1,#10	  ; 比较R1和10的大小
	BHS LOOP_END  	  ; 如果R1大于等于10,则跳转到LOOP_END程序段,反之忽略该语句,直接执行下面的语句
	ADD R2,#1	  ; j++
	ADD R1,#1     ; i++
	BL get5  	  ; 调用get5,返回的值传入R0
	B LOOP		  ; 循环
	
LOOP_END
	NOP	
	
	
	END  ; 必须空格后再写END,不然会被认为是段名,表示程序结束

编译并调试:
在这里插入图片描述
可发现,执行get5后,R0变为了5,符合预期。

### 如何在 Element UI 的 `el-table` 中根据字段动态设置单元格背景颜色Element UI 的 `el-table` 组件中,可以通过 `row-class-name` 或者 `cell-style` 属性来实现基于字段的动态单元格背景颜色设置。以下是具体方法: #### 方法一:通过 `row-class-name` 可以在 `<el-table>` 上绑定 `row-class-name` 属性,并提供一个回调函数,在该函数中返回不同的类名以区分不同行的颜色。 ```vue <template> <el-table :data="tableData" :row-class-name="tableRowClassName"> <el-table-column prop="date" label="日期"></el-table-column> <el-table-column prop="name" label="姓名"></el-table-column> <el-table-column prop="status" label="状态"></el-table-column> </el-table> </template> <script> export default { data() { return { tableData: [ { date: '2023-10-01', name: '张三', status: '正常' }, { date: '2023-10-02', name: '李四', status: '异常' } ] }; }, methods: { tableRowClassName({ row }) { if (row.status === '异常') { return 'error-row'; } else { return ''; } } } }; </script> <style scoped> .error-row { background-color: #f56c6c !important; } </style> ``` 上述代码中,当某一列的状态字段为“异常”时,对应的整行会被赋予红色背景[^1]。 --- #### 方法二:通过 `cell-style` 如果只需要针对特定单元格而不是整个行进行样式修改,则可以使用 `cell-style` 属性。它接受一个对象或者一个函数作为参数。 ```vue <template> <el-table :data="tableData" :cell-style="cellStyle"> <el-table-column prop="date" label="日期"></el-table-column> <el-table-column prop="name" label="姓名"></el-table-column> <el-table-column prop="status" label="状态"></el-table-column> </el-table> </template> <script> export default { data() { return { tableData: [ { date: '2023-10-01', name: '张三', status: '正常' }, { date: '2023-10-02', name: '李四', status: '异常' } ] }; }, methods: { cellStyle({ row, column }) { if (column.property === 'status' && row[column.property] === '异常') { return { backgroundColor: '#f56c6c' }; // 设置单元格背景色 } return {}; } } }; </script> ``` 此方法允许更细粒度地控制每个单元格的样式,而不仅仅是影响整行[^2]。 --- #### 注意事项 1. **优先级问题** 如果同时设置了全局 CSS 和局部样式的覆盖逻辑,请注意样式优先级可能会影响最终效果。通常建议使用 `!important` 来提高自定义样式的权重[^3]。 2. **性能优化** 对于大规模数据表,频繁调用样式计算可能会带来一定的性能开销。因此推荐结合虚拟滚动技术(如 `el-table-v2`),减少 DOM 渲染压力[^4]。 3. **兼容性测试** 不同浏览器对某些特殊样式的解析可能存在差异,务必进行全面的跨平台验证[^5]。 --- ### 示例总结 以上两种方式分别适用于行级别和单元格级别的样式定制需求。开发者可以根据实际场景灵活选用合适的方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值