在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線(xiàn)課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

C語(yǔ)言的基本知識(shí)、特征和面向?qū)ο笤斀?/h1>

基礎(chǔ)知識(shí)

結(jié)構(gòu)體

除了提供基本數(shù)據(jù)類(lèi)型外,C 語(yǔ)言還提供給用戶(hù)自己定制數(shù)據(jù)類(lèi)型的能力,那就是結(jié)構(gòu)體,在 C 語(yǔ)言中,你可以用結(jié)構(gòu)體來(lái)表示任何實(shí)體。結(jié)構(gòu)體正是面向?qū)ο笳Z(yǔ)言中的類(lèi)的概念的雛形,比如:

typedef struct{

float x;

float y;

}Point;

定義了一個(gè)平面坐標(biāo)系中的一個(gè)點(diǎn),點(diǎn)中有兩個(gè)域,x 坐標(biāo)和 y 坐標(biāo)。

結(jié)構(gòu)體中的域稱(chēng)為結(jié)構(gòu)體的成員。結(jié)構(gòu)體中的數(shù)據(jù)類(lèi)型可以是簡(jiǎn)單數(shù)據(jù)類(lèi)型,也可以是其他的結(jié)構(gòu)體,甚至結(jié)構(gòu)體本身還可以嵌套,比如,一個(gè)標(biāo)準(zhǔn)的鏈表結(jié)構(gòu)可以進(jìn)行如下定義:

typedef struct node{

void *data;// 數(shù)據(jù)指針

int dataLength;// 數(shù)據(jù)長(zhǎng)度

struct node *next;// 指向下一個(gè)節(jié)點(diǎn)

}Node;

可以看到,結(jié)構(gòu)體 node 中的 next 指針的類(lèi)型又是 node 類(lèi)型。

函數(shù)指針

指針是 C 語(yǔ)言的靈魂,是 C 比其他語(yǔ)言更靈活,更強(qiáng)大的地方。所以學(xué)習(xí) C 語(yǔ)言必須很好的掌握指針。函數(shù)指針,即指向函數(shù)在內(nèi)存映射中的首地址的指針,通過(guò)函數(shù)指針,可以將函數(shù)作為參數(shù)傳遞給另一個(gè)函數(shù),并在適當(dāng)?shù)臅r(shí)候調(diào)用,從而實(shí)現(xiàn)異步通信等功能。

比如, UNIX/Linux 系統(tǒng)中的信號(hào)注冊(cè)函數(shù),其原型如下:

void (*signal(int signo,void (*func)(int))) (int)

使用的時(shí)候,需要自己在外部定義一個(gè)信號(hào)處理函數(shù) (signal handler), 然后使用 signal(sigNo, handler) 將處理程序注冊(cè)在進(jìn)程上,當(dāng)信號(hào)發(fā)生時(shí),進(jìn)程就可以回調(diào)信號(hào)處理函數(shù)。

將函數(shù)指針作為結(jié)構(gòu)體的成員

正如前面提到的,結(jié)構(gòu)體的成員可以是簡(jiǎn)單的數(shù)據(jù)結(jié)構(gòu),也可以是其他的結(jié)構(gòu)體,當(dāng)然,也可以是指針。當(dāng)將函數(shù)指針作為結(jié)構(gòu)體的成員,并且這些函數(shù)只用來(lái)操作本結(jié)構(gòu)體中的數(shù)據(jù)時(shí),就可以形成一個(gè)獨(dú)立的實(shí)體,這個(gè)實(shí)體中既有數(shù)據(jù),也有對(duì)數(shù)據(jù)的操作,這樣自然就可以引出類(lèi)(class)的概念。

面向?qū)ο笳Z(yǔ)言的特性

一般而言,繼承,封裝和多態(tài)被認(rèn)為是面向?qū)ο笳Z(yǔ)言所必須支持的三種特征,也正是通過(guò)這三種特征才可以體現(xiàn)出面向?qū)ο笤谀男┓矫鎯?yōu)于面向過(guò)程。由于語(yǔ)言開(kāi)發(fā)商的宣傳或其他的各種原因,使的表面上面向?qū)ο蟮乃枷胍ㄟ^(guò)語(yǔ)言為載體而得以實(shí)現(xiàn),然而實(shí)際上,面向?qū)ο笫且环N軟件設(shè)計(jì)思想,完全是可以與具體實(shí)現(xiàn)無(wú)關(guān)的。

