⑴ linux下用c語言實現查cpu類型和型號等信息
都在/proc/ 下面
cpu信息在/proc/cpuinfo
啟動時間在/proc/uptime 單位是s
/proc/stat 裡面有cpu執行的時間,用戶態,系統態,空閑都有
⑵ linux下c語言是交叉編譯嗎
採用交叉編譯的主要原因在於,多數嵌入式目標系統不能提供足夠的資源供編譯過程使用,因而只好將編譯工程轉移到高性能的主機中進行。
linux下的交叉編譯環境重要包括以下幾個部分:
1.對目標系統的編譯器gcc
2.對目標系統的二進制工具binutils
3.目標系統的標准c庫glibc
4.目標系統的linux內核頭文件
交叉編譯環境的建立步驟
一、下載源代碼 下載包括binutils、gcc、glibc及linux內核的源代碼(需要注意的是,glibc和內核源代碼的版本必須與目標機上實際使用的版本保持一致),並設定shell變數PREFIX指定可執行程序的安裝路徑。
二、編譯binutils 首先運行configure文件,並使用--prefix=$PREFIX參數指定安裝路徑,使用--target=arm-linux參數指定目標機類型,然後執行make install。
三、配置linux內核頭文件
首先執行make mrproper進行清理工作,然後執行make config ARCH=arm(或make menuconfig/xconfig ARCH=arm)進行配置(注意,一定要在命令行中使用ARCH=arm指定cpu架構,因為預設架構為主機的cpu架構),這一步需要根據目標機的實際情況進行詳細的配置,筆者進行的實驗中目標機為HP的ipaq-hp3630 PDA,因而設置system type為SA11X0,SA11X0 Implementations中選擇Compaq iPAQ H3600/H3700。
配置完成之後,需要將內核頭文件拷貝到安裝目錄: cp -dR include/asm-arm $PREFIX/arm-linux/include/asm cp -dR include/linux $PREFIX/arm-linux/include/linux
四、第一次編譯gcc
首先運行configure文件,使用--prefix=$PREFIX參數指定安裝路徑,使用--target=arm-linux參數指定目標機類型,並使用--disable-threads、--disable-shared、--enable-languages=c參數,然後執行make install。這一步將生成一個最簡的gcc。由於編譯整個gcc是需要目標機的glibc庫的,它現在還不存在,因此需要首先生成一個最簡的gcc,它只需要具備編譯目標機glibc庫的能力即可。
五、交叉編譯glibc
這一步驟生成的代碼是針對目標機cpu的,因此它屬於一個交叉編譯過程。該過程要用到linux內核頭文件,默認路徑為$PREFIX/arm-linux/sys-linux,因而需要在$PREFIX/arm-linux中建立一個名為sys-linux的軟連接,使其內核頭文件所在的include目錄;或者,也可以在接下來要執行的configure命令中使用--with-headers參數指定linux內核頭文件的實際路徑。
configure的運行參數設置如下(因為是交叉編譯,所以要將編譯器變數CC設為arm-linux-gcc): CC=arm-linux-gcc ./configure --prefix=$PREFIX/arm-linux --host=arm-linux --enable-add-ons 最後,按以上配置執行configure和make install,glibc的交叉編譯過程就算完成了,這里需要指出的是,glibc的安裝路徑設置為$PREFIXARCH=arm/arm-linux,如果此處設置不當,第二次編譯gcc時可能找不到glibc的頭文件和庫。
六、第二次編譯gcc
運行configure,參數設置為--prefix=$PREFIX --target=arm-linux --enable-languages=c,c++。
運行make install。
到此為止整個交叉編譯環境就完全生成了。
幾點注意事項
第一點、在第一次編譯gcc的時候可能會出現找不到stdio.h的錯誤,解決辦法是修改gcc/config/arm/t-linux文件,在TARGET_LIBGCC2_CFLAGS變數的設定中增加-Dinhibit_libc和-D__gthr_posix_h。
⑶ Linux c 語言怎麼方便的讀取 cpu,磁碟信息
我附上我的代碼給你參考。
CPU佔用 需要查看/proc/stat 的信息
磁碟需要 使用statfs這個函數來確認文件所包含的信息。
我附上我的代碼給你參考。
我的代碼支持CPU使用率(佔用率),內存佔用率,及磁碟佔用率。
#include<stdio.h>
#include<stdlib.h>
#include<sys/time.h>
#include<unistd.h>
#include<sys/vfs.h>
#include<error.h>
#defineGsize(1024.00*1024.00*1024.00)
#defineMsize(1024.00*1024.00)
#ifndefEXT2_SUPER_MAGIC
#defineEXT2_SUPER_MAGIC0xef53
#endif
doubletime_so_far();
floatget_cpu_rate();
floatget_memory_rate();
floatget_disk_rate();
intmain(intargc,char*argv[])
{
get_cpu_rate();
get_memory_rate();
get_disk_rate();
return0;
}
doubletime_so_far(){
structtimevaltp;
if(gettimeofday(&tp,(structtimezone*)NULL)==-1)
perror("gettimeofday");
return((double)(tp.tv_sec))+(((double)tp.tv_usec)*0.000001);
}
floatget_cpu_rate(){
FILE*f1;
doubleti,tf;
charc[10],d[10];
intt,i1,i2,i3,i4,i5,i6;
ti=time_so_far();
f1=fopen("/proc/stat","r");
fscanf(f1,"%s %d %d %d ",c,&i1,&i2,&i3);
fclose(f1);
printf("%s %d %d %d ",c,i1,i2,i3);
usleep(1000000);
tf=time_so_far();
f1=fopen("/proc/stat","r");
fscanf(f1,"%s %d %d %d ",c,&i4,&i5,&i6);
fclose(f1);
printf("%s %d %d %d ",c,i4,i5,i6);
t=(i4+i5+i6)-(i1+i2+i3);
printf("%d ",t);
printf("cpuusage:%.2f%% ",(t/((tf-ti)*100))*100);
}
floatget_memory_rate(){
FILE*f1;
intitemp1,itemp2;
charc[10],d[10];
f1=fopen("/proc/meminfo","r");
fscanf(f1,"%s %d %s",c,&itemp1,d);
printf("memorytotalis%dKb ",itemp1);
printf("memorytotalis%.2fMb ",itemp1/1024.0);
fscanf(f1,"%s %d %s",c,&itemp2,d);
printf("memoryfreeis%dKb ",itemp2);
printf("memoryfreeis%.2fMb ",itemp2/1024.0);
fclose(f1);
printf("menusage:%.2f%% ",((itemp1-itemp2)*100.0)/itemp1);
}
floatget_disk_rate(){
structstatfs*fs;
longlongblocks,bfree;
if(statfs("/",fs)!=0)
{
perror("stafts");
printf("exit ");
exit(1);
}
blocks=fs->f_blocks;
bfree=fs->f_bfree;
//if(fs.f_type==EXT2_SUPER_MAGIC)
//{
printf("Disksizeof/is%.2fG ",blocks*fs->f_bsize/Gsize);
printf("FreeDisksizeof/is%.2fG ",bfree*fs->f_bsize/Gsize);
printf("Diskusageof/is%.2f%% ",bfree*100.0/blocks);
//}
}
⑷ Linux c 語言怎麼方便的讀取 cpu,磁碟信息
最簡單的方法
是到proc下讀對應的文件
cpu信息 磁碟信息 都有對應文件的。
也可以用cpuinfo fdisk一類的命令 操作簡單,但效率略低。
可以網路一下,有很多這樣的源碼的。
⑸ 嵌入式C語言重點知識點
嵌入式LINUX
嵌入式Linux 是將日益流行的Linux操作系統進行裁剪修改,使之能在嵌入式計算機系統上運行的一種操作系統。Linux做嵌入式的優勢,首先,Linux是開放源代碼;其次,Linux的內核小、效率高,可以定製,其系統內核最小隻有約134KB;第三,Linux是免費的OS,Linux還有著嵌入式操作系統所需要的很多特色,突出的就是Linux適應於多種CPU和多種硬體平台而且性能穩定,裁剪性很好,開發和使用都很容易。同時,Linux內核的結構在網路方面是非常完整的,Linux對網路中最常用的TCP/IP協議有最完備的支持。提供了包括十兆、百兆、千兆的乙太網絡,以及無線網路,Token Ring(令牌環網)、光纖甚至衛星的支持。
移植步驟:
1.Bootloader的移植;
2.嵌入式Linux操作系統內核的移植;
3.嵌入式Linux操作系統根文件系統的創建;
4.電路板上外設Linux驅動程序的編寫。
WinCE
WinCE是微軟公司嵌入式、移動計算平台的基礎,它是一個開放的、可升級的32位嵌入式操作系統,是基於掌上型電腦類的電子設備操作系統,它是精簡的Windows 95,Win CE的圖形用戶界面相當出色。WinCE是從整體上為有限資源的平台設計的多線程、完整優先權、多任務的操作系統。它的模塊化設計允許它對於從掌上電腦到專用的工業控制器的用戶電子設備進行定製。操作系統的基本內核需要至少200K的ROM。
一般來說,一個WinCE系統包括四層結構:應用程序、WinCE內核映像、板級支持包(BSP)、硬體平台。而基本軟體平台則主要由WinCE系統內核映像(OS Image)和板卡支持包(BSP)兩部分組成。因為WinCE系統是一個軟硬體緊密結合的系統,因此即使CPU處理器相同,但是如果開發板上的外圍硬體不相同,這個時候還是需要修改BSP來完成一個新的BSP。因此換句話說,就是WinCE的移植過程主要是改寫BSP的過程。
Android
Android 是一個包括操作系統,中間件以及一些重要應用程序的專門針對移動設備的層次結構的軟體集。Android 作為一個完全開源的.操作系統,是由操作系統Linux、中間件以及核心應用程序組成的軟體棧。通過 android SDK 提供的 API 以及相應的開發工具, 程序員可以很方便的開發android平台上的應用程序。其整個系統由應用程序,應用程序框架,應用程序庫,Android運行庫,Linux內核(Linux Kernel)五個部分組成。Android操作系統內置了一部分應用程序, 包括電子郵件客戶端、SMS程序、日歷、地圖、瀏覽器、通訊錄以及其他的程序,值得一提的是這些所有的程序都是用java編寫的。
移植的主要的工作是驅動,硬體抽象層的移植。為了更好地理解和調試系統,也應該適當地了解上層對硬體抽象層的調用情況。
TinyOS
TinyOS是一個開源的嵌入式操作系統,它是由加州大學的伯利克分校開發出來的,主要應用於無線感測器網路方面。程序採用的是模塊化設計,所以它的程序核心往往都很小,一般來說核心代碼和數據大概在400 Bytes左右,能夠突破感測器存儲資源少的限制。TinyOS提供一系列可重用的組件,一個應用程序可以通過連接配置文件(A Wiring Specification)將各種組件連接起來,以完成它所需要的功能。
嵌入式實時操作系統(RTOS)
在工業控制、 軍事設備、航空航天等領域對系統的響應時間有苛刻的要求,這就需要使用實時系統。當外界事件或數據產生時,能夠接受並以足夠快的速度予以處理,其處理的結果又能在規定的時間之內來控制生產過程或對處理系統作出快速響應,並控制所有實時任務協調一致運行的嵌入式操作系統。故對嵌入式實時操作系統的理解應該建立在對嵌入式系統的理解之上加入對響應時間的要求。
FreeRTOS
FreeRTOS是一個迷你操作系統內核的小型嵌入式系統。作為一個輕量級的操作系統,功能包括:任務管理、時間管理、信號量、消息隊列、內存管理、記錄功能等,可基本滿足較小系統的需要。FreeRTOS任務可選擇是否共享堆棧,並且沒有任務數限制,多個任務可以分配相同的優先權。相同優先順序任務的輪轉調度,同時可設成可剝奪內核或不可剝奪內核。
FreeRTOS 的移植主要需要改寫如下三個文件。
1.portmacro.h
2.port.c
3. port.asm
μTenux
μTenux基於ARM微控制器平台,對uT最適用於ARM Cortex M0-M4系列的微控制器,代碼開源、免費,是一個功能強大的搶占式實時多任務操作系統。μTenux除具有實時嵌入式操作系統的一般特性:可移植性,可固化,可裁剪等特性以外,它還具有如下優點:
(1)微內核。無MMU, ROM/RAM佔用量小,所佔ROM最大60KB,最小10KB;RAM最大12KB,最小2KB;
(2)開源免費;
(3)支持所有32位ARM7/9和Cortex M系列的微控制器;
(4)可配置多達到256個任務以及140個任務優先順序;
(5)有良好的商業支持, T-Engine論壇進行總的維護。
移植主要包括:晶元系統時鍾移植,外設移植和通用輸出/輸入埠的移植以及看門狗模塊移植。由於考慮到內核代碼的重要性以及其在整個移植中的重要意義,且為了整個系統有更好的實時性,可選用匯編語言編寫操作系統的啟動代碼。
VxWorks
VxWorks系統提供多處理器間和任務間高效的信號燈、消息隊列、管道、網路透明的套接字。實時系統的另一關鍵特性是硬體中斷處理。為了獲得最快速可靠的中斷響應,VxWorks系統的中斷服務程序ISR有自己的上下文。VxWorks實時操作系統由400多個相對獨立的、短小精煉的目標模塊組成,用戶可根據需要選擇適當模塊來裁剪和配置系統,這有效地保證了系統的安全性和可靠性。系統的鏈接器可按應用的需要自動鏈接一些目標模塊。這樣,通過目標模塊之間的按需組合,可得到許多滿足功能需求的應用。
移植過程可以參考網路上一些BSP代碼,BSP的英文全稱為board support package,即板級支持包,它的作用是針對特殊的硬體平台,為VxWorks內核提供操作的介面。
μClinux
嵌入式Linux作為一個開放源代碼的操作系統,以價格低廉、功能強大又易移植的特性正在被廣泛應用,μClinux是專門針對沒有MMU的處理器而設計的嵌入式Linux,非常適合中低端嵌入式系統的需求。 在GNU通用公共許可證的授權下,μClinux操作系統的用戶可以使用幾乎所有Linux的API函數,不會因為沒有內存管理單元MMU而受到影響;而且,μClinux在標準的Linux基礎上進行了適當的裁剪和優化,形成了一個高度優化的、代碼緊湊的嵌入式Linux,體積小了,但是仍然保留了Linux的大多數的優點,比如穩定性好、強大的網路功能、良好的可移植性、完備的文件系統支持功能、以及標准豐富的應用程序介面API等,可以支持類似ARM7TDMI等類型多的小巧玲瓏的中央處理器。
eCos
eCos中文翻譯為嵌入式可配置操作系統或嵌入式可配置實時操作系統。適合於深度嵌入式應用,主要應用對象包括消費電子、電信、車載設備、手持設備以及其他一些低成本和攜帶型應用。eCos是一種開發源代碼軟體,無任何版權費用。 eCos最大的特點是模塊化,內核可配置。如果說嵌入式Linux太龐大了,那麼eCos可能就能夠滿足要求。它是一個針對16位、32位和64位處理器的可移植開放源代碼的嵌入式RTOS。和嵌入式Linux不同,它是由專門設計嵌入式系統的工作組設計的。eCos具有相當豐富的特性和一個配置工具,後者能夠讓你選取你所需要的特性。
eCos的軟體分了若乾的模塊,移植工作主要在他的hal層進行,所謂hal(硬體抽象層)就是把和硬體相關的軟體湊到一起。
μC/OS-II
μC/OS-II是一個完整的、可移植、可固化、可裁剪的佔先式實時多任務內核。μC/OS-II絕大部分的代碼是用ANSI的C語言編寫的,包含一小部分匯編代碼,使之可供不同架構的微處理器使用。其結構小巧簡潔且支持搶占式的多任務調度與管理。此實時操作系統管理任務數多達64個,且提供內部程序存儲器管理、系統運行時間管理、多任務實時調度與管理等功能。由於它的作者佔用和保留了8個任務,所以留給用戶應用程序最多可有56個任務。賦予各個任務的優先順序必須是不相同的。這意味著μC/OS-II不支持時間片輪轉調度法。μC/OS-II為每個任務設置獨立的堆棧空間,可以快速實現任務切換。
將μC/OS-II操作系統移植到目標處理器上,需要從硬體和軟體兩方面來考慮。硬體方面,目標處理器需滿足以下條件:
①處理器的C編譯器能產生可重入代碼;
②用C語言可以開/關中斷;
③處理器支持中斷,並且能夠產生定時中斷(通常在10~1000 Hz之間);
④處理器能夠支持容納一定量數據的硬體堆棧;
⑤處理器有將堆棧指針和其他寄存器讀出和存儲到堆棧或內存中的指令。
軟體方面,主要是一些與處理器相關的代碼移植,其分布在OS_CPU.H、OS_CPU_C.C和OS_CPU_A.ASM這3個不同的文件中。
⑹ 在linux環境下,我們使用C語言編程,如何正確計算CPU使用率(不限/proc/stat)
我的笨方法:
以/proc/stat為例,它裡面的內容如下:(第一行的幾個單詞,是我為了便於說明,另外標注的)
user nice system idle iowait irq softirq
cpu 65376847 362756 2405159 10834971593 3765180 93399 2395097 0
cpu0 7680302 5263 111909 1355640955 47680 0 185343 0
cpu1 6527638 2261 327795 1356540189 249151 1 24242 0
intr 21259182 122 97003 0 0 0 0 0 0 1 44 0 0 4290639 0 0 0 742540 1330673 0 0 0 0 0 111 173 0 0 0 0 161039 191398 10286 2440 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
ctxt 42582486
btime 1376534806
processes 346513
procs_running 1
procs_blocked 0
softirq 21851001 2 9105868 18006 318205 256633 2 1384334 1159984 60546 9547421
---------------------------- 分割線------------------------------
說明:
user:從系統啟動開始累計到當前時刻,用戶態的CPU時間(單位:jiffies) ,不包含 nice值為負進程。1jiffies=0.01秒
nice:從系統啟動開始累計到當前時刻,nice值為負的進程所佔用的CPU時間(單位:jiffies)
system:從系統啟動開始累計到當前時刻,核心時間(單位:jiffies)
idle:從系統啟動開始累計到當前時刻,除硬碟IO等待時間以外其它等待時間(單位:jiffies)
iowait:從系統啟動開始累計到當前時刻,硬碟IO等待時間(單位:jiffies) ,
irq:從系統啟動開始累計到當前時刻,硬中斷時間(單位:jiffies)
softirq:從系統啟動開始累計到當前時刻,軟中斷時間(單位:jiffies)
CPU時間=user+system+nice+idle+iowait+irq+softirq
-------------------------下面這幾項可以不看------------------
intr:第一個為自系統啟動以來,發生的所有的中斷的次數;然後每個數對應一個特定的中斷自系統啟動以來所發生的次數。
ctxt:自系統啟動以來CPU發生的上下文交換的次數。
btime:從系統啟動到現在為止的時間,單位為秒。
processes:自系統啟動以來所創建的任務的個數目。
procs_running:當前運行隊列的任務的數目。
procs_blocked:當前被阻塞的任務的數目。
-----------------------------計算方法-----------------------------
那麼CPU利用率可以使用以下兩個方法。先取兩個采樣點,然後計算其差值:
cpu usage=(idle2-idle1)/(cpu2-cpu1)*100
cpu usage=[(user_2 +sys_2+nice_2) - (user_1 + sys_1+nice_1)]/(total_2 - total_1)*100
=============================================
建議:要用C語言來編程實現的話,提取各項數據會比較復雜,而用shell腳本來提取的話,會簡單的多;所以你可以嘗試用腳本來提取數據並計算出CPU使用率,然後在C程序中用system( )函數來調用這個腳本。
⑺ C語言 編程實現獲取cpu信息
耐心看看啊,運行通過啦,希望對你有幫助啊!
#include<stdio.h>
unsigned int veax;
unsigned int vebx;
unsigned int vedx;
unsigned int vecx;
//執行CPUID指令
void cpuid(unsigned int veax1)
{
_asm{
mov eax,veax1
cpuid
mov veax,eax
mov vebx,ebx
mov vecx,ecx
mov vedx,edx
}
}
//做移位操作,把寄存器中的ASCII碼,以字元形式輸出
void LeftMove(unsigned int var)
{
printf("%c",var);
for(int i=0;i<3;i++)
{
var=(var>>;
printf("%c",var);
}
}
//做移位操作,把寄存器中的值以「%d」形式輸出
void LM(unsigned int var)
{
printf("%d",var);
for(int i=0;i<3;i++)
{
var=(var>>;
printf("%d",var);
}
}
//得到CPU的生產廠商(當EAX值為0時),依次存放在EBX,EDX,ECX中
void getCpuName()
{
cpuid(0);
LeftMove(vebx);
LeftMove(vedx);
LeftMove(vecx);
printf("\
";
}
//得到CPU的商標,當EAX中的值為0x80000003和0x80000004時分別返回16個字元,組成商標
//依次存放在EAX,EBX,ECX,EDX中
void getCpuBrand()
{
for(int j=0;j<2;j++)
{
cpuid(0x80000003+j);
LeftMove(veax);
LeftMove(vebx);
LeftMove(vecx);
LeftMove(vedx);
}
printf("\
";
}
//獲得CPU的特性,參數是eax = 1,返回值放在edx和ecx,通過驗證edx或者ecx的某一個bit,
//可以獲得CPU的一個特性是否被支持。比如說,edx的bit 32代表是否支持MMX,
//edx的bit 28代表是否支持Hyper-Threading,ecx的bit 7代表是否支持speed sted。
void getCpuFeature()
{//由於特性太多,無法一一編寫,需要的時候再寫,方法是一樣的。
}
//獲得CPU序列號,獲得序列號需要兩個步驟,首先用eax = 1做參數,返回的eax中存儲序列號的高兩個WORD。
//用eax = 3做參數,返回ecx和edx按從低位到高位的順序存儲前4個WORD。
void getCpuSeris()
{
cpuid(1);
LM(veax);
cpuid(3);
LM(vecx);
LM(vedx);
printf("\
";
}
void main()
{
getCpuName();
getCpuBrand();
getCpuSeris();
}
⑻ Linux下調試編寫並調試C語言程序,怎麼查看它的內存和CPU信息GDB中可以實現嗎
內存和cpu是硬體的概念,在程序中只有被映射後的內存和線程/進程的概念,具體如何調度程序版的內存地址和線程權/進程的掛起和運行都是操作系統來做的。使用gdb能夠查看當前程序各個變數的內存數據內容此時的內存地址對程序員來說是沒什麼用的(除非是做硬體開發,可能會需要),gdb還能夠查看當前程序中那些線程被掛起或正在運行,但查詢不到當前線程在哪個cpu上運行。
⑼ 在Linux C語言下,可執行的Shell腳本文件與編譯之後的C可執行文件的區別有哪些
shell腳本是shell的一種擴展功能,也就是shell會根據你所寫的腳本一條一條的去執行,C寫的程序是直接給CPU執行的。一般來說做一些簡單功能,特別是和shell有關的。我們會用shell腳本,如系統環境的設定,開機後執行系統的初始化等。做一些功能復雜的,特別人用戶自已所想到的功能時會用C語。另外如果程序執行是要用到root許可權是最好也用C語。
(1)Shell腳本與Windows/Dos下的批處理相似,也就是用各類命令預先放入到一個文件中,方便一次性執行的一個程序文件,主要是方便管理員進行設置或者管理用的。但是它比Windows下的批處理更強大,比用其他編程程序編輯的程序效率更高,它使用了Linux/Unix下的命令。
(2)C語言的設計目標是提供一種能以簡易的方式編譯、處理低級存儲器、產生少量的機器碼以及不需要任何運行環境支持便能運行的編程語言。
⑽ Linux系統下如何用C/C++語言編寫程序查看cpu_id的值
在linux當然是GNU編譯器工具
C語言的GCC;
C + + G+ +;
G+ +
view/456776.html?WTP = TT「目標=」_blank「> http://ke..com/view/456776.html?wtp=tt
准備資源參考