20200117 .net 001

来源:https://www.cnblogs.com/2eggs/archive/2020/01/17/12205249.html

第一部分:面向對象 封裝 繼承(里氏轉換) 多態第二部分:值類型、引用類型、字元串操作第三部分:集合文件操作第四部分:正則表達式第五部分:XML操作第六部分:委托、事件第七部分:反射。 //存儲著我們當前正在運行的進程//Process[] pro = Process.GetProcesses(); ...


第一部分:面向對象 封裝 繼承(里氏轉換) 多態
第二部分:值類型、引用類型、字元串操作
第三部分:集合文件操作
第四部分:正則表達式
第五部分:XML操作
第六部分:委托、事件
第七部分:反射。

 

1、變數的命名
首先我們要保證的就是變數的名稱一定要有意義(就是我們看到了變數的名字,就知道變數在這段程式中的作用)
Camel:多餘用給變數或者欄位命名,第一個單詞的首字母小寫,其餘每個單詞的首字母大寫。
我們給欄位命名,前面必須加下劃線。
_highSchoolStudent
Pascal:要求我們每個單詞的首字母都要大寫,其餘每個單詞的首字母小寫。
HighSchoolStudent

int max=	GetMax();
int min=	GetMin();


2、進程	
一個應用程式就是一個進程,而一個進程又是由多個線程組成的。
進程幫助我們在記憶體中分配應用程式執行所需要的空間。

//存儲著我們當前正在運行的進程
//Process[] pro = Process.GetProcesses();
//foreach (var item in pro)
//{
// //item.Kill();不試的不是爺們
// Console.WriteLine(item.ProcessName);
//}
//使用進程來打開應用程式
//Process.Start("notepad");//打開記事本
//Process.Start("mspaint");//打開畫圖工具
//Process.Start("iexplore", "http://www.baidu.com");
//Process.Start("calc");//打開計算器
//使用進程來打開文件
//封裝我們要打開的文件 但是並不去打開這個文件
ProcessStartInfo psi = new ProcessStartInfo(@"C:\Users\SpringRain\Desktop\打開文件練習.exe");
//創建進程對象
Process pro = new Process();
//告訴進程要打開的文件信息
pro.StartInfo = psi;
//調用函數打開
pro.Start();
Console.ReadKey();




----> 我們可以通過進程來直接操作應用程式。 3、面向對象複習 類決定了對象將要擁有的屬性和行為。

class BaseFile
{
//欄位、屬性、構造函數、函數、索引器
private string _filePath;
public string FilePath//ctrl+R+E
{
get { return _filePath; }
set { _filePath = value; }
}

//自動屬性 prop+兩下tab
public string FileName { get; set; }

public BaseFile(string filePath, string fileName)
{
this.FilePath = filePath;
this.FileName = fileName;
}


//設計一個函數 用來打開指定的文件
public void OpenFile()
{
ProcessStartInfo psi = new ProcessStartInfo(this.FilePath + "\\" + this.FileName);
Process pro = new Process();
pro.StartInfo = psi;
pro.Start();
}
}

封裝:
--->減少了大量的冗餘代碼
--->封裝將一坨很難理解的功能封裝起來,但是對外提供了一個很簡單的使用介面。我們會使用就OK。
繼承:
--->減少了類中的冗餘代碼
--->讓類與類產生了關係,為多態打下了基礎。
特性:
單根性:一個子類只能有一個父類
傳遞性:爺爺類 爹類 兒子類
里氏轉換:
1、子類可以賦值給父類
2、如果父類中裝的是子類對象,則可以將這個父類轉換為對應的子類對象
---->關鍵字
1、is:返回bool類型,指示是否可以做這個轉換
2、as:如果轉換成功,則返回對象,否則返回null
作用:我們可以將所有的子類都當做是父類來看,針對父類進行編程,寫出通用的代碼,適應需求的不斷改變。	
多態:
--->虛方法
virtual override
--->抽象類
abstract override
--->介面
interface 
4、關鍵字
new
1、創建對象
--->在堆中開闢空間
--->在開闢的堆空間中創建對象
--->調用對象的構造函數
2、隱藏父類的成員	
this
1、代表當前類的對象
2、顯示的調用自己的構造函數
base
1、顯示調用父類的構造函數
2、調用父類的成員