雖然如此,但是不可否認(rèn),這些所謂的純面向?qū)ο蟮恼Z(yǔ)言,在其代碼的可讀性以及與人的自然思維的匹配方面,比面向過(guò)程的語(yǔ)言要好的多。

語(yǔ)言層次的面向?qū)ο?/p>

我們一般要描述一個(gè)對(duì)象,一般需要描述這個(gè)對(duì)象的一些屬性,比如盒子(box) 是一個(gè)實(shí)體,它有 6 個(gè)面,有顏色,重量,是否為空等屬性,并且可以放東西進(jìn)去,可以取東西出來(lái)。在面向?qū)ο蟮恼Z(yǔ)言中,通常將這樣的對(duì)象抽象成一個(gè)類(lèi) (class):

class Box{

clolr color;

int weight;

boolean empty;

put(something);

something get();

}

對(duì)盒子進(jìn)行操作時(shí),可以做一下動(dòng)作:

Box.put(cake);

Box.get();// 取到某個(gè)東西,從盒子中。

而面向過(guò)程的語(yǔ)言中,通常是將實(shí)體傳遞給一個(gè)貫穿全局的函數(shù)來(lái)進(jìn)行的,同樣以 Box 為例,對(duì) Box 進(jìn)行操作時(shí),往往是這樣:

Put(Box, cake);// 將一個(gè)蛋糕放到盒子中

Get(Box);// 從盒子中取出某個(gè)東西來(lái)

而顯然,第一種代碼形式更符合常理,所以面向?qū)ο蟮恼Z(yǔ)言大都提供這種語(yǔ)言層面的細(xì)節(jié)的支持,使得代碼的可讀性,可理解性大大增加。 C 語(yǔ)言,作為一個(gè)靈活而簡(jiǎn)單的語(yǔ)言,我們完全可以通過(guò) C 提供的簡(jiǎn)單機(jī)制,實(shí)現(xiàn)這樣的比較優(yōu)美的代碼形式。

C 語(yǔ)言的面向?qū)ο?/h2>

如前所說(shuō),面向?qū)ο笫且环N軟件設(shè)計(jì)的思想,是語(yǔ)言無(wú)關(guān)的。在本節(jié)中,我舉一個(gè)鏈表(list)的例子來(lái)說(shuō)明如何在 C 語(yǔ)言中的設(shè)計(jì)出有面向?qū)ο箫L(fēng)格的代碼。

定義接口

接口是面向?qū)ο笳Z(yǔ)言中的一個(gè)比較重要的概念,接口只對(duì)外部承諾實(shí)現(xiàn)該接口的實(shí)體可以完成什么樣的功能,但是不暴露實(shí)現(xiàn)的方式。這樣的好處是,實(shí)現(xiàn)者可以在不接觸接口使用者的代碼的情況下,對(duì)實(shí)現(xiàn)進(jìn)行調(diào)整。

我們來(lái)看看鏈表的接口定義:

清單 1. 鏈表的接口定義

#ifndef _ILIST_H

#define _ILIST_H

// 定義鏈表中的節(jié)點(diǎn)結(jié)構(gòu)

typedef struct node{

void *data;

struct node *next;

}Node;

// 定義鏈表結(jié)構(gòu)

typedef struct list{

struct list *_this;

Node *head;

int size;

void (*insert)(void *node);// 函數(shù)指針

void (*drop)(void *node);

void (*clear)();

int (*getSize)();

void* (*get)(int index);

void (*print)();

}List;

void insert(void *node);

void drop(void *node);

void clear();

int getSize();

void* get(int index);

void print();

#endif /* _ILIST_H */

IList 接口中,可以清晰的看到,對(duì)于一個(gè) list 實(shí)體 ( 也就是對(duì)象 ) 來(lái)說(shuō),可以在其上進(jìn)行 insert, drop, clear, getSize, get(index) 以及 print 等操作。

接口的實(shí)現(xiàn)

