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

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

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

C語言編寫的程序執(zhí)行效率到底高在哪里

strongerHuang ? 來源:typedef ? 作者:typedef ? 2022-11-10 09:03 ? 次閱讀

都說C語言編寫的程序執(zhí)行效率比較高,那么到底高在哪里,我們一塊來學習學習。

C語言由來

C語言源自于BCPL、B兩種語言。

BCPL語言以及代碼

1967年,劍橋大學的馬丁·理察德(Martin Richards)以CPL編程語言為基礎(chǔ),發(fā)明了BCPL(Basic Combined Pogramming Language)編程語言。

我們在看一個用BCPL語言編寫的計算階乘的功能,代碼如下:

GET"libhdr"
LETstart()=VALOF
{FORi=1TO5DOwritef("fact(%n)=%i4*n",i,fact(i))
RESULTIS0
}
ANDfact(n)=n=0->1,n*fact(n-1)

GET "libhdr"是包含標準庫,LET start() = VALOF是程序運行時要調(diào)用的第一個函數(shù)??绽ㄌ?)表示函數(shù)不需要任何參數(shù),VALOF表示函數(shù)有返回值。

FOR i = 1 TO 5 DO是一個從1到5的循環(huán)。writef是字符格式化字符串函數(shù),用來輸出將i替換%n、fact(i)替換%i4格式化之后的字符串。*n表示換行,RESULTIS 0是返回值,用來告訴系統(tǒng)函數(shù)執(zhí)行成功。

AND fact(n) =介紹了函數(shù)fact的定義,通過接受一個參數(shù)來實現(xiàn)n的階乘。

n=0 -> 1, n*fact(n-1)則是階乘的實現(xiàn),當n等于0時候,返回1(0的階乘是1),當n不等于0的時候則返回n*fact(n-1),

AND原文是下面這樣說的,如下:

The word AND causes fact to available to the previously definedfunction

我的個人理解是支持嵌套,那么你認為呢?

當上述功能執(zhí)行后將會在終端有如下輸出:

fact(1)=1
fact(2)=2
fact(3)=6
fact(4)=24
fact(5)=120

BCPL用戶指南:https://www.cl.cam.ac.uk/~mr10/bcplman.pdf

B語言以及代碼

肯·湯普遜(Ken Thompson)簡稱“ken”,在貝爾實驗室工作期間設(shè)計和實現(xiàn)了Unix操作系統(tǒng)。他基于BCPL創(chuàng)造了B語言。

同樣的,我們來看一個用B語言實現(xiàn)進制轉(zhuǎn)換功能。輸入一個n轉(zhuǎn)換為b進制,其中b在2和10之間。

/*Thefollowingfunctionwillprintanon-negativenumber,n,to
thebaseb,where2<=b<=10,??This?routine?uses?the?fact?that
??in?the?ANSCII?character?set,?the?digits?O?to?9?have?sequential
??code?values.??*/

printn(n,b)?{
?extrn?putchar;
?auto?a;

?if(a=n/b)?/*?assignment,?not?test?for?equality?*/
??printn(a,?b);?/*?recursive?*/
?putchar(n%b?+?'0');
}

代碼出處:https://www.bell-labs.com/usr/dmr/www/kbman.html

C語言

在1972年,美國貝爾實驗室的丹尼斯·里奇(D.M.Ritchie)在B語言的基礎(chǔ)上設(shè)計出了新的言,他取BCPL的第二個字母作為這種語言的名字,這就是C語言的由來。

以下是用C語言實現(xiàn)的進制轉(zhuǎn)換功能。

#include

voidprintn(intn,charb){
chara;
if(a=n/b){
printn(a,b);
}
putchar(n%b+'0');
}

intmain(intargc,char**argv){
printn(8,2);
return0;
}

Terminal:1000

跟B語言非常接近了吧。

編程語言

機器語言是二進制文件,匯編語言是符號語言,再往匯編之上是高級語言。下圖是C編寫的源文件,經(jīng)過匯編和鏈接生成的匯編文件以及二進制文件。

6a8f925c-6090-11ed-8abf-dac502259ad0.png

機器語言

機器語言是一種指令集的體系,它是用二進制代碼表示的語言,是計算機唯一可以直接識別和執(zhí)行的語言,它具有計算機可以直接執(zhí)行、簡潔、運算速度快等優(yōu)點,這是一件十分繁瑣的工作。編寫程序花費的時間往往是實際運行時間的幾十倍或幾百倍,而且直觀性比較差,容易出錯,程序的檢查和調(diào)試都比較困難。

匯編語言

為了解決機器語言難以理解和記憶的缺點,于是就出現(xiàn)了匯編語言。用易于理解和記憶的名稱和符號表示機器指令中的操作碼。這樣用符號代替機器語言的二進制碼,就把機器語言變成了匯編語言;于是匯編語言亦稱為符號語言。

高級語言

高級語言又主要是相對于匯編語言(機器語言)而言的,它是高度封裝了的編程語言;是較接近自然語言和數(shù)學公式的編程,基本脫離了機器的硬件系統(tǒng),用人們更易理解的方式編寫程序。

例如java,c,c++,C#,python都是高級語言。

C為何快速

越高級的語言,越人性化,機器負擔就重。因為機器幫你處理了常見的問題,需要一些額外開銷。而C語言是一門非常干凈的語言,相當于裸奔,被設(shè)計之初就將速度大于安全之上,它不會檢查數(shù)組索引是否會越界,不會檢查內(nèi)存是否泄漏,也不會檢查指針是否是野指針。

