chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

為什么C語(yǔ)言的執(zhí)行效率高,運(yùn)行快?

汽車(chē)電子技術(shù) ? 來(lái)源:typedef ? 作者:typedef ? 2023-02-21 09:59 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

目錄

  • 簡(jiǎn)述
  • C語(yǔ)言由來(lái)
    • BCPL語(yǔ)言及代碼
    • B語(yǔ)言以及代碼
    • C語(yǔ)言
  • 編程語(yǔ)言
  • 機(jī)器語(yǔ)言
  • 匯編語(yǔ)言
  • 高級(jí)語(yǔ)言
  • C為何快速

簡(jiǎn)述

都說(shuō)C語(yǔ)言編寫(xiě)的程序執(zhí)行效率比較高,那么到底高在哪里,我們一塊來(lái)學(xué)習(xí)學(xué)習(xí)。

C語(yǔ)言由來(lái)

C語(yǔ)言源自于BCPL、B兩種語(yǔ)言。

BCPL語(yǔ)言以及代碼

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

我們?cè)诳匆粋€(gè)用BCPL語(yǔ)言編寫(xiě)的計(jì)算階乘的功能,代碼如下:

GET "libhdr"
LET start() = VALOF
{ FOR i = 1 TO 5 DO writef("fact(%n) = %i4*n", i, fact(i))
  RESULTIS 0
}
AND fact(n) = n=0 -> 1, n*fact(n-1)

GET "libhdr"是包含標(biāo)準(zhǔn)庫(kù),LET start() = VALOF是程序運(yùn)行時(shí)要調(diào)用的第一個(gè)函數(shù)。空括號(hào)()表示函數(shù)不需要任何參數(shù),VALOF表示函數(shù)有返回值。

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

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

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

AND原文是下面這樣說(shuō)的,如下:

The word AND causes fact to available to the previously defined function

我的個(gè)人理解是支持嵌套,那么你認(rèn)為呢?

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

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

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

B語(yǔ)言以及代碼

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

同樣的,我們來(lái)看一個(gè)用B語(yǔ)言實(shí)現(xiàn)進(jìn)制轉(zhuǎn)換功能。輸入一個(gè)n轉(zhuǎn)換為b進(jìn)制,其中b在2和10之間。