清單 2. 構(gòu)造方法

Node *node = NULL;

List *list = NULL;

void insert(void *node);

void drop(void *node);

void clear();

int getSize();

void print();

void* get(int index);

List *ListConstruction(){

list = (List*)malloc(sizeof(List));

node = (Node*)malloc(sizeof(Node));

list->head = node;

list->insert = insert;// 將 insert 函數(shù)實(shí)現(xiàn)注冊(cè)在 list 實(shí)體上

list->drop = drop;

list->clear = clear;

list->size = 0;

list->getSize = getSize;

list->get = get;

list->print = print;

list->_this = list;// 用 _this 指針將 list 本身保存起來(lái)

return (List*)list;

}

需要注意的是此處的 _this 指針,_this 指針可以保證外部對(duì) list 的操作映射到對(duì) _this 的操作上,從而使得代碼得到簡(jiǎn)化。

清單 3. 插入及刪除

// 將一個(gè) node 插入到一個(gè) list 對(duì)象上

void insert(void *node){

Node *current = (Node*)malloc(sizeof(Node));

current->data = node;

current->next = list->_this->head->next;

list->_this->head->next = current;

(list->_this->size)++;

}

// 刪除一個(gè)指定的節(jié)點(diǎn) node

void drop(void *node){

Node *t = list->_this->head;

Node *d = NULL;

int i = 0;

for(i;i < list->_this->size;i++){

d = list->_this->head->next;

if(d->data == ((Node*)node)->data){

list->_this->head->next = d->next;

free(d);

(list->_this->size)--;

break;

}else{

list->_this->head = list->_this->head->next;

}

}

list->_this->head = t;

}

其他的實(shí)現(xiàn)代碼可以參看下載部分,這里限于篇幅就不再意義列舉出來(lái)。

測(cè)試

測(cè)試代碼

好了,前面做的一切工作都是為了保證我們的暴露給使用者的 API 可以盡量的簡(jiǎn)潔,優(yōu)美,現(xiàn)在到測(cè)試的時(shí)候了:

清單 4. 測(cè)試代碼

int main(int argc, char** argv) {

List *list = (List*)ListConstruction();// 構(gòu)造一個(gè)新的鏈表

// 插入一些值做測(cè)試

list->insert("Apple");

list->insert("Borland");

list->insert("Cisco");

list->insert("Dell");

list->insert("Electrolux");

list->insert("FireFox");

list->insert("Google");

list->print();// 打印整個(gè)列表

printf("list size = %d\n",list->getSize());

Node node;

node.data = "Electrolux";

node.next = NULL;

list->drop(&node);// 刪除一個(gè)節(jié)點(diǎn)

node.data = "Cisco";

node.next = NULL;

list->drop(&node);// 刪除另一個(gè)節(jié)點(diǎn)

list->print();// 再次打印

printf("list size = %d\n",list->getSize());

list->clear();// 清空列表

return 0;

}

圖 1. 運(yùn)行結(jié)果

結(jié)束語(yǔ)

C 語(yǔ)言所誕生的UNIX平臺(tái)提倡這樣一種設(shè)計(jì)哲學(xué):盡量進(jìn)行簡(jiǎn)單的設(shè)計(jì),讓使用者如同搭積木一樣的將這些簡(jiǎn)單的工具連接成強(qiáng)大的,完整的應(yīng)用。 應(yīng)該說(shuō),C 比較好的繼承了這一點(diǎn),C 語(yǔ)言非常簡(jiǎn)潔,非常強(qiáng)大,而由于 C 語(yǔ)言誕生的比較早,當(dāng)時(shí)的面向?qū)ο蟮乃枷脒€不成熟,所以出現(xiàn)了大量的過(guò)程式的 C 應(yīng)用,從而給人們一種 C 語(yǔ)言是面向過(guò)程的語(yǔ)言的錯(cuò)覺(jué),其實(shí) C 只是提供了一些簡(jiǎn)單,強(qiáng)大而通用的能力,至于你想將其搭成什么樣的積木,則全靠你自己了。

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • C語(yǔ)言
    +關(guān)注

    關(guān)注

    180

    文章

    7604

    瀏覽量

    136846

