使用芯片stm32f103zet6和stm32l151c8t6,在移植程序时发现,编译器提示u8未定义: 在Keil MDK 开发环境里,st定义无符号32位整形数据有很多种表示方法: 1 unsigned int 32——标准写法: 2 uint32_t ;  3 u32;  三种方式都是在表达同一个意思. 其实ST之所以这样多种方式表示同一个值,主要是减少代码编写工作量,同时也是为了向下兼容旧版本的程序.使用typedef多次重新定义罢了,关于这些定义可以看下面几个文件:core_cm4.h…
转:http://stackoverflow.com/questions/11382057/declaring-a-delegate-protocol There definitely are subtle differences. If the protocol you are talking about is a delegate that is used by one particular class, for example, MySpecialViewController, and M…
下面为string.h文件中函数的详细用法: strcpy函数名:strcpy功 能: 拷贝一个字符串到另一个用 法: char *strcpy(char *destin, char *source); strncpy函数名:strncpy原型:char *strncpy(char *dest, char *src,size_tn);功能:将字符串src中最多n个字符复制到字符数组dest中(它并不像strcpy一样遇到NULL才停止复制,而是等凑够n个字符才开始复制),返回指向dest的指针.…
一.".h"文件必须以如下格式书写 例:文件<CZ_efg_hi.h"> ------------文件内容----------- #ifndef CZ_Efg_Hi_H #define CZ_Efg_Hi_H ..... 所有文件内容 ..... #endif --------------------------------- 二.全局变量 在".h"文件中声明,在".c"文件中定义及初始化 例:某2个全局变量 小型程序中…
今天在头文件.h中初始化了一个数组和函数,在编译的时候提示这个数组和函数重新定义了,检查后发现,犯了一个致命的错误,在头文件中定义变量... 以下引用别人的一篇说明,警示自己. C语言作为一种结构化的程序设计语言,在模块的划分上主要依据功能,C语言模块化程序设计需理解如下概念: (1) 模块即是一个.c文件和一个.h文件的结合,头文件(.h)中是对于该模块接口的声明: (2) 某模块提供给其它模块调用的外部函数及数据需在.h中文件中冠以extern关键字声明: (3) 模块内的函数和全局变量需在…
今天写了一个简单的类,定义在 .h 文件中, 类很简单就将其成员函数定义在了一起(class类后面).运行的时候出现了如下图所示的编译错误(error LNK2005) 查资料,大部分都是说需要加上 #pragma once  防止重定义,但是我之前就加了的,明显不是这个问题.耽搁了会儿,想到可以把函数实现放到 cpp 文件试试,果然放到 cpp 中就好使了.…
不知道大家有没有批量删除c文件和h文件中注释的需要,说起来搞笑,偶然翻出来早先写的一份,首先楼猪不是闲的蛋疼写这东西,工作需要,哪里要砖就要搬.冷门的东西大家需要的时候也不一定好找,分享给大家,省的自己写了. https://github.com/songjinli/deletenote 放心不会删除代码,可以指定删除文件或者目录下所有文件,不会覆盖当前文件,会生成一个以时间戳命名的备份.(还是建议大家自己做好一个备份,以防不测....) 可以删除所有的注释类型,如: 1. printf("%d…
KEIL中,在".H"文件定义变量. 如果该".H"文件同时被两个".C"文件调用,则会出现重复定义错误(*** ERROR L104: MULTIPLE PUBLIC DEFINITIONS).显而易见嘛,".H"文件被调用了两次,则等于里面的变量被定义了两次.所以不要再H文件中定义文件,而要定义在C中. 在OLED的例程中,在一个叫"LCD.H"的文件中保存了图片的模,不产生错误的原因是该文件只被一个C…
time.h头文件中包含以下函数 char* asctime(const struct tm *tm); char* asctime_r(const struct tm *tm,char *buf); char* ctime(const time_t *timep); char* ctime_r(const time_t *timep,char *buf); struct tm *gmtime(const time_t *timep); struct tm *gmtime_r(const tim…
当你不使用这个模板函数或模板类,编译器并不实例化它,当你使用时,编译器需要实例化它,因为编译器是一次只能处理一个编译单元,也就是一次处理一个cpp文件,所以实例化时需要看到该模板的完整定义.所以都放在头文件中. 这不同于普通的函数,在使用普通函数时,编译时只需看到该函数的声明即可编译,而在链接时由链接器来确定该函数的. 其实模板实现不能放在cpp文件中,主要是cpp在c++编译期间不能决定模板参数的类型,所以不能生成模板函数的实例,所以它会把模板类型带到链接期间,如果这个期间有函数调用了该实例,…