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。