原文標(biāo)題:如何寫(xiě)出優(yōu)美的 C 代碼

文章出處:【微信號(hào):weixin21ic,微信公眾號(hào):21ic電子網(wǎng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    嵌入式C語(yǔ)言面向對(duì)象編程---多態(tài)

    前兩篇文章主要講述了 C 語(yǔ)言面向對(duì)象編程– 封裝和繼承。本篇文章繼續(xù)來(lái)討論一下,如何使用 C 語(yǔ)言
    發(fā)表于 10-31 14:41 ?1007次閱讀

    Python的面向對(duì)象編程詳解

    一般編程可分為面向過(guò)程編程,和面向對(duì)象編程。Python的面向對(duì)象編程,與Java的面向
    發(fā)表于 09-04 16:35 ?568次閱讀
    Python的<b class='flag-5'>面向</b><b class='flag-5'>對(duì)象</b>編程<b class='flag-5'>詳解</b>

    C++筆記005:用面向過(guò)程和面向對(duì)象方法求解圓形面積

    鍵盤(pán)輸入的內(nèi)容流到了某某某中!面向過(guò)程程序比較簡(jiǎn)單,只要有一些C語(yǔ)言的基礎(chǔ),加上對(duì)C++輸入輸出流就可以了!第二,面向
    發(fā)表于 03-05 12:59

    如何用C語(yǔ)言實(shí)現(xiàn)面向對(duì)象編程

    1 用C語(yǔ)言實(shí)現(xiàn)面向對(duì)象編程GOF的《設(shè)計(jì)模式》一書(shū)的副標(biāo)題叫做“可復(fù)用面向對(duì)象軟件的基礎(chǔ)”,從
    發(fā)表于 07-12 07:24

    c語(yǔ)言實(shí)現(xiàn)面向對(duì)象編程 精選資料分享

    c語(yǔ)言面向對(duì)象框架(以RT-Thread軟件包rt-robot為例)概述??有一種說(shuō)法是c語(yǔ)言
    發(fā)表于 09-02 07:46

    JAVA語(yǔ)言面向對(duì)象程序設(shè)計(jì)課件

    JAVA語(yǔ)言面向對(duì)象程序設(shè)計(jì)課件:第1章  Java和面向對(duì)象概述.ppt第2章  Java概述.ppt第3章&nbs
    發(fā)表于 12-06 13:52 ?44次下載

    GO語(yǔ)言的模塊化和面向對(duì)象

    提及GO所支持的package(包)和面向對(duì)象。在這之前呢,還是建議讀者閱讀一下此書(shū),照舊,歡迎各方高人點(diǎn)評(píng)和糾錯(cuò)。 總的來(lái)說(shuō),我發(fā)現(xiàn)GO語(yǔ)言面向對(duì)
    發(fā)表于 09-28 17:11 ?0次下載

    C++語(yǔ)言和面向對(duì)象程序設(shè)計(jì)教程

    C++語(yǔ)言和面向對(duì)象程序設(shè)計(jì)代表了旨在使計(jì)算機(jī)問(wèn)題解更加符合人的思維活動(dòng),是軟件開(kāi)發(fā)方法的一場(chǎng)革命;面向對(duì)象建模
    發(fā)表于 03-02 08:00 ?6次下載

    為什么要用C語(yǔ)言實(shí)現(xiàn)面向對(duì)象

    對(duì)象的編程語(yǔ)言,但面向對(duì)象的概念是在C語(yǔ)言階段就有了,而且應(yīng)用到了很多地方,比如某些操作系統(tǒng)內(nèi)核
    的頭像 發(fā)表于 11-05 18:05 ?1714次閱讀
    為什么要用<b class='flag-5'>C</b><b class='flag-5'>語(yǔ)言</b>實(shí)現(xiàn)<b class='flag-5'>面向</b><b class='flag-5'>對(duì)象</b>

    C語(yǔ)言是如何實(shí)現(xiàn)面向對(duì)象

    C++是 面向對(duì)象 的編程語(yǔ)言,但面向對(duì)象的概念是在C
    的頭像 發(fā)表于 12-24 17:08 ?2w次閱讀
    <b class='flag-5'>C</b><b class='flag-5'>語(yǔ)言</b>是如何實(shí)現(xiàn)<b class='flag-5'>面向</b><b class='flag-5'>對(duì)象</b>的

    為什么要用C語(yǔ)言實(shí)現(xiàn)面向對(duì)象

    對(duì)象的編程語(yǔ)言,但面向對(duì)象的概念是在C語(yǔ)言階段就有了,而且應(yīng)用到了很多地方,比如某些操作系統(tǒng)內(nèi)核
    的頭像 發(fā)表于 06-04 17:44 ?2335次閱讀
    為什么要用<b class='flag-5'>C</b><b class='flag-5'>語(yǔ)言</b>實(shí)現(xiàn)<b class='flag-5'>面向</b><b class='flag-5'>對(duì)象</b>呢

    為什么要用C語(yǔ)言實(shí)現(xiàn)面向對(duì)象呢?

    對(duì)象的編程語(yǔ)言,但面向對(duì)象的概念是在C語(yǔ)言階段就有了,而且應(yīng)用到了很多地方,比如某些操作系統(tǒng)內(nèi)核
    的頭像 發(fā)表于 06-12 17:55 ?1726次閱讀
    為什么要用<b class='flag-5'>C</b><b class='flag-5'>語(yǔ)言</b>實(shí)現(xiàn)<b class='flag-5'>面向</b><b class='flag-5'>對(duì)象</b>呢?

    嵌入式C語(yǔ)言面向對(duì)象編程應(yīng)用及優(yōu)勢(shì)

    既然面向對(duì)象是一種編程思想,而編程語(yǔ)言只是一種工具,那么,思想與工具之間就不存在一種強(qiáng)耦合的關(guān)系,C++可以面向
    發(fā)表于 11-10 12:00 ?1786次閱讀
    嵌入式<b class='flag-5'>C</b><b class='flag-5'>語(yǔ)言</b><b class='flag-5'>面向</b><b class='flag-5'>對(duì)象</b>編程應(yīng)用及優(yōu)勢(shì)

    C語(yǔ)言是怎么面向對(duì)象編程

    在嵌入式開(kāi)發(fā)中,C/C++語(yǔ)言是使用最普及的,在C++11版本之前,它們的語(yǔ)法是比較相似的,只不過(guò)C++提供了
    的頭像 發(fā)表于 02-14 13:57 ?1680次閱讀
    <b class='flag-5'>C</b><b class='flag-5'>語(yǔ)言</b>是怎么<b class='flag-5'>面向</b><b class='flag-5'>對(duì)象</b>編程

    淺談C語(yǔ)言面向對(duì)象編程思想

    C語(yǔ)言是一種面向過(guò)程的語(yǔ)言,但是也可以用結(jié)構(gòu)體和函數(shù)指針來(lái)模擬面向對(duì)象的特性,比如封裝、繼承和多
    發(fā)表于 11-02 12:27 ?1118次閱讀

    主站蜘蛛池模板: 日韩黄网| 欧美黄色片在线| a成人在线| 午夜精品久久久久久影视riav| 亚洲小younv另类| 午夜免费伦费影视在线观看| 日日日干干干| 亚洲免费不卡| 中文字幕天堂在线| 91华人在线视频| 天天躁夜夜躁狠狠躁2021西西| 18男女很黄的视频| 色偷偷88欧美精品久久久| 欧美一级日韩在线观看| 国产精品三级在线观看| 午夜一区二区在线观看| zsvdy午夜片| 亚洲综合欧美日本另类激情| 三级黄色免费| 精品一区二区视频| 亚洲理论片在线观看| 国产成人永久在线播放| 视频1区| 五月婷婷六月合| 久久久久99精品成人片三人毛片| 在线免费看片| 99香蕉精品视频在线观看| 轻点太大了好深好爽h文| 手机免费黄色网址| 国产日本特黄特色大片免费视频| 天天草狠狠干| 亚洲欧洲无码一区二区三区| 日本免费的一级绿象| 最色网在线观看| 手机看片www xiao2b cm| 曰韩毛片| 黄色视屏日本| 你懂的手机在线视频| 亚洲国产情侣偷自在线二页| 久久综合性| 手机在线看a|