/* The following function will print a non-negative number, n, to
  the base b, where 2<=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語(yǔ)言

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

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

#include

void printn(int n, char b) {
  char a;
  if(a=n/b) {
    printn(a, b);
  }
  putchar(n%b + '0');
}

int main(int argc ,char **argv) {
  printn(8, 2);
  return 0;
}

Terminal: 1000

跟B語(yǔ)言非常接近了吧。

編程語(yǔ)言

機(jī)器語(yǔ)言是二進(jìn)制文件,匯編語(yǔ)言是符號(hào)語(yǔ)言,再往匯編之上是高級(jí)語(yǔ)言。下圖是C編寫(xiě)的源文件,經(jīng)過(guò)匯編和鏈接生成的匯編文件以及二進(jìn)制文件。

圖片

機(jī)器語(yǔ)言

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

匯編語(yǔ)言

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

高級(jí)語(yǔ)言

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

例如java,c,c++C#,python都是高級(jí)語(yǔ)言。

C為何快速

越高級(jí)的語(yǔ)言,越人性化,機(jī)器負(fù)擔(dān)就重。因?yàn)闄C(jī)器幫你處理了常見(jiàn)的問(wèn)題,需要一些額外開(kāi)銷(xiāo)。而C語(yǔ)言是一門(mén)非常干凈的語(yǔ)言,相當(dāng)于裸奔,被設(shè)計(jì)之初就將速度大于安全之上,它不會(huì)檢查數(shù)組索引是否會(huì)越界,不會(huì)檢查內(nèi)存是否泄漏,也不會(huì)檢查指針是否是野指針。

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

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

END

聲明:本文內(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

    文章

    7632

    瀏覽量

    141486
  • 編程語(yǔ)言
    +關(guān)注

    關(guān)注

    10

    文章

    1956

    瀏覽量

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

    關(guān)注

    0

    文章

    13

    瀏覽量

    10851
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    為什么C語(yǔ)言執(zhí)行效率高,運(yùn)行?

    都說(shuō)C語(yǔ)言編寫(xiě)的程序執(zhí)行效率比較高,那么到底在哪里,我們一塊來(lái)學(xué)習(xí)學(xué)習(xí)。
    發(fā)表于 11-04 09:04 ?1200次閱讀

    嵌入式工程師怎么寫(xiě)出效率高C語(yǔ)言程序

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

    公式節(jié)點(diǎn)的效率高嗎?

    如題,完成一個(gè)功能, 公式節(jié)點(diǎn)效率高,還是用VI函數(shù)效率高? 相信labview是用C++寫(xiě)的程序.
    發(fā)表于 11-20 11:30

    關(guān)于主函數(shù)whil循環(huán)調(diào)用多個(gè)函數(shù)執(zhí)行,和直接代碼執(zhí)行,哪個(gè)效率高的問(wèn)題。

    主函數(shù)while中多段代碼,是將代碼封裝成多個(gè)函數(shù),去調(diào)用多個(gè)函數(shù)執(zhí)行,還是直接貼代碼在主函數(shù)while中運(yùn)行 哪個(gè)效率高?是不是調(diào)用了很多個(gè)函數(shù) 導(dǎo)致慢了,高手從編譯 運(yùn)行角度解讀下
    發(fā)表于 06-24 10:14

    真心請(qǐng)教,a=b=1和a=1;b=1;這兩種寫(xiě)法在c語(yǔ)言執(zhí)行起來(lái)哪個(gè)效率高?

    小白我真心請(qǐng)教,a=b=1和a=1;b=1;這兩種寫(xiě)法在c語(yǔ)言執(zhí)行起來(lái)哪個(gè)效率高?求高手們賜教啊
    發(fā)表于 01-01 12:30

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

    的事那么效率。下面說(shuō)說(shuō)如何提高C語(yǔ)言程序的執(zhí)行效率。1、盡量避免調(diào)用延時(shí)函數(shù)沒(méi)有帶操作系統(tǒng)的
    發(fā)表于 07-20 06:39

    MCS的C語(yǔ)言和標(biāo)準(zhǔn)C語(yǔ)言的區(qū)別

    MCS的C語(yǔ)言和標(biāo)準(zhǔn)C語(yǔ)言的區(qū)別MC9S12的C語(yǔ)言與標(biāo)準(zhǔn)C
    發(fā)表于 07-20 07:06

    解釋型語(yǔ)言與編譯型語(yǔ)言以及解釋器與編譯器之間的區(qū)別是什么

    類(lèi)別優(yōu)點(diǎn)缺點(diǎn)應(yīng)用場(chǎng)合代表語(yǔ)言解釋型 語(yǔ)言運(yùn)行的時(shí)候?qū)⒊绦蚍g成機(jī)器語(yǔ)言跨平臺(tái),開(kāi)發(fā)效率高執(zhí)行速度
    發(fā)表于 02-28 12:51

    有源pfc效率高還是無(wú)源效pfc效率高?

    有源pfc效率高還是無(wú)源效pfc效率高
    發(fā)表于 10-07 09:01

    使用c語(yǔ)言給單片機(jī)編寫(xiě)的程序在運(yùn)行的時(shí)候if語(yǔ)句運(yùn)行還是switch語(yǔ)句執(zhí)行的速度?

    請(qǐng)問(wèn)使用c語(yǔ)言給單片機(jī)編寫(xiě)的程序在運(yùn)行的時(shí)候if語(yǔ)句運(yùn)行,還是switch語(yǔ)句執(zhí)行的速度
    發(fā)表于 11-08 06:55

    DN303-閃光燈電容充電器充電效率高、電池耗電量低

    DN303-閃光燈電容充電器充電、效率高、電池耗電量低
    發(fā)表于 05-15 19:57 ?12次下載
    DN303-閃光燈電容充電器充電<b class='flag-5'>快</b>、<b class='flag-5'>效率高</b>、電池耗電量低

    C/C++靈魂拷問(wèn):++i與i++哪個(gè)執(zhí)行效率高?有什么區(qū)別?

    當(dāng)然,就C語(yǔ)言代碼來(lái)看,i++和++i都只有一行,看起來(lái)似乎二者的執(zhí)行效率一樣了?其實(shí)不是的,在學(xué)習(xí)C語(yǔ)
    的頭像 發(fā)表于 03-31 14:04 ?2158次閱讀

    C語(yǔ)言靈魂拷問(wèn): ++i為何比i++執(zhí)行效率高!

    當(dāng)然,就C語(yǔ)言代碼來(lái)看,i++ 和 ++i 都只有一行,看起來(lái)似乎二者的執(zhí)行效率一樣?其實(shí)不是的,在學(xué)習(xí)C
    的頭像 發(fā)表于 03-07 11:02 ?1359次閱讀

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

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

    C語(yǔ)言運(yùn)行環(huán)境是什么

    C語(yǔ)言運(yùn)行環(huán)境(C language runtime environment)是指在執(zhí)行C
    的頭像 發(fā)表于 11-27 16:13 ?4454次閱讀