位操作总结

1. void *memset(void *s, int ch, size_t n);
函数解释:将s中当前位置后面的n个字节 (typedef unsigned int size_t )用 ch 替换并返回 s 。
memset:作用是在一段内存块中填充某个给定的值,它是对较大的结构体或数组进行清零操作的一种最快方法 [1]  。
memset()函数原型是extern void *memset(void *buffer, int c, int count) buffer:为指针或是数组,c:是赋给buffer的值,count:是buffer的长度.
2.考虑对其不同的位进行先后顺序不同的设置,因为这样可能达不到预期的效果,这个不太好总结,但是对寄存器操作的方法是固定的。在这之前,首先要明白逻辑运算符(! && ||)和位运算符(<< >> ~ | ^ &)的区别,对寄存器的操作使用的是位运算符,逻辑运算符一般用于在程序中判断逻辑中使用。

例如 定义一个8位的寄存器(0xf0是寄存器的地址):

define REG 0xF0

1)对单个的位进行赋值 
(1)将寄存器REG的第5位置“1” 
REG |= (1 << 5);

(2)将寄存器REG的第5位清零 
REG &= ~(1 << 5);

(3)将寄存器REG的第3和第5位置“1” 
REG |= (1 << 5) | (1 << 3);

(4)将寄存器REG的第3和5位清零 
REG &= ~( (1 << 5) | (1 << 3) );

该段总结如下: 
将某位置1,移位取反后使用位运算”|” 
将某位置0,移位取反后,使用位运算”&”

2)直接赋值 
(1)将寄存器REG的1、2、3、5、7位置“1” 
REG = 0x5E; 
(即给寄存器REG1赋值为1010 1110,这种方法多在初始化中使用)

(2)分别将寄存器REG的1、3、5、7位置“1”,0、2位置“0” 
u8 temp; 
tmep = REG; 
temp &= ~0x01; //等价于 temp &= ~(1<<0) 将第0位清零 
temp |= (1 << 1); 
temp &= ~(1 << 2); 
temp |= (1 << 3); 
temp |= (1 << 5); 
temp |= (1 << 7); 
REG = temp;

3.位操作

首先注意 |(按位或)和&(按位与)的基本操作:或1置1,与0置0

其次注意读法(没错,是读法!)。由于|和&运算均是左结合性,因此需要从左向右读,
例如:

RCC -> AHB1ENR |= 1<<2;

上述代码的1<<2 应该读作1向左移动2位,即AHB1ENR寄存器的第2位置1。


GPIOC -> MODER &= ~(3<<(11*2));
上述代码应读作3左移22位,什么意思呢,也就是11(十进制的3 == 二进制的11)左移22位,即第22位、第23位置0。
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值