在制定C標準時指出C代碼是能夠可移植的,但是如果要為了更快的執(zhí)行效率,可以犧牲可移植性。C完全相信程序員,不會阻止程序員要做的事情。

C語言經(jīng)過編譯優(yōu)化生成的機器碼和和直接寫匯編生成的機器碼是相當?shù)?,所以C非常高效。






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • UNIX操作系統(tǒng)
    +關(guān)注

    關(guān)注

    0

    文章

    13

    瀏覽量

    15306
  • C語言
    +關(guān)注

    關(guān)注

    180

    文章

    7604

    瀏覽量

    136841
  • CPL
    CPL
    +關(guān)注

    關(guān)注

    0

    文章

    13

    瀏覽量

    10697

原文標題:C語言效率高,是有原因的

文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    如何提高單片機C語言程序執(zhí)行效率

    首先什么是執(zhí)行效率。我們平常所說的執(zhí)行效率就是使用相同的算法在相同輸入條件下完成相同計算所產(chǎn)生的系統(tǒng)開銷,目前來說一般會更多關(guān)注執(zhí)行時間方面
    發(fā)表于 03-06 18:52 ?1881次閱讀

    為什么C語言執(zhí)行效率高,運行快?

    都說C語言編寫程序執(zhí)行效率比較高,那么到底
    發(fā)表于 11-04 09:04 ?1095次閱讀

    嵌入式工程師怎么寫出效率高C語言程序

    作為嵌入式工程師,怎么寫出效率高、思路清晰的C語言程序呢?
    發(fā)表于 07-03 09:34 ?336次閱讀

    Go開發(fā)語言的優(yōu)勢在哪里

    進程。對于Go語言,一直存在著爭議,很多人善于用Go語言進行開發(fā),但不是所有人都喜歡Go語言,那么Go語言的存在有什么價值?Go語言的優(yōu)勢
    發(fā)表于 03-22 15:04

    請問不同編程語言的區(qū)別到底在哪里?

    不同編程語言的區(qū)別到底在哪里??C語言、python、ruby、java...撇開前端開發(fā)語言不談,但論這些后端
    發(fā)表于 06-02 06:44

    如何提高C語言程序執(zhí)行效率

    的事那么效率。下面說說如何提高C語言程序執(zhí)行效率
    發(fā)表于 07-20 06:39

    使用c語言給單片機編寫程序在運行的時候if語句運行的快還是switch語句執(zhí)行的速度快?

    請問使用c語言給單片機編寫程序在運行的時候if語句運行的快,還是switch語句執(zhí)行的速度快?在優(yōu)化之前的人寫的
    發(fā)表于 11-08 06:55

    編寫一個以C語言為基礎(chǔ)的DSP程序

    實驗2 : 編寫一個以C 語言為基礎(chǔ)的DSP程序一.實驗目的1.學習用標準C語言編制
    發(fā)表于 03-17 00:13 ?3494次閱讀
    <b class='flag-5'>編寫</b>一個以<b class='flag-5'>C</b><b class='flag-5'>語言</b>為基礎(chǔ)的DSP<b class='flag-5'>程序</b>

    關(guān)于c語言編寫的算法程序

    關(guān)于c語言編寫的算法程序
    發(fā)表于 04-09 17:47 ?12次下載

    如何提高單片機程序執(zhí)行效率

    更短的時間內(nèi)完成相同的事那么效率。 關(guān)于如何提高C語言程序執(zhí)行
    發(fā)表于 02-11 15:42 ?6次下載
    如何提高單片機<b class='flag-5'>程序</b><b class='flag-5'>執(zhí)行</b><b class='flag-5'>效率</b>

    為什么說C語言程序運行時要比其他語言編寫程序快得多

    C語言程序運行時要比其他語言編寫程序快得多,因為它“離底層機器很近”,這個說法正確嗎?
    的頭像 發(fā)表于 03-16 08:45 ?2228次閱讀

    labview和vb的優(yōu)勢在哪里

    以可視化編程方式的編寫程序,不需要像傳統(tǒng)的編程語言一樣使用代碼編寫,而是使用圖形化的模塊和線條來組合程序。這使得編寫程序變得更加簡單、易于
    的頭像 發(fā)表于 08-31 17:37 ?1450次閱讀

    C語言編寫程序執(zhí)行效率高的原因是什么?

    機器語言是一種指令集的體系,它是用二進制代碼表示的語言,是計算機唯一可以直接識別和執(zhí)行語言,它具有計算機可以直接執(zhí)行、簡潔、運算速度快等優(yōu)
    發(fā)表于 10-23 10:18 ?651次閱讀
    <b class='flag-5'>C</b><b class='flag-5'>語言</b><b class='flag-5'>編寫程序</b><b class='flag-5'>執(zhí)行</b><b class='flag-5'>效率高</b>的原因是什么?

    c語言編寫的源程序可以直接運行嗎

    C語言編寫的源程序不能直接運行,必須經(jīng)過一系列的編譯鏈接過程才能生成可執(zhí)行文件,然后才能運行。 C
    的頭像 發(fā)表于 11-26 09:03 ?7040次閱讀

    c語言hello world程序編寫

    語言"Hello world"程序編寫過程,并提供一些實用技巧和注意事項。 首先,我們需要一個C語言開發(fā)環(huán)境來
    的頭像 發(fā)表于 11-26 09:23 ?2441次閱讀