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

    文章

    1030

    浏览量

    47594

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

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

收藏 人收藏

    评论

    相关推荐

    蓝牙AOA定位系统如何做到高精准度?

    蓝牙AOA定位系统是一种高精度的室内定位技术,其高精准度是通过一系列高科技的技术和方法实现的。以下是给大家分析的几点关于如何做到高精准度的几个关键点:
    的头像 发表于 12-13 11:42 139次阅读

    ADC7846如何做到使用手指触摸有效?

    ADC7846芯片触摸转换时候,不准,能否通过配置,如何做到使用手指触摸有效?
    发表于 12-04 06:47

    如何快速入门HAL编程 HAL与裸机编程的比较

    如何快速入门HAL编程 要快速入门HAL编程,可以遵循以下步骤: 了解基础知识 : 掌握C语言编程
    的头像 发表于 12-02 11:39 329次阅读

    两个高速ADC的CLK时钟如何做到同步无相位差?

    如何做到同步无相位差,两个ADC使用同一个时钟发生器是否可以满足同步问题? 2、两个高速ADC的CLKOUT是否存在时延,如果存在那相位差是多少?我再规格书中没有看到CLKOUT引脚关于这方面的描述
    发表于 11-18 06:47

    工程行业中如何做到低碳甚至零碳

    低碳的生活方式越来越多地融入我们的日常习惯当中。但是在工程行业中如何做到低碳甚至零碳呢?
    的头像 发表于 10-14 10:31 429次阅读

    TPA3251如何做到180W的功率,电压12V,电流应该多少?

    TPA3251如何做到180W的功率,电压12V,电流应该多少,请推荐DCDC
    发表于 10-11 06:54

    请问使用lwip创建socket,该如何做到非阻塞的接收发送数据?

    请问使用lwip创建socket,该如何做到非阻塞的接收发送数据?
    发表于 06-19 06:02

    PLC编程语言和C语言的区别

    在工业自动和计算机编程领域中,PLC(可编程逻辑控制器)编程语言和C语言各自扮演着重要的角色。尽管两者都是
    的头像 发表于 06-14 17:11 2869次阅读

    c语言怎么做可视界面

    C语言是一种通用的编程语言,广泛应用于系统编程、嵌入式开发等领域。虽然C语言本身并不支持直接创建可视界面,但通过结合一些图形
    的头像 发表于 06-06 10:46 2376次阅读

    STM32在PWM输出模式中,如何做到PWM移向输出?

    在PWM输出模式中,如何做到PWM移向输出?在DSP中有时基相位寄存器,可以移向配置占空比。但是好像没有发现STM32单片机有类似的寄存器功能。请问各位大神是否有其他方法可以实现PWM移向输出呢?
    发表于 05-15 06:02

    多路电源并联输出如何做到均流不倒灌?

    如果负载所需要的功率较大,单独一路供电又满足不了需求,但是有暂时没有大的供电电源,那么是如何做到两个或者多个同样的电源做到相等输出均流不倒灌呢?有什么办法解决,其原理是什么? 举例,在两个LDO输出
    发表于 04-27 22:54

    基于原生libbpf的eBPF编程改进方案

    为了简化 eBPF程序的开发流程,降低开发者在使用 libbpf 时的入门难度,libbpf-bootstrap 框架应运而生。基于libbpf-bootstrap框架的编程方案是目前网络上看到的最主流编程方案。
    发表于 03-19 14:19 676次阅读
    基于原生libbpf<b class='flag-5'>库</b>的eBPF<b class='flag-5'>编程</b>改进方案

    光伏户用如何做到低成本获客?

    光伏户用如何做到低成本获客? 随着可再生能源的日益普及和技术的不断进步,光伏系统正逐渐走进千家万户。然而,对于光伏企业来说,如何在激烈的市场竞争中低成本地获取客户,成为了他们面临的一大挑战。本文将
    发表于 02-27 10:33

    RF模组sleep状态下如何做到最低功耗?

    的。那么如何解决呢?本文将对RF模组在Sleep状态下如何做到最低功耗进行说明。RF模组sleep时RF模组的IO状态先要获知RF模组Sleep时,RF模组的IO
    的头像 发表于 01-06 08:13 494次阅读
    RF模组sleep状态下<b class='flag-5'>如何做到</b>最低功耗?

    工业级连接器如何做到高抗冲击性?选款一定要了解这几点

    连接器知识分享工业级连接器多用在工厂、车载、户外等复杂场景下,因而面临冲击等应力影响的概率极高。工业级连接器如何做到高抗冲击性,确保高可靠连接呢?这篇文章讲清楚。工业级连接器如何做到高抗冲击性?LP
    的头像 发表于 01-06 08:13 384次阅读
    工业级连接器<b class='flag-5'>如何做到</b>高抗冲击性?选款一定要了解这几点