【笔记】2013-07

受不了xxxx恶心人的行为,遂搬迁至博客园。
始发:2014-03-06 13:24:53

此为作者学习工作中的笔记,多有网搜资料;故,若侵权,请告知,第一时间删除。

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 ('').

strlen() function is thread-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 is thread-safe.

int strcmp(const char *s1, const char *s2);

比较字符串s1和s2,当s1==s2时,返回值= 0;当s1<s2时,返回值小于0,当s1>s2时,返回值大于0。

strcmp() function is thread-safe.

int strncmp(const char *s1, const char *s2, size_t n);

比较字符串s1和s2的前n个字符,返回值同 strncmp()。

strncmp() function is thread-safe.

char *strcpy(char *dest, const char *src);

把从src地址开始的字符串复制到以dest开始的地址空间(包含''),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结尾处的'')并添加''。

char *strncat(char *dest, const char *src, size_t n);

把src所指字符串的前n个字符添加到dest结尾处(覆盖dest结尾处的'')并添加'',src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。

int sprintf(char *str, const char *format, ...);

格式化的数据写入某个字符串缓冲区。

int sscanf(const char *str, const char *format, ...);

参数str的字符串根据参数format字符串来转换并格式化数据。

void *memset(void *s, int c, size_t n);

将s中前n个字节(typedef unsigned int size_t)用 c 替换并返回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方面的区别:

  • 复制的内容不同。strcpy只能复制字符串,而memcpy可以复制任意内容,例如字符数组、整型、结构体、类等。
  • 复制的方法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符""才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度。
  • 用途不同。通常在复制字符串时用strcpy,而需要复制其他类型数据时用memcpy。
int atoi(constchar *nptr);

参数nptr字符串,如果第一个非空格字符存在,是数字或者正负号则开始做类型转换,之后检测到非数字(包括结束符 ) 字符时停止转换,返回整型数。否则,返回零。

char *itoa(int value, char *string, int radix);

value 被转换的整数,string 转换后储存的字符数组,int radix 要转换成的进制数,如2,8,10,16 进制等。

DATA:7.18

strlen和sizeof有什么区别:

  • sizeof操作符的结果类型是 size_t 类型,保证能容纳所建立的最大对象的字节大小
  • sizeof是宏定义,strlen是函数
  • sizeof可以用类型做参数,strlen只能用char*做参数,且必须是以''''结尾的
  • 数组做sizeof的参数不退化,传递给strlen就退化为指针了
  • 大部分编译程序在编译的时候就把sizeof计算过了,是类型或是变量的长度这就是sizeof(x)可以用来定义数组维数的原因
char str[20]="0123456789";
int a = strlen(str); //a=10;计算字符串的长度,以结束符’’为字符串结束
int b = sizeof(str); //b=20;计算的则是分配的数组str[20]所占的内存空间的大小
  • strlen的结果要在运行的时候才能计算出来,时用来计算字符串的长度,不是类型占内存的大小
  • sizeof后如果是类型必须加括弧,如果是变量名可以不加括弧。这是因为sizeof是个操作符不是个函数
  • 当适用于一个结构类型时或变量,sizeof 返回实际的大小

数组作为参数传给函数时传的是指针而不是数组,传递的是数组的首地址,如:

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技术,都需要有机械性的操作如连接下载线,设置跳线帽等。若产品的电路板已经层层密封在外壳中,要对其进行程序更新无疑困难重重,若产品安装于狭窄空间等难以触及的地方,更是一场灾难。

原文地址:https://www.cnblogs.com/rockyching2009/p/13112831.html