高級軟件工程師面試題
高級軟件工程師面試題
高級軟件工程師面試的時候,會被問到哪些問題呢?下面是學習啦小編為大家帶來的高級軟件工程師面試題,相信對你會有幫助的。
高級軟件工程師面試題(一)
你對MVC的理解,MVC有什么優缺點?結合Struts,說明在一個Web應用如何去使用?
答:
MVC設計模式(應用觀察者模式的框架模式)
M: Model(Business process layer),模型,操作數據的業務處理層,并獨立于表現層(Independent of presentation)。
V: View(Presentation layer),視圖,通過客戶端數據類型顯示數據,并回顯模型層的執行結果。 C: Controller(Control layer),控制器,也就是視圖層和模型層橋梁,控制數據的流向,接受視圖層發出的事件,并重繪視圖
MVC框架的一種實現模型
模型二(Servlet-centric):
JSP+Servlet+JavaBean,以控制為核心,JSP只負責顯示和收集數據,Sevlet,連接視圖和模型,將視圖層數據,發送給模型層,JavaBean,分為業務類和數據實體,業務類處理業務數據,數據實體,承載數據,基本上大多數的項目都是使用這種MVC的實現模式。
StrutsMVC框架(Web application frameworks)
Struts是使用MVC的實現模式二來實現的,也就是以控制器為核心。
Struts提供了一些組件使用MVC開發應用程序:
Model:Struts沒有提供model類。這個商業邏輯必須由Web應用程序的開發者以JavaBean或EJB的形式提供
View:Struts提供了action form創建form bean, 用于在controller和view間傳輸數據。此外,Struts提供了自定義JSP標簽庫,輔助開發者用JSP創建交互式的以表單為基礎的應用程序,應用程序資源文件保留了一些文本常量和錯誤消息,可轉變為其它語言,可用于JSP中。
Controller:Struts提供了一個核心的控制器ActionServlet,通過這個核心的控制器來調用其他用戶注冊了的自定義的控制器Action,自定義Action需要符合Struts的自定義Action規范,還需要在struts-config.xml的特定配置文件中進行配置,接收JSP輸入字段形成Action form,然后調用一個Action控制器。Action控制器中提供了model的邏輯接口。
高級軟件工程師面試題(二)
什么是WebService?
答:
WebService是一個SOA(面向服務的編程)的架構,它是不依賴于語言,不依賴于平臺,可以實現不同的語言間的相互調用,通過Internet進行基于Http協議的網絡應用間的交互。
WebService實現不同語言間的調用,是依托于一個標準,webservice是需要遵守WSDL(web服務定義語言)/SOAP(簡單請求協議)規范的。
WebService=WSDL+SOAP+UDDI(webservice的注冊)
Soap是由Soap的part和0個或多個附件組成,一般只有part,在part中有Envelope和Body。
Web Service是通過提供標準的協議和接口,可以讓不同的程序集成的一種SOA架構。
Web Service的優點
(1) 可以讓異構的程序相互訪問(跨平臺)
(2) 松耦合
(3) 基于標準協議(通用語言,允許其他程序訪問)
Web Service的基本原理
(1) Service Provider采用WSDL描述服務
(2) Service Provider 采用UDDI將服務的描述文件發布到UDDI服務器(Register server)
(3) Service Requestor在UDDI服務器上查詢并 獲取WSDL文件
(4) Service requestor將請求綁定到SOAP,并訪問相應的服務。
高級軟件工程師面試題(三)
什么是中間件?
中間件就是程序中可織入的,可重用的,與業務邏輯無關的各種組件。
中間件(middleware)是基礎軟件的一大類,屬于可復用軟件的范疇。顧名思義,中間件處于操作系統軟件與用戶的應用軟件的中間。中間件在操作系統、網絡和數據庫之上,應用軟件的下層,總的作用是為處于自己上層的應用軟件提供運行與開發的環境,幫助用戶靈活、高效地開發和集成復雜的應用軟件。
在眾多關于中間件的定義中,比較普遍被接受的是IDC表述的:中間件是一種獨立的系統軟件或服務程序,分布式應用軟件借助這種軟件在不同的技術之間共享資源,中間件位于客戶機服務器的操作系統之上,管理計算資源和網絡通信。
分類:數據訪問中間件,遠程調用中間件,消息中間件,交易中間件,對象中間件。 舉例:
1,RMI(Remote Method Invocations, 遠程調用)
2,Load Balancing(負載均衡,將訪問負荷分散到各個服務器中)
3,Transparent Fail-over(透明的故障切換)
4,Clustering(集群,用多個小的服務器代替大型機)
5,Back-end-Integration(后端集成,用現有的、新開發的系統如何去集成遺留的系統) 6,Transaction事務(全局/局部)全局事務(分布式事務)局部事務(在同一數據庫聯接內的事務)
7,Dynamic Redeployment(動態重新部署,在不停止原系統的情況下,部署新的系統) 8,System Management(系統管理)
9,Threading(多線程處理)
10,Message-oriented Middleware面向消息的中間件(異步的調用編程)
11,Component Life Cycle(組件的生命周期管理)
12,Resource pooling(資源池)
13,Security(安全)
14,Caching(緩存)
看過“高級軟件工程師面試題”的人還看了: