嗨,你好,陌生人,你的頭發掉光了么ლ(′◉❥◉`ლ),哈,我的還在,氣人不。已經好久沒有更新此文章了,最近很榮幸在公司給大家做了.net7開發實戰培訓,一共8節,已經順利結課,非常感謝各位同事的支持。培訓之后忽然想到這篇文章還沒有補全,然后又到了一年一度金三銀四的季節,所以接下來要完善一下此文章,希望可以幫助到大家(有些問題還沒補全答案,如果沒有大家先思考一下怎么回答,如果你有更好的問題或者答案,歡迎在下方評論)。
目前樓主在備考高項(已獲取PMP,ACP證書),要是你也在考,我們可以一起交流學習。
先說一下我培訓課程的目錄:net7入門,依賴注入,中間件,Orm,DDD,Identity,docker,微服務入門。下面的問題也會在我的PPT中找到。
【騰訊文檔】.net7培訓課程
https://docs.qq.com/pdf/DYml2WmtKR1hQblRh?
【項目】git地址:
https://gitee.com/seven-lu/IntelliRay.git
net7面試題
1、.netcore框架為什么可以跨平台?
2、net7的啟動過程是core框架的核心,請簡要說明net7的啟動過程。
3、如何獲取appsetting配置文件中的數據?
4、請說明你對restfulapi風格的理解。
5、什么是依賴注入?
依賴注入是ASP.Net Core的核心,依賴注入我們可以分開來理解
依賴:當一個類需要另一個類協作來完成工作的時候就產生了依賴
注入:把依賴的創建丟給其它人,自己只負責使用,其它人丟給你依賴的這個過程理解為注入。
startup ConfigureServices方法 可以使用netcore自帶的di或者使用第三方autofac
jesse大佬文章: https://www.cnblogs.com/jesse2013/p/di-in-aspnetcore.html
6、依賴注入的生命周期有哪些,請詳細說明含義。
Transient:每一次GetService都會創建一個新的實例
Scoped:在同一個Scope內只初始化一個實例 ,可以理解為( 每一個request級別只創建一個實例,同一個http request會在一個 scope內)
Singleton:整個應用程序生命周期內只創建一個實例
7、依賴注入的方式都有什么?
8、什么是中間件,談談你對中間件的理解
中間件在這里是指注入到應用中處理請求和響應的組件。
startup Configure方法
9、中間中有map,use和run三種方式,說明每種方式的功能。
中間件在這里是指注入到應用中處理請求和響應的組件。
startup Configure方法
10、什么是認證,什么是授權?
11、請列出Outh2.0四種授權模式
12、EFCore 怎么做性能優化
EF SQL監控 ,優化效率
使用AsNoTracking(),無跟蹤查詢技術
EF預熱
對於復雜的可以使用sqlquery 用sql語句查詢
擴展問題
1、說一下常用的狀態碼,並分別說出他們的含義。
2、如何理解敏捷開發。
3、談談你理解的軟件開發流程。
架構層面,設計思想
1、談一談你對DDD思想的理解。
DDD,領域驅動設計。就是通過領域來指導軟件設計,是一種十分抽象的軟件設計思想,它主要分為戰略設計和戰術設計
戰略方面,通過事件風暴進行領域模型的划分,划分出核心域,子域,支撐域,定義通用語言,划分出界限上下文。
在戰術設計方面,ddd將架構分層,“松耦合,高內聚”是架構設計的整體思想。按照DDD思想,可以分為領域層,基礎設施層,應用層,接口層。
接口層為前端用戶提供api接口。基礎設施層可以放一些第三方的服務,數據庫連接等內容。應用層是對領域服務的編排,是很薄的一層(目前我自己的架構,應用的是cqrs,所有的相關邏輯都是放在了應用層,而領域層只是放了實體,因為暫時還不是特別理解領域層的服務和事件都應該寫什么)。領域層包括實體,值對象,聚合根,領域服務,領域事件等內容
2、DDD有四種領域模型,都有什么,在戰術層面是怎么實現的?
1、失血模型
失血模型簡單來說,就是domain object只有屬性的getter/setter方法的純數據類,所有的業務邏輯完全由business object來完成
2、貧血模型
簡單來說,就是domain ojbect包含了不依賴於持久化的領域邏輯,而那些依賴持久化的領域邏輯被分離到Service層。
3、充血模型
充血模型和第二種模型差不多,所不同的就是如何划分業務邏輯,即認為,絕大多業務邏輯都應該被放在domain object里面(包括持久化邏輯),而Service層應該是很薄的一層,僅僅封裝事務和少量邏輯,不和DAO層打交道。
4、脹血模型
基於充血模型的第三個缺點,干脆取消Service層,只剩下domain object和DAO兩層,在domain object的domain logic上面封裝事務。
3、DDD四層架構是什么?
4、談談你對CQRS架構的理解,在net7中通過什么方式實現?
微服務
1、什么是微服務架構,什么時候使用微服務架構?
2、微服務架構的需要注意的問題有哪些?
數據庫
1、mysql的數據引擎有哪些
myisam
innodb
2、數據庫事務
3、什么是sql注入?
利用sql語言漏洞獲得合法身份登陸系統
4、如何做數據庫優化?
設計:存儲引擎,字段類型,范式與逆范式
功能:索引,緩存,分區分表。
架構:主從復制,讀寫分離,負載均衡。
詳解:https://www.cnblogs.com/sharpest/p/10390035.html
docker
1、列出docker常用命令
docker images //查看所有鏡像文件
docker ps //查看運行中的容器
docker ps -a //查看所有容器
docker exec -it xx /bin/bash //進入容器內部
docker logs -f xx //查看容器日志
docker run //啟動容器
docker login //登錄鏡像倉庫
docker pull //拉取鏡像
docker push //推送鏡像
docker save -o //將指定鏡像保存成 tar 歸檔文件
docker load -i //導入使用 [docker save] 命令導出的鏡像
docker cp //用於容器與主機之間的數據拷貝
docker history //查看指定鏡像的創建歷史。
docker build //用於使用 Dockerfile 創建鏡像。
docker tag // 標記本地鏡像,將其歸入某一倉庫。
2、docker部署的方案有哪些,如何將打包的鏡像在另一台機器上運行?
Redis
1、說一說redis數據類型以及使用場景
string 字符串(可以為整形、浮點型和字符串,統稱為元素)
list 列表(實現隊列,元素不唯一,先入先出原則)
set 集合(各不相同的元素)
hash hash散列值(hash的key必須是唯一的,hash 特別適合用於存儲對象)
sort set 有序集合
2、什么是緩存雪崩,緩存擊穿?
緩存雪崩:在請求redis的時候,key大面積失效,導致大量請求到數據庫
緩存擊穿:在請求數據的時候,key值不存在或者失效,導致請求直接穿透到數據庫進行請求
3.數據同步
4.過期時間機制
5.redis持久化方式以及優缺點
RDB:
RDB持久化是指在指定的時間間隔內將內存中的數據集快照寫入磁盤。也是默認的持久化方式.
1、RDB文件緊湊,全量備份,非常適合用於進行備份和災難恢復。
2、生成RDB文件的時候,redis主進程會fork()一個子進程來處理所有保存工作,主進程不需要進行任何磁盤IO操作。
3、RDB 在恢復大數據集時的速度比 AOF 的恢復速度要快。
劣勢
RDB快照是一次全量備份,存儲的是內存數據的二進制序列化形式,存儲上非常緊湊。當進行快照持久化時,會開啟一個子進程專門負責快照持久化,子進程會擁有父進程的內存數據,父進程修改內存子進程不會反應出來,所以在快照持久化期間修改的數據不會被保存,可能丟失數據。
AOF:
redis會將每一個收到的寫命令都通過write函數追加到文件中。通俗的理解就是日志記錄。
優勢:
1、AOF可以更好的保護數據不丟失,一般AOF會每隔1秒,通過一個后台線程執行一次fsync操作,最多丟失1秒鍾的數據。
2、AOF日志文件沒有任何磁盤尋址的開銷,寫入性能非常高,文件不容易破損。
3、AOF日志文件即使過大的時候,出現后台重寫操作,也不會影響客戶端的讀寫。
4、AOF日志文件的命令通過非常可讀的方式進行記錄,這個特性非常適合做災難性的誤刪除的緊急恢復。比如某人不小心用flushall命令清空了所有數據,只要這個時候后台rewrite還沒有發生,那么就可以立即拷貝AOF文件,將最后一條flushall命令給刪了,然后再將該AOF文件放回去,就可以通過恢復機制,自動恢復所有數據
劣勢:
1、對於同一份數據來說,AOF日志文件通常比RDB數據快照文件更大
2、AOF開啟后,支持的寫QPS會比RDB支持的寫QPS低,因為AOF一般會配置成每秒fsync一次日志文件,當然,每秒一次fsync,性能也還是很高的
3、以前AOF發生過bug,就是通過AOF記錄的日志,進行數據恢復的時候,沒有恢復一模一樣的數據出來。
6、redis 單機最大存儲量
7、哨兵模式
c#基礎
1、什么是aop?
面向切面編程-通過預編譯方式和動態代理實現程序功能的統一維護的一種技術。降低業務邏輯部分的耦合度,提高程序的可重用性,提高開發效率。
比較常見的場景是:日志記錄,錯誤捕獲、性能監控等
2、什么是托管和非托管?
托管代碼:是由公共語言運行庫(CLR)執行的代碼,而不是由操作系統直接執行。有關內存管理(內存申請,內存釋放,垃圾回收之類的)全部都是.net的CLR來管理
非托管代碼:直接編譯成目標計算機碼,由操作系統直接執行的代碼,內存回收要繼承IDisposable接口手動回收
3、string和stringbuilder的區別
string 每次內容發生變化,都會生成一個新對象,重新分配內存
stringbuilder 每次操作都是對自身進行操作,而不是生成新的對象
4、ref和out的區別
ref指定的參數在函數調用時候必須初始化,不能為空的引用。而out指定的參數在函數調用時候可以不初始化;
out指定的參數在進入函數時會清空自己,必須在函數內部賦初值。而ref指定的參數不需要。
5、重載與重寫
overload重載:同一個類下,相同的函數名,不同參數列表
override重寫:是對父類的方法進行重寫;基類函數用virtual修飾,派生類用override修飾
注:不能重寫非虛方法或靜態方法
6、一個類可以繼承幾個父類,幾個接口?
在創建一個類的時候只能繼承一個父類 但可以實現多個接口
7、委托和事件,委托中action和func的區別用法
委托是面向對象的、類型安全的,是引用類型。使用delegate關鍵字進行定義
詳解:https://www.cnblogs.com/wangjiming/p/8300103.html
8、常用修飾符
public: 同一程序集中的任何其他代碼或引用該程序集的其他程序集都可以訪問該類型或成員。
private: 只有同一類或結構中的代碼可以訪問該類型或成員。
protected: 只有同一類或結構或者此類的派生類中的代碼才可以訪問該類型或成員。
internal: 同一程序集中的任何代碼都可以訪問該類型或成員,但別的代碼不可以。
9、C#中,string str = null 與 string str =""的區別
String str=null沒有分配內存,String str=""分配了內存
10、是否可以繼承String類
String類是一個最終類,被final修飾,所以不能被繼承
11、String s = new String("xyz");創建了幾個String Object?
兩個對象,一個是“xyx”,一個是指向“xyx”的引用對像s。
12、堆和棧
引用類型存在堆上,值類型存在棧上
13、什么是GC。Idispose的用法
GC,垃圾回收器,用於自動回收托管堆中無效對象的內存,釋放內存空間。
程序在運行過程中 ,有很多對象分配內存空間后,使用一次就不再使用了,這不僅占用內存空間,導致內存溢出,還可能影響程序的性能。所以我們自動釋放內存
原理可參考:https://my.oschina.net/u/4354590/blog/4321333
14、抽象類abstract class與接口interface的異同
同:都不能被實例化。都可以被繼承。都可以包含方法聲明。派生類必須實現抽象類(接口)中未實現的方法。
異:接口可以被多重實現,抽象類只能被單一繼承。
15、using關鍵字的使用場景
作為指令:用於導入其他命名空間中定義的類型或為命名空間創建別名
作為語句:用於定義一個范圍,在此范圍的末尾將釋放對象
16、task異步用法,它和thread有什么區別?
1.什么是thread
當我們提及多線程的時候會想到thread和threadpool,這都是異步操作,threadpool其實就是thread的集合,具有很多優勢,不過在任務多的時候全局隊列會存在競爭而消耗資源。thread默認為前台線程,主程序必須等線程跑完才會關閉,而threadpool相反。
總結:threadpool確實比thread性能優,但是兩者都沒有很好的api區控制,如果線程執行無響應就只能等待結束,從而誕生了task任務。
2.什么是task
task簡單地看就是任務,那和thread有什么區別呢?Task的背后的實現也是使用了線程池線程,但它的性能優於ThreadPoll,因為它使用的不是線程池的全局隊列,而是使用的本地隊列,使線程之間的資源競爭減少。同時Task提供了豐富的API來管理線程、控制。但是相對前面的兩種耗內存,Task依賴於CPU對於多核的CPU性能遠超前兩者,單核的CPU三者的性能沒什么差別。
17、異步方調用同步方法和同步方法調用異步方法性能上有什么區別?
18、靜態類在程序的生命周期,何時初始化,靜態類的靜態方法和類的靜態方法啥區別
其他大佬整理的,希望可以幫助到你
https://www.yuque.com/ysgstudyhard/da6e0c/wlcivg
https://zhuanlan.zhihu.com/p/526163635