0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

C编程如何做到完美库化?

GReq_mcu168 来源:未知 作者:佚名 2017-12-01 09:19 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

一个的设备程序如果完美库化,它意味着:

1.所有工程师在移植或创建该设备驱动时,花费的代价超小。

2.随着使用者的增多,它饱经考验,不断趋于稳定,变为当之无愧的公共代码。

3.库对外的接口(函数名及其参数声明)是不变的,当所有常用设备都实现库化时,它带来另外一个好处,应用层的移植、创建、修改维护的时间耗费也会剧烈减少。应用层的跨平台无缝移植不是传说,当它所依赖的所有外围设备通通在不同平台库化的时候,应用层的实现,就像在写java代码一样。

4.库意味这公司核心代码的安全,库代码只掌握在核心工程师手里,应用层的程序即使丢失也是无碍。

5.新人对于这些基于库案子更快上手,一来有库帮助文档的说明,二来不必也无法关心底层细节,专注于应用开发。

6.提供给客户二次开发,你可以把硬件和外设驱动的库交给客户,让其二次开发。

7.通信协议的库化,将使通信系统类的产品更加安全,至少不会被离职的工程师破坏,比如RFID的扣款充值。

8. ......

怎么样,它使老板心动,工程师百味杂陈。

当然,有些工程师会想到,库可以使他脱离繁琐的底层驱动工作,进行更高层次的工作。

库的创建要想搞得好,有以下几个条件

1.提供给客户的只有.h档和.lib档。

2.所有.h档中没有define,编译条件对于.lib档来说只是一个笑话。

3.所有.h档中没有extern变量,如果有,这意味着系统只能创建一个这种设备。比如蜂鸣器驱动,如果extern变量,就意味着整个系统只允许一个蜂鸣器。

4.完善而详细的使用帮助文档。可参考keil的hlp文档格式。

5.简单的使用该.h档的demo程序让人参考。

6.“动态链接”库代码,简言之,没用到的接口函数代码不会被链接器搞到最终的二进制档中。

7.还有一点,尽量的平台无关性,它不依赖于任何寄存器或者其他和平台相关的东西。

要达到上述的目的,通常会使库有如下特点

1.结构体指针

2.大量的回调函数指针。

3.丰富的接口。

4.库源码的.c档将按接口函数拆分成更多的.c档,这为了实现链接时代码空间最小化。

库的缺点也是有的

1.它会使设备速度变慢一些,多了几层间接取址的消耗。但对于32位机,对于它带来的便利,还是可接受的。

2.它会使code空间消耗相对更大一些,但请相信我,对于一整个中大型系统而言,它会使代码量不升反降,因为大系统中有非常多的重复冗余代码。这方面我个人的经验,降的不是一般的多,简直到了一个难以置信的程度。

早期的8位机,51平台上其实不能很好地实现完美的库,至少是不能实现一个跨机型的底层设备驱动库。近年来随着32位机的兴起,库渐渐地受到越来越多工程师的青睐。这里面最本质的原因在于,51架构的栈是静态编译的,局部变量和传参的栈也是静态的,函数无法重入。而多数的32位机都是压栈传参的方式。当然,51速度慢也是重要的原因之一。

如果有熟悉面向对象语言或者linux驱动的朋友,你大概就明白一个好的库是什么样子的了。库就像是面向对象中的类,至于linux底层驱动的代码,那就是函数指针和结构体指针的世界。C的精华在指针,在里面得到完美的诠释。

当然,库的代价也是有的

1.它会使设备速度变慢一些,多了几层取地址的消耗。但对于32位机,对于它带来的便利,还是可接受的。

2.它会使code消耗便大一些,但请相信我,对于一个中大型系统而言,它会使代码不升反降,因为大系统中有非常多的重复冗余代码。


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式开发
    +关注

    关注

    18

    文章

    1172

    浏览量

    50228

原文标题:嵌入式C编程经验细谈: 你库了吗?

