- 相關(guān)推薦
神州數(shù)碼筆試經(jīng)歷
30個選擇,兩個編程,總體不是很難,還是很基礎(chǔ)的東西~
有幾個不太確定的總結(jié)一下:
1.%o。太遙遠(yuǎn)的都忘得不行了~
C語言書真是個寶貝~%o是以八進(jìn)制形式輸出整數(shù)。%x是以十六進(jìn)制數(shù)形式輸出整數(shù)。%e以指數(shù)形式輸出實數(shù)。%g用來輸出實數(shù),它根據(jù)數(shù)值的大小自動選擇f或e格式(選擇輸出時占寬度較小的一種)輸出,且不輸出無意義的零。
2.進(jìn)程和線程的區(qū)別
什么是進(jìn)程(Process):普通的解釋就是,進(jìn)程是程序的一次執(zhí)行;而什么是線程(Thread),線程可以理解為進(jìn)程中的執(zhí)行的一段程序片段。在一個多任務(wù)環(huán)境中下面的概念可以幫助我們理解兩者間的差別:
進(jìn)程間是獨立的,這表現(xiàn)在內(nèi)存空間,上下文環(huán)境;線程運行在進(jìn)程空間內(nèi)。
一般來講(不使用特殊技術(shù))進(jìn)程是無法突破進(jìn)程邊界存取其他進(jìn)程內(nèi)的存儲空間;而線程由于處于進(jìn)程空間內(nèi),所以同一進(jìn)程所產(chǎn)生的線程共享同一內(nèi)存空間。
同一進(jìn)程中的兩段代碼不能夠同時執(zhí)行,除非引入線程。
線程是屬于進(jìn)程的,當(dāng)進(jìn)程退出時該進(jìn)程所產(chǎn)生的線程都會被強(qiáng)制退出并清除。
線程占用的資源要少于進(jìn)程所占用的資源。
進(jìn)程和線程都可以有優(yōu)先級。
在線程系統(tǒng)中進(jìn)程也是一個線程?梢詫⑦M(jìn)程理解為一個程序的第一個線程。
說法一:進(jìn)程是具有一定獨立功能的程序關(guān)于某個數(shù)據(jù)集合上的一次運行活動,進(jìn)程是系統(tǒng)進(jìn)行資源分配和調(diào)度的一個獨立單位.
線程是進(jìn)程的一個實體,是CPU調(diào)度和分派的基本單位,它是比進(jìn)程更小的能獨立運行的基本單位.線程自己基本上不擁有系統(tǒng)資源,只擁有一點在運行中必不可少的資源(如程序計數(shù)器,一組寄存器和棧),但是它可與同屬一個進(jìn)程的其他的線程共享進(jìn)程所擁有的全部資源.
一個線程可以創(chuàng)建和撤銷另一個線程;同一個進(jìn)程中的多個線程之間可以并發(fā)執(zhí)行
說法二:進(jìn)程和線程都是由操作系統(tǒng)所體會的程序運行的基本單元,系統(tǒng)利用該基本單元實現(xiàn)系統(tǒng)對應(yīng)用的并發(fā)性。進(jìn)程和線程的區(qū)別在于:
簡而言之,一個程序至少有一個進(jìn)程,一個進(jìn)程至少有一個線程.
線程的劃分尺度小于進(jìn)程,使得多線程程序的并發(fā)性高。
另外,進(jìn)程在執(zhí)行過程中擁有獨立的內(nèi)存單元,而多個線程共享內(nèi)存,從而極大地提高了程序的運行效率。
線程在執(zhí)行過程中與進(jìn)程還是有區(qū)別的。每個獨立的線程有一個程序運行的入口、順序執(zhí)行序列和程序的出口。但是線程不能夠獨立執(zhí)行,必須依存在應(yīng)用程序中,由應(yīng)用程序提供多個線程執(zhí)行控制。
從邏輯角度來看,多線程的意義在于一個應(yīng)用程序中,有多個執(zhí)行部分可以同時執(zhí)行。但操作系統(tǒng)并沒有將多個線程看做多個獨立的應(yīng)用,來實現(xiàn)進(jìn)程的調(diào)度和管理以及資源分配。這就是進(jìn)程和線程的重要區(qū)別。
說法三:多線程共存于應(yīng)用程序中是現(xiàn)代操作系統(tǒng)中的基本特征和重要標(biāo)志。用過UNIX操作系統(tǒng)的讀者知道進(jìn)程,在UNIX操作系統(tǒng)中,每個應(yīng)用程序的執(zhí)行都在操作系統(tǒng)內(nèi)核中登記一個進(jìn)程標(biāo)志,操作系統(tǒng)根據(jù)分配的標(biāo)志對應(yīng)用程序的執(zhí)行進(jìn)行調(diào)度和系統(tǒng)資源分配,但進(jìn)程和線程有什么區(qū)別呢?
進(jìn)程和線程都是由操作系統(tǒng)所體會的程序運行的基本單元,系統(tǒng)利用該基本單元實現(xiàn)系統(tǒng)對應(yīng)用的并發(fā)性。進(jìn)程和線程的區(qū)別在于:
線程的劃分尺度小于進(jìn)程,使得多線程程序的并發(fā)性搞。
另外,進(jìn)程在執(zhí)行過程中擁有獨立的內(nèi)存單元,而多個線程共享內(nèi)存,從而極大地提高了程序的運行效率。
線程在執(zhí)行過程中與進(jìn)程還是有區(qū)別的。每個獨立的線程有一個程序運行的入口、順序執(zhí)行序列和程序的出口。但是線程不能夠獨立執(zhí)行,必須依存在應(yīng)用程序中,由應(yīng)用程序提供多個線程執(zhí)行控制。
從邏輯角度來看,多線程的意義在于一個應(yīng)用程序中,有多個執(zhí)行部分可以同時執(zhí)行。但操作系統(tǒng)并沒有將多個線程看做多個獨立的應(yīng)用,來實現(xiàn)進(jìn)程的調(diào)度和管理以及資源分配。這就是進(jìn)程和線程的重要區(qū)別。
進(jìn)程(Process)是最初定義在Unix等多用戶、多任務(wù)操作系統(tǒng)環(huán)境下用于表示應(yīng)用程序在內(nèi)存環(huán)境中基本執(zhí)行單元的概念。以Unix操作系統(tǒng)為例,進(jìn)程是Unix操作系統(tǒng)環(huán)境中的基本成分、是系統(tǒng)資源分配的基本單位。Unix操作系統(tǒng)中完成的幾乎所有用戶管理和資源分配等工作都是通過操作系統(tǒng)對應(yīng)用程序進(jìn)程的控制來實現(xiàn)的。
C、C++、Java等語言編寫的源程序經(jīng)相應(yīng)的編譯器編譯成可執(zhí)行文件后,提交給計算機(jī)處理器運行。這時,處在可執(zhí)行狀態(tài)中的應(yīng)用程序稱為進(jìn)程。從用戶角度來看,進(jìn)程是應(yīng)用程序的一個執(zhí)行過程。從操作系統(tǒng)核心角度來看,進(jìn)程代表的是操作系統(tǒng)分配的內(nèi)存、CPU時間片等資源的基本單位,是為正在運行的程序提供的運行環(huán)境。進(jìn)程與應(yīng)用程序的區(qū)別在于應(yīng)用程序作為一個靜態(tài)文件存儲在計算機(jī)系統(tǒng)的硬盤等存儲空間中,而進(jìn)程則是處于動態(tài)條件下由操作系統(tǒng)維護(hù)的系統(tǒng)資源管理實體。多任務(wù)環(huán)境下應(yīng)用程序進(jìn)程的主要特點包括:
●進(jìn)程在執(zhí)行過程中有內(nèi)存單元的初始入口點,并且進(jìn)程存活過程中始終擁有獨立的內(nèi)存地址空間;
●進(jìn)程的生存期狀態(tài)包括創(chuàng)建、就緒、運行、阻塞和死亡等類型;
●從應(yīng)用程序進(jìn)程在執(zhí)行過程中向CPU發(fā)出的運行指令形式不同,可以將進(jìn)程的狀態(tài)分為用戶態(tài)和核心態(tài)。處于用戶態(tài)下的進(jìn)程執(zhí)行的是應(yīng)用程序指令、處于核心態(tài)下的應(yīng)用程序進(jìn)程執(zhí)行的是操作系統(tǒng)指令。
在Unix操作系統(tǒng)啟動過程中,系統(tǒng)自動創(chuàng)建swapper、init等系統(tǒng)進(jìn)程,用于管理內(nèi)存資源以及對用戶進(jìn)程進(jìn)行調(diào)度等。在Unix環(huán)境下無論是由操作系統(tǒng)創(chuàng)建的進(jìn)程還要由應(yīng)用程序執(zhí)行創(chuàng)建的進(jìn)程,均擁有唯一的進(jìn)程標(biāo)識(PID)。
說法四:應(yīng)用程序在執(zhí)行過程中存在一個內(nèi)存空間的初始入口點地址、一個程序執(zhí)行過程中的代碼執(zhí)行序列以及用于標(biāo)識進(jìn)程結(jié)束的內(nèi)存出口點地址,在進(jìn)程執(zhí)行過程中的每一時間點均有唯一的處理器指令與內(nèi)存單元地址相對應(yīng)。
Java語言中定義的線程(Thread)同樣包括一個內(nèi)存入口點地址、一個出口點地址以及能夠順序執(zhí)行的代碼序列。但是進(jìn)程與線程的重要區(qū)別在于線程不能夠單獨執(zhí)行,它必須運行在處于活動狀態(tài)的應(yīng)用程序進(jìn)程中,因此可以定義線程是程序內(nèi)部的具有并發(fā)性的順序代碼流。
Unix操作系統(tǒng)和Microsoft Windows操作系統(tǒng)支持多用戶、多進(jìn)程的并發(fā)執(zhí)行,而Java語言支持應(yīng)用程序進(jìn)程內(nèi)部的多個執(zhí)行線程的并發(fā)執(zhí)行。多線程的意義在于一個應(yīng)用程序的多個邏輯單元可以并發(fā)地執(zhí)行。但是多線程并不意味著多個用戶進(jìn)程在執(zhí)行,操作系統(tǒng)也不把每個線程作為獨立的進(jìn)程來分配獨立的系統(tǒng)資源。進(jìn)程可以創(chuàng)建其子進(jìn)程,子進(jìn)程與父進(jìn)程擁有不同的可執(zhí)行代碼和數(shù)據(jù)內(nèi)存空間。而在用于代表應(yīng)用程序的進(jìn)程中多個線程共享數(shù)據(jù)內(nèi)存空間,但保持每個線程擁有獨立的執(zhí)行堆棧和程序執(zhí)行上下文(Context)。
基于上述區(qū)別,線程也可以稱為輕型進(jìn)程 (Light Weight Process,LWP)。不同線程間允許任務(wù)協(xié)作和數(shù)據(jù)交換,使得在計算機(jī)系統(tǒng)資源消耗等方面非常廉價。
線程需要操作系統(tǒng)的支持,不是所有類型的計算機(jī)都支持多線程應(yīng)用程序。Java程序設(shè)計語言將線程支持與語言運行環(huán)境結(jié)合在一起,提供了多任務(wù)并發(fā)執(zhí)行的能力。這就好比一個人在處理家務(wù)的過程中,將衣服放到洗衣機(jī)中自動洗滌后將大米放在電飯鍋里,然后開始做菜。等菜做好了,飯熟了同時衣服也洗好了。
需要注意的是:在應(yīng)用程序中使用多線程不會增加 CPU 的數(shù)據(jù)處理能力。只有在多CPU 的計算機(jī)或者在網(wǎng)絡(luò)計算體系結(jié)構(gòu)下,將Java程序劃分為多個并發(fā)執(zhí)行線程后,同時啟動多個線程運行,使不同的線程運行在基于不同處理器的Java虛擬機(jī)中,才能提高應(yīng)用程序的執(zhí)行效率。
3.靜態(tài)成員
class test{
public:
test(){}
~test(){}
public:
//靜態(tài)成員函數(shù)
static int getCount(){
return m_nCount;
}
private:
//靜態(tài)數(shù)據(jù)成員
static int m_nCount;
};
int test::m_nCount=0;
靜態(tài)數(shù)據(jù)成員和普通數(shù)據(jù)成員區(qū)別較大,體現(xiàn)在下面幾點:
(1)普通數(shù)據(jù)成員屬于類的一個具體的對象,只有對象被創(chuàng)建了,普通數(shù)據(jù)成員才會被分配內(nèi)存。而靜態(tài)數(shù)據(jù)成員屬于整個類,即使沒有任何對象創(chuàng)建,類的靜態(tài)數(shù)據(jù)成員變量也存在。
(2)因為類的靜態(tài)數(shù)據(jù)成員的存在不依賴與于任何類對象的存在,類的靜態(tài)數(shù)據(jù)成員應(yīng)該在代碼中被顯示的初始化,一定要在類外進(jìn)行,例如上例。
(3)外部訪問類的靜態(tài)成員只能通過類名來訪問,例如:test::getCount()。
(4)類的靜態(tài)成員函數(shù)無法直接訪問普通數(shù)據(jù)成員(可以通過類的指針等作為參數(shù)間接訪問),而類的任何成員函數(shù)都可以訪問類的靜態(tài)數(shù)據(jù)成員。
(5)靜態(tài)成員和類的普通成員一樣,也具有public、protected、private3種訪問級別,也可以具有返回值、const修飾符等參數(shù)。
應(yīng)用舉例:
汽車制造商為統(tǒng)計汽車的產(chǎn)量,可以在在汽車類--car類中增加用于計數(shù)的靜態(tài)數(shù)據(jù)成員變量,比如在某個類car中聲明一個static int number;初始化為0。這個number就能被所有car的實例共用。在A的構(gòu)造函數(shù)里加上number++,在A的析構(gòu)函數(shù)里加上number--。那么每生成一個car的實例,number就加一,每銷毀一個car的實例(汽車報廢),number就減一,這樣,number就可以記錄在市場上car的實例。
【神州數(shù)碼筆試經(jīng)歷】相關(guān)文章:
最新神州數(shù)碼筆試題02-25
神州數(shù)碼筆試后的感覺08-10
神州數(shù)碼面試經(jīng)歷11-06
神州數(shù)碼筆試試題分享11-21
筆試經(jīng)歷回憶,筆試經(jīng)歷分享11-21
神州數(shù)碼筆試后的一些感覺07-16
神州數(shù)碼筆試后的一些感覺02-18
google筆試的經(jīng)歷12-12
尼爾森筆試經(jīng)歷11-06
友邦 筆試經(jīng)歷11-21