5、抽象類實現多態練習
模擬將外部的移動存儲設備插到電腦上進行讀寫數據。
U盤
Read()
Write()
移動硬碟
Read();
Write();
MP3
Read();
Write();
PlayMusic();
手機....平板電腦......


6、介面
---->介面是一種能力
---->介面也是一種規範
---->如果你繼承了這個介面,就必須按照介面的要求來實現這個介面。
interface I開頭...able結尾


7、石頭剪刀布案例
玩家
--->出拳的方法,是我們指定的
電腦
--->出拳的方法,隨機的
裁判
--->判斷輸贏或者平手

石頭1 剪刀2 布3
玩家贏:石頭1 剪刀2 =-1 剪刀2 布3 =-1 布3 石頭1=2
平手:玩家-電腦=0;
電腦贏:

 

8、訪問修飾符
public private internal protected protected internal
public:在哪都可以訪問
private:私有的,只能在當前類的內部進行訪問
internal:只能在當前程式集中訪問。
protected:受保護的,可以在當前類以及該類的子類中訪問

註意點:
1、能夠修飾類的訪問修飾符只有兩個:public internal(預設就是internal)。
2、在同一個項目中,public的許可權跟internal是一樣的。
3、子類的訪問許可權不能高於父類。
 

  

 

1、導入命名空間
	命名空間就是類的"文件夾"。類就是"文件夾"中的文件。需要導入命名空間
	添加引用:
		如果我需要在一個項目中,訪問另一個項目中的某一個類
			--->添加對另一個項目的引用
			--->導入命名空間


2、靜態和非靜態
	靜態成員:被static修飾
	實例成員:不被static修飾
	靜態成員先於實例成員被載入到記憶體中,只有創建了對象,才有實例成員。
	靜態類中只能存在靜態成員
	調用:
		靜態成員調用:
			類名.靜態成員名;
		實例成員調用:
			實例名.實例成員;(實例就是我們的對象)
	什麼時候使用靜態?
		---->作為工具類
		---->在整個項目中資源共用,正因為它是資源共用的,所以靜態成員必須要等到整個項目都結束的時候
		才會被資源釋放。
		在我們的項目中應該儘可能的少使用靜態成員。
		繼承是創建對象的過程。
3、設計模式
		---->單例設計模式
			在整個程式中,我們要保證對象必須是唯一的。
			實現:
				---->第一步:構造函數私有化
				---->第二步:聲明一個靜態欄位,作為全局唯一的單例對象
				---->第三步:聲明一個靜態函數,返回全局唯一的對象
		---->簡單工廠設計模式
			核心:把所有的子類都當做父類來看待
			練習:
				提示用戶分別的輸入兩個數字:
				再輸入運算符:返回一個計算的父類,並調用方法得到結果。
				Add Sub Cheng Chu
	建築行業最早應用到設計模式這個概念
		1、註冊一個公司
				
		2、招兵買馬
		3、投標買地
		4、安排施工隊開始施工
		5、賣樓
		
		
		設計模式就是用來專門解決一些特定的問題。
		
4、類庫
	.dll文件,我們使用類庫來幫助我們封裝一些常用的功能
		
		
		
5、值類型和引用類型		
	值類型:int double char bool decimal struct enum
	引用類型:string 數組 自定義類 介面 委托
	
	值類型的值存儲在記憶體的棧上,引用類型的值存儲在堆中。
	棧上存儲數據的效率要高於堆。
		
	值傳遞:把值類型作為參數傳遞,把值本身進行傳遞。
		註意:
		ref可以把值傳遞改變為引用傳遞。
	引用傳遞:把引用類型的值作為參數傳遞,傳遞的是引用。
		


6、字元串的學習
	重要特性:
		不可變性,我們不管對字元串做什麼操作,都會在記憶體中產生一塊新的實例。
		駐留池
		我們可以將一個字元串看作是char類型的只讀數組。
	GC:Garbage Collection垃圾回收	,每隔一段時間,會掃描整個記憶體,發現,如果有的空間沒有被指向。則立即把它銷毀。

  

