DATA:7-16
__set_FAULTMASK(1); //关闭所有中断
NVIC_SystemReset(); //系统复位
size_t strlen(const char *s);
返回s的长度,不包括结束符
strlen() function calculates the length of the string s, excluding the terminating null byte ('\0')
strlen() function isthread-safe
char *strstr(const char *haystack, const char *needle);
从字符串haystack中查找是否有字符串needle,如果有,从haystack中的needle位置起,返回haystack中needle起始位置的指针,如果没有,返回NULL
These functions return a pointer to the beginning of the located substring, or NULL if the substring is not found
strstr() function isthread-safe
int strcmp(const char *s1, const char *s2);
比较字符串s1和s2,当s1==s2时,返回值= 0;当s1<s2时,返回值小于0,当s1>s2时,返回值大于0
strcmp() function isthread-safe
int strncmp(const char *s1, const char *s2, size_t n);
比较字符串s1和s2的前n个字符,返回值同 strncmp()
strncmp() function isthread-safe
char *strcpy(char *dest, const char *src);
把从src地址开始的字符串复制到以dest开始的地址空间(包含'\0'),src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串,返回指向dest的指针
char *strncpy(char *dest, const char *src, size_t n);
复制src中的前n个内容到dest,返回指向dest的指针
注:如果复制的src中前n个字符没有结束符,则dest中的内容也不含结束符!
char *strcat(char *dest, const char *src); // dest参数必须是足够大的数组!
把src所指字符串添加到dest结尾处(覆盖dest结尾处的'\0')并添加'\0'
char *strncat(char *dest, const char *src, size_t n);
把src所指字符串的前n个字符添加到dest结尾处(覆盖dest结尾处的'\0')并添加'\0',src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串
int sprintf(char *str, const char *format, ...);
格式化的数据写入某个字符串缓冲区
int sscanf(const char *str, const char *format, ...);
参数str的字符串根据参数format字符串来转换并格式化数据
char buf[512] = ;
sscanf("123456 ", "%s", buf);
printf("%s\n", buf);
结果为:123456
void *memset(void *s, int c, size_t n);
将s中前n个字节(typedef unsigned int size_t)用 ch 替换并返回s,作用是在一段内存块中填充某个给定的值,它是对较大的结构体或数组进行清零操作的一种最快方法
memset() function returns a pointer to the memory area s
void *memcpy(void *dest, const void *src, size_t n);
从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中
memcpy() function returns a pointer to dest
strcpy和memcpy主要有以下3方面的区别:
1、复制的内容不同。strcpy只能复制字符串,而memcpy可以复制任意内容,例如字符数组、整型、结构体、类等
2、复制的方法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符"\0"才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度
3、用途不同。通常在复制字符串时用strcpy,而需要复制其他类型数据时则一般用memcpy
int atoi(constchar *nptr);
参数nptr字符串,如果第一个非空格字符存在,是数字或者正负号则开始做类型转换,之后检测到非数字(包括结束符 \0) 字符时停止转换,返回整型数。否则,返回零
char *itoa(intvalue, char *string, int radix);
int value 被转换的整数,char *string 转换后储存的字符数组,int radix 要转换成的进制数,如2,8,10,16 进制等
DATA:7-18
strlen和sizeof有什么区别:
1、sizeof操作符的结果类型是unsigned int类型,保证能容纳所建立的最大对象的字节大小
2、sizeof是关键字,strlen是函数
3、sizeof可以用类型做参数,strlen只能用char*做参数,且必须是以''\0''结尾的
sizeof还可以用函数做参数,比如:
short f();
printf("%d\n", sizeof(f()));
输出的结果是sizeof(short),即2
4、数组做sizeof的参数不退化,传递给strlen就退化为指针了
5、大部分编译程序在编译的时候就把sizeof计算过了,是类型或是变量的长度这就是sizeof(x)可以用来定义数组维数的原因
char str[20]="0123456789";
int a = strlen(str); //a=10;计算字符串的长度,以结束符’\0’为字符串结束
int b = sizeof(str); //b=20;计算的则是分配的数组str[20]所占的内存空间的大小
6、strlen的结果要在运行的时候才能计算出来,时用来计算字符串的长度,不是类型占内存的大小
7、sizeof后如果是类型必须加括弧,如果是变量名可以不加括弧。这是因为sizeof是个操作符不是个函数
8、当适用了于一个结构类型时或变量,sizeof 返回实际的大小
9、数组作为参数传给函数时传的是指针而不是数组,传递的是数组的首地址,如:
fun(char [8])
fun(char [])
都等价于fun(char *)
DATA:7-25
STM32的内部闪存地址起始于0x8000000,一般情况下,程序文件就从此地址开始写入。此外STM32是基于Cortex-M3内核的微控制器,其内部通过一张“中断向量表”来响应中断,程序启动后,将首先从“中断向量表”取出复位中断向量执行复位中断程序完成启动。而这张“中断向量表”的起始地址是0x8000004,当中断来临,STM32的内部硬件机制亦会自动将PC指针定位到“中断向量表”处,并根据中断源取出对应的中断向量执行中断服务程序。最后还需要知道关键的一点,通过修改STM32工程的链接脚本可以修改程序文件写入闪存的起始地址。
IAP是一种对通过微控制器的对外接口(如USART,IIC,CAN,USB,以太网接口甚至是无线射频通道)对正在运行程序的微控制器进行内部程序的更新的技术(注意这完全有别于ICP或者ISP技术)。ICP(In-Circuit Programming)技术即通过在线仿真器对单片机进行程序烧写,而ISP技术则是通过单片机内置的bootloader程序引导的烧写技术。无论是ICP技术还是ISP技术,都需要有机械性的操作如连接下载线,设置跳线帽等。若产品的电路板已经层层密封在外壳中,要对其进行程序更新无疑困难重重,若产品安装于狭窄空间等难以触及的地方,更是一场灾难。