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

  • 相关阅读:
    Spring的事务 之 9.4 声明式事务 ——跟我学spring3
    我对AOP的理解
    基于JDK动态代理和CGLIB动态代理的实现Spring注解管理事务(@Trasactional)到底有什么区别。
    我对IoC/DI的理解
    Spring对事务管理的支持的发展历程(基础篇)
    Tomcat一个BUG造成CLOSE_WAIT
    用dubbo时遇到的一个序列化的坑
    只写完功能代码仅仅只是开始
    事物隔离级别和乐观锁
    关于ubuntu实机与虚机互相copy
  • 原文地址:https://www.cnblogs.com/rockyching2009/p/13112831.html
Copyright © 2020-2023  润新知