文章出处:【微信号:mcu168,微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    探索UPSD3212A/C/CV:集成8032 MCU、USB与可编程逻辑的闪存可编程系统设备

    探索UPSD3212A/C/CV:集成8032 MCU、USB与可编程逻辑的闪存可编程系统设备 在当今的电子设计领域,寻找一款功能强大、性能卓越且能满足多样需求的系统设备至关重要。今
    的头像 发表于 04-17 15:55 202次阅读

    【PCIe 6.0 连载 · 中篇】从设计到实现:高速信号如何做到又快又稳?

    读懂了PCIe6.0的行业价值,接下来更关键的是:64GT/s的高速信号,如何做到稳定传输?上篇我们讲了“为什么需要PCIe6.0”,本篇作为系列中篇,聚焦工程实现核心,拆解PAM4信号的“脆弱性
    的头像 发表于 04-15 17:34 110次阅读
    【PCIe 6.0 连载 · 中篇】从设计到实现:高速信号<b class='flag-5'>如何做到</b>又快又稳?

    线性编程与结构编程的不同点

    线性编程是将整个用户程序连续放置在一个循环程序块(OB1)中,按顺序执行的编程范式。这种结构与PLC所代替的硬接线继电器控制类似,CPU逐条地处理指令,体现了早期PLC编程的简单性和
    的头像 发表于 03-16 16:58 510次阅读
    线性<b class='flag-5'>化</b><b class='flag-5'>编程</b>与结构<b class='flag-5'>化</b><b class='flag-5'>编程</b>的不同点

    光伏电站智慧运维系统核心模块如何做到针对管理?

    光伏电站智慧运维系统的应用,其目的是实现光伏电站全生命周期的智能管理。通过集成物联网、大数据、人工智能等多种技术,进行模块功能应用部署,实现系统智慧运维系统,助力多种类型光伏电站(大型地面电站
    的头像 发表于 01-28 14:34 342次阅读
    光伏电站智慧运维系统核心模块<b class='flag-5'>如何做到</b>针对<b class='flag-5'>化</b>管理?

    瑞萨RA系列FSP开发实战指南之I2C读写EEPROM实验

    使用瑞萨官方提供的FPS进行编程,瑞萨官方提供的FPS具有方便、快捷、简洁的特性。
    的头像 发表于 01-27 10:02 3788次阅读
    瑞萨RA系列FSP<b class='flag-5'>库</b>开发实战指南之I2<b class='flag-5'>C</b>读写EEPROM实验

    与标准C的区别

    因为针对Arm的嵌入式系统,通常存储(代码)资源相对较小,为了使其能用上标准函数,工程师就针对Arm嵌入式系统,对标准C进行了优化,以减小代码量。 优化标准,肯定会带来一些差异,下面分享几点
    发表于 12-09 07:49

    单片机C语言编程的心得

    写这个8*8按键程序的过程中,不管是在自己写还是参考别人程序的过程中,发现自己对C语言有些基本知识点和编程规范有很多不懂的地方,有些是自己以前的编程习惯不好,有些就是基础知识不扎实的表现,所以总结
    发表于 12-08 07:44

    为什么单片机还在用C语言编程

    ,只是C语言是最适合单片机编程的高级语言。 一、单片机编程的特点 1.对单片机编程来说,我们首先要考虑的是单片机的程序空间和数据空间都是有限的,所以我们在编写程序时要尽量
    发表于 11-28 07:37

    C语言的编程技巧

    设计,分层开发代码,便于理解和维护。 ‌8、避免使用GOTO语句‌:尽管GOTO语句在某些情况下仍然有用,但现代编程更倾向于使用函数和循环控制结构,以提高代码的可读性和维护性。 ‌9、利用C语言的灵活性
    发表于 11-27 06:46

    AP6181移植到STM32H723,wifi初始错误怎么解决?

    的sdio驱动,wifi驱动采用潘多拉的drv_wlan.c驱动. 目前遇到的问题是执行wifi_hw_init()后初始失败,目前没有头绪,各位大佬熟悉这块的可以指点下么? 下面附上启动LOGO图
    发表于 09-18 08:20

    技能+1!如何在树莓派上使用C++控制GPIO?

    和PiGPIO等C++可用于编程控制树莓派的GPIO引脚。它提供了更好的性能和控制能力,非常适合对速度和精度要求较高的硬件项目。在树莓派社区中,关于“Python
    的头像 发表于 08-06 15:33 4503次阅读
    技能+1!如何在树莓派上使用<b class='flag-5'>C</b>++控制GPIO?

    在STM32F103c8上做DLQR最优控制算法的C编程资料

    这是我近期做的一个项目--基于STM32F103c8的DLQR控制算法的C编程,涉及DLQR最优控制算法、嵌入式STM32F103编程、CMSIS-DSP
    发表于 07-23 15:30 0次下载

    无感考勤如何做到“无懈可击”?

    无感考勤的核心价值,在于用技术赋能管理。四维慧眼通过精准识别、本地部署与开放生态,为系统集成商和工程商提供高适配、易落地的解决方案,帮助企业实现效率与体验的双重升级。
    的头像 发表于 07-17 18:03 741次阅读

    海康威视以物联感知和人工智能技术助力水利行业数智转型

    汛期堤防隐患如何实现毫米级监测?河湖生态治理如何做到智能预警?大模型技术如何赋能传统水利决策?这场汇聚100+技术单位的行业盛会给出了创新答案。
    的头像 发表于 05-07 10:51 1112次阅读

    单片机c语言编程实例大全

    单片机c语言编程实例大全_18
    发表于 04-30 16:11 7次下载