C语言高级编程技巧.ppt

C语言高级编程技巧.ppt

ID:49479207

大小:122.00 KB

页数:14页

时间:2020-02-25

C语言高级编程技巧.ppt_第1页
C语言高级编程技巧.ppt_第2页
C语言高级编程技巧.ppt_第3页
C语言高级编程技巧.ppt_第4页
C语言高级编程技巧.ppt_第5页
资源描述:

《C语言高级编程技巧.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、C语言高级编程技巧段博C与面向对象C语言是应用非常广泛的一门编程语言,特别是在嵌入式领域,更是占据着不可替代的位置。面向对象程序设计把数据和对数据的操作封装在一起构成类,由类来产生对象,由对象来构建程序。通过继承、多态等机制大大增强软件的可重用性和可维护性。将面向对象概念引入C语言编程过程具有重要意义。面向对象特性在C语言中的实现—封装性封装:C语言可以实现struct,这个与类非常接近。封装的产物就是类,其实例便是对象。对于属性,struct内部可以包含任何类型的数据成员作为对象的属性;但是,struct内

2、部不能有函数成员,却可以有函数指针,通过函数指针指向成员函数。面向对象特性在C语言中的实现—封装性(2)举个例子,下面的结构GTKObjectClass就可以看成一个类,其中flag是成员变量,三个函数指针是成员函数。struct_GtkObjectClass{guint32flag;void(*set_arg)(GtkObject*object,GtkArg*arg,guintarg_id);void(*get_arg)(GtkObject*object,GtkArg*arg,guintarg_id);vo

3、id(*destroy)(GtkObject*object);};面向对象特性在C语言中的实现—继承性继承:复用已经定义的操作。C语言不支持继承,但struct可以实现组合(Composition),可以先定义一个“父”struct,然后定义一个“子”struct,在“子”struct中添加其特有的属性和方法指针,这样就模拟了继承。面向对象特性在C语言中的实现—继承性(2)举个例子,GTK+中有一个类GtkObject,它是所有其他类的父类。GTK+中最常用的按钮控件也是一个类GtkButton,它继承自Gt

4、kObject。它与GtkObject的继承关系是:GtkObject->GtkWidget->GtkContainer->GtkBin->GtkButton面向对象特性在C语言中的实现—继承性(3)在GTK中实现如下:structGtkObject{......}structWidget{GtkObjectobject;......}structGtkContainer{GtkWidgetwidget;......};structGtkBin{GtkContainercontainer;......};st

5、ructGtkButton{GtkBinbin;......};面向对象特性在C语言中的实现—多态性多态:用一个经典的英文解释就是Avaluebelongtomultipletypes.即一个值属于多种类型。C语言中可以使用强制类型转换实现多态性,但要求父类结构体数据必须位于子类结构体数据的开始。面向对象特性在C语言中的实现—多态性(2)以创建一个ButtonWidget为例:GtkWidget*button;button=gtk_button_new_with_label("HelloWorld");g_s

6、ignal_connect(G_OBJECT(button),"clicked",G_CALLBACK(hello),NULL);button声明为GtkWidget类型的指针,用gtk_button_new_with_lable创建一个GtkButton;G_OBJECT是一个宏,完成强制类型转换,这里将button从GtkWidget类型转换成GObject类型。C编程-链表的操作链表的操作(2)Linux内核链表中几个重要的宏【1】#defineinit_list_head(ptr)do{(ptr)-

7、>next=(ptr);(ptr)->prev=(ptr);}while(0)代码中为何使用do{…}while(0)?链表的操作(3)【2】#definelist_entry(ptr,type,member)((type*)((unsignedlong)(ptr)-((unsignedlong)(&((type*)0)->member)链表的操作(3)【3】#definelist_for_each(pos,head)for((pos)=(head)->next;(pos)!=(head);(po

8、s)=(pos)->next)【4】#definelist_for_each_safe(pos,n,head)for((pos)=(head)->next,n=(pos)->next;(pos)!=(head);(pos)=n,n=(pos)->next)【3】与【4】功能有何不同?谢谢!

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。