1、StringBuilder
	它就是拼接字元串的一個工具,拼成完成後,還是需要將它轉回字元串。


2、ref參數
	ref參數側重於將一個值帶到函數中進行改變,再講改變後的值帶出去。ref參數在函數內不用賦值
	函數外必須為ref參數賦值。

3、out參數

4、params可變參數	


5、集合的學習
	非泛型集合
		ArrayList
		Hashtable
	泛型集合
		List<T>
		Dictionary<Tkey,Tvalue>

6、裝箱和拆箱
   裝箱:值類型---->引用類型
   拆箱:引用類型--->值類型
   我們判斷是否發生了拆箱或者裝箱,首先要判斷這兩種數據類型是否存在繼承關係。
   你裝箱的時候拿什麼類型裝的箱,你拆的時候,就得拿什麼類型去拆。
   
   
   
7、List<T>常用的函數
Add():添加單個元素
AddRange():添加一個集合
Insert():插入一個元素
InsertRange():插入一個集合
Remove():移除指定的元素
RemoveAt():根據下標移除元素
RemoveRange():移除一定範圍內的元素
ToArray():集合轉換成數組
ToList():數組轉換成集合 


8、編碼格式
將字元串是怎樣的形式保存為二進位。
ascii 256

6000 GB2312
GBK  GB18030

ISO
	Unicode
		utf-16
		utf-8
出現亂碼的原因:我們保存這個文件的時候採取的編碼跟打開這個文件的時候採取的編碼格式不一致。



文本文件:拖到txt中還能看得懂得就是文本文件。

  

 


您的分享是我們最大的動力!

