華為c/c++筆試題
1.Windows是內核級線程么。
答:見下一題
2.Linux有內核級線程么。
答:線程通常被定義為一個進程中代碼的不同執行路線。從實現方式上劃分,線程有兩種類型:“用戶級線程”和“內核級線程”。 用戶線程指不需要內核支持而在用戶程序中實現的線程,其不依賴于操作系統核心,應用進程利用線程庫提供創建、同步、調度和管理線程的函數來控制用戶線程。這種線程甚至在象 DOS 這樣的操作系統中也可實現,但線程的調度需要用戶程序完成,這有些類似 Windows 3.x 的協作式多任務。另外一種則需要內核的參與,由內核完成線程的調度。其依賴于操作系統核心,由內核的內部需求進行創建和撤銷,這兩種模型各有其好處和缺點。用戶線程不需要額外的內核開支,并且用戶態線程的實現方式可以被定制或修改以適應特殊應用的要求,但是當一個線程因 I/O 而處于等待狀態時,整個進程就會被調度程序切換為等待狀態,其他線程得不到運行的機會;而內核線程則沒有各個限制,有利于發揮多處理器的.并發優勢,但卻占用了更多的系統開支。
Windows NT和OS/2支持內核線程。Linux 支持內核級的多線程
3.C++中什么數據分配在;蚨阎,New分配數據是在近堆還是遠堆中?
答:棧: 存放局部變量,函數調用參數,函數返回值,函數返回地址。由系統管理堆: 程序運行時動態申請,new和malloc申請的內存就在堆上
4.使用線程是如何防止出現大的波峰。
答:意思是如何防止同時產生大量的線程,方法是使用線程池,線程池具有可以同時提高調度效率和限制資源使用的好處,線程池中的線程達到最大數時,其他線程就會排隊等候。
5函數模板與類模板有什么區別?
答:函數模板的實例化是由編譯程序在處理函數調用時自動完成的,而類模板的實例化必須由程序員在程序中顯式地指定。
6一般數據庫若出現日志滿了,會出現什么情況,是否還能使用?
答:只能執行查詢等讀操作,不能執行更改,備份等寫操作,原因是任何寫操作都要記錄日志。也就是說基本上處于不能使用的狀態。
7 SQL Server是否支持行級鎖,有什么好處?
答:支持,設立封鎖機制主要是為了對并發操作進行控制,對干擾進行封鎖,保證數據的一致性和準確性,行級封鎖確保在用戶取得被更新的行到該行進行更新這段時間內不被其它用戶所修改。因而行級鎖即可保證數據的一致性又能提高數據操作的迸發性。
8如果數據庫滿了會出現什么情況,是否還能使用?
答:見16
9 關于內存對齊的問題以及sizof()的輸出
答:編譯器自動對齊的原因:為了提高程序的性能,數據結構(尤其是棧)應該盡可能地在自然邊界上對齊。原因在于,為了訪問未對齊的內存,處理器需要作兩次內存訪問;然而,對齊的內存訪問僅需要一次訪問。
【華為c/c++筆試題】相關文章:
華為C++筆試題11-23
2016年華為認證C/C++筆試題目11-06
C/C++面試題目12-12
聯想C++筆試題11-23
Sony C++筆試題12-19
華為2017筆試題08-16
C++筆試題目分享12-20
華為2017筆試試題08-10
C,C++的幾個面試題小集11-24