更多相關文章
  • 之前接手老項目的時候有遇到一些的方法參數中使用了ref關鍵字加在傳參的參數前面的情況。對於新手,這裡介紹和講解一下ref的用法和實際效果。 CLR中預設所有方法的參數傳遞方式都是傳值,也就是說不管你傳遞的對象是值類型還是引用類型,在作為參數傳入到方法中時,傳遞的是原對象的副本。無論在方法中對該對象做 ...
  • 這幾天,對程式重構,主要針對angularjs的綁定: 第一個例子: 下麵是一段html程式: 不管是name或者是ng-model的屬性值,它都有一定規律"StartX"和"EndX" 後面的數字是連續的序號。 我們可以使用ASP.NET MVC的Razor的語法@for來簡化它們: @{ for ...
  • C#實現的Check Password,並根據輸錯密碼的次數分情況鎖定賬戶:如果輸入錯誤3次,登錄賬戶鎖定5分鐘並提示X點X分後重試登錄。如果5分鐘後再次輸入,累計輸入錯誤密碼累計達到5次。則賬戶會被永久鎖定,需聯繫系統管理員進行把資料庫中的輸入錯誤的次數(errorcount)進行清零解鎖才能登陸 ...
  • [TOC] MVC "MVC 維基百科,自由的百科全書" MVC 是軟體工程的一種軟體架構模式,它不是具體的技術,而是一種代碼分層的理念,主要體現了職責分離原則。 M Model 模型 V View 視圖 C Controller 控制器 對 MVC 的誤解及緣由 誤解:頁面視圖 = View ,E ...
  • 簡介 Orleans用起來的確很爽,更爽的是咱們有能監控它的工具。 " OrleansDashboard " 這個工具是一個可視化的Silo監控工具,Silo和Grain的活躍狀態一目瞭然,各個介面的響應速度也可以很清晰的統計到。 安裝 使用NuGet引用 然後修改 的配置,添加Dashboard: ...
  • Teigha中實體旋轉 代碼: using (var trans = database.TransactionManager.StartTransaction()) { Entity ent = trans.GetObject(entityId, OpenMode.ForWrite) asEntit ...
  • 什麼是AutoMapper?AutoMapper是一個簡單的小型庫,用於解決一個看似複雜的問題 - 擺脫將一個對象映射到另一個對象的代碼。這種類型的代碼是相當沉悶和無聊的寫,所以為什麼不發明一個工具來為我們做? 我們來看看在.netcore3.1中怎樣使用AutoMapper9.0。 Profile ...
  • 程式處理存放圖片的幾種方式 我的理解有4個: 1:放在項目本身得文件夾中,直接部署到伺服器上 2:存放在磁碟中,然後資料庫中存放路徑,讀取得時候傳路徑。這個適合小項目 3:將圖片轉換成二進位文件,但是不建議這樣做,因為會給資料庫造成壓力。 4:存放在雲存儲器上,也是在資料庫上存地址,不過是雲地址,使 ...
一周排行
  • 1. 泛型Generic 1.1 引入泛型:延遲聲明 泛型方法聲明時,並未寫死類型,在調用的時候再指定類型。 延遲聲明:推遲一切可以推遲的。 1.2 如何聲明和使用泛型 泛型方法:方法名稱後面加上尖括弧,裡面是類型參數 類型參數實際上就是一個類型T聲明,方法就可以用這個類型T了。 如下所示: pub ...
  • 本筆記摘抄自:https://www.cnblogs.com/PatrickLiu/p/7903617.html,記錄一下學習過程以備後續查用。 一、引言 今天我們要講行為型設計模式的第三個模式--迭代器模式,先從名字上來看。迭代是遍歷的意思,迭代器可以理解為是遍歷某某的工具,遍歷什麼呢?在軟 件設 ...
  • 本筆記摘抄自:https://www.cnblogs.com/PatrickLiu/p/7928521.html,記錄一下學習過程以備後續查用。 一、引言 今天我們要講行為型設計模式的第四個模式--觀察者模式,先從名字上來看。觀察者模式可以理解為既然有“觀察者”,那肯定就有“被觀察者”了。“觀察者” ...
  • 先看核心代碼: public List<DataEntity> SearchShopSalesReport(DateTimeOffset? dateFrom, DateTimeOffset? dateTo,string groupBy) { var query = data.DataEntity / ...
  • 首先新建一個項目,名稱叫Caliburn.Micro.ActionConvertions 然後刪掉MainWindow.xaml 然後去app.xaml刪掉StartupUri這行代碼 其次,安裝Caliburn.Micro,Caliburn.Micro.Core,這兩個Nuget包,如下圖 然後新 ...
  • 一文帶你瞭解 C DLR 的世界 在很久之前,我寫了一片文章 "dynamic結合匿名類型 匿名對象傳參" ,裡面我以為DLR內部是用反射實現的。因為那時候是心中想當然的認為只有反射能夠在運行時解析對象的成員信息並調用成員方法。後來也是因為其他的事一直都沒有回過頭來把這一節知識給補上,正所謂亡羊補牢 ...
  • ​ 在C#8.0中,針對介面引入了一項新特性,就是可以指定預設實現,方便對已有實現進行擴展,也對面向Android和Swift的Api進行互操作提供了可能性。下麵我們來看看該特性的具體規則與實現。 一、主要應用場景: 在不破壞影響已有實現的情況下,可以添加新成員。這解決了在第三方已經大量使用了的介面 ...
  • 前言 通常在應用程式開發到正式上線,在這個過程中我們會分為多個階段,通常會有 開發、測試、以及正式環境等。每個環境的參數配置我們會使用不同的參數,因此呢,在ASP.NET Core中就提供了相關的環境API,方便我們更好的去做這些事情。 環境 ASP.NET Core使用ASPNETCORE_ENV ...
  • 擱置了幾天,工作忙的一塌糊塗,今天終於抽空來繼續看看MVC的知識。先來看看MVC的路由是如何處理的。以下為替代的路由: app.UseEndpoints(endpoints => { endpoints.MapControllerRoute( name: "default", pattern: "{ ...
  • 多用www.bing.com國際版解決代碼報錯 代碼運行的時候,報異常,國內的搜索引擎一搜, 浮誇的廣告太多,解決方案准確性不足, 盜版又很嚴重(導致一錯皆錯),方案未及時更新等詬病。 www.bing.com國際版可以關聯到: (1). 外國官網,可以獲得官方的解決方案。 (2). stackov ...
x