-
123456
查看全部 -
ref 關鍵字,將值傳遞改為引用傳遞
查看全部 -
構造方法的作用:為屬性賦值。
如果沒有顯式定義構造方法,則會由一個默認的無參數的構造方法
如果顯示定義了構造方法,則沒有默認構造方法
只能用 new 方法()的形式調用構造方法
構造方法通常生命為 public
構造方法沒有返回值類型
構造方法必須與類名相同
查看全部 -
限制屬性賦值就是在 set 方法中增加業務判斷也處理支路
查看全部 -
c# 封裝的快捷鍵 ctrl +r+e
查看全部 -
c# 中對象與屬性的區別。
prvate string _name;
public string Name
{
? ? set{_name=value;}
? ?get{return _name;}
}
查看全部 -
struct:
s
查看全部 -
C#中的數據類型
值類型:int char double bool
值類型變量存儲對象的值,賦值會創建值得副本,修改任何一個副本,不會影響其他的副本
引用類型:類 數組 接口 string
引用類型變量存儲對象的內存地址,賦值不會創建值得副本,只會創建地址的副本,修改任何一個副本,也同時修改其他的副本。
查看全部 -
初始化:一、用有參數構造方法初始化對象
二、用無參數構造方法初始化對象
三、對象初始化器初始化對象(使用的是構造方法的無參數構造)與二相同,只是寫法更加簡潔而已。
例子:Child child=new Child(){Name=“小米”,Age=55}?
or?Child Child3 = new Child{ Name = "周潤發", Age = 5 };
查看全部 -
封裝的概念:隱藏對象的信息,留出訪問的接口
關于封裝:
類和對象;把字段封裝成屬性;方法;構造方法;值類型與引用類型
引用:結構 枚舉 out ref
方法
構造方法
查看全部 -
ref起到傳參作用:
out是獲取結果且可以返回多個值;return返回一個值。
使用Out 修飾形參必須得給形參賦值
查看全部 -
關鍵字 ref :讓值類型參數按引用類型傳參。
注意,這里的值類型不能是對象的屬性。諸如 Growth( ref c1.Age),就是錯誤的。
正確舉例:
先定義方法,注意使用ref :static void Growth( ref int age){ age ++ ;}
然后定義一個值類型變量:int age1 = 3;
調用方法的時候,也必須使用ref :Growth( ref age1);
查看全部 -
在Main中訪問靜態方法時不需要實例化對象便可以直接調用方法名
值類型和引用類型作為方法參數時的區別:
1、按值傳參,方法修改形參,實參不會被修改;
2、按引用傳參,方法修改形參,實參不會被修改;
查看全部 -
枚舉:限定了范圍
枚舉:
1、值類型
2、不能定義字段屬性和方法
3、枚舉值是從0遞增的整數
例子:enum Gender
//Child c1 = new Child("梁曉雪", "女", 4);//錯誤?? ?5?? ?參數 2: 無法從“string”轉換為“Gender”?? ?
??????????? //Child c2 = new Child("劉小牛","猴",5);
??????????? //Child c2 = new Child("劉小牛", Gender.男, 5);
??????????? Child c2 = new Child("劉小牛", (Gender)0, 5);1、創建枚舉類型:項目名稱,右鍵,添加,類或新建項(代碼文件)
2、枚舉屬于值類型,枚舉中不能定義字段屬性和方法,枚舉值是從0開始的整數值
3、枚舉類型限定了一組有限的值,可以在某種程度上防止錯誤數據的輸入
查看全部 -
簡單來說,struct是值類型,創建一個struct類型的實例被分配在棧上。class是引用類型,創建一個class類型實例被分配在托管堆上。但struct和class的區別遠不止這么簡單。 概括來講,struct和class的不同體現在: ●?類是引用類型,struct是值類型 ●?在托管堆上創建類的實例,在棧上創建struct實例 ●?類實例的賦值,賦的是引用地址,struct實例的賦值,賦的是值 ●?類作為參數類型傳遞,傳遞的是引用地址,struct作為參數類型傳遞,傳遞的是值 ●?類沒有默認無參構造函數,struct有默認無參構造函數 ●?類支持繼承,struct不支持繼承 ●?類偏向于"面向對象",用于復雜、大型數據,struct偏向于"簡單值",比如小于16字節,結構簡單 ●?類的成員很容易賦初值,很難給struct類型成員賦初值 ●?類的實例只能通過new?someclass()來創建,struct類型的實例既可以通過new?somestruct()來創建,也可以通過somestruct?mystruct;來創建 一、從賦值的角度體驗struct和class的不同 引用類型賦值,是把地址賦值給了變量 class?program ??{ ????static?void?main(string[]?args) ????{ ??????sizeclass?sizeclass?=?new?sizeclass(){width?=?10,?length?=?10}; ??????console.writeline("賦值前:width={0},length={1}",?sizeclass.width,?sizeclass.length); ? ??????var?copyofsizeclass?=?sizeclass; ??????copyofsizeclass.length?=?5; ??????copyofsizeclass.width?=?5; ??????console.writeline("賦值后:width={0},length={1}",sizeclass.width,?sizeclass.length); ??????console.readkey(); ????} ??} ? ??public?class?sizeclass ??{ ????public?int?width?{?get;?set;?} ????public?int?length?{?get;?set;?} ??} ? ??public?struct?sizestruct ??{ ????public?int?width?{?get;?set;?} ????public?int?length?{?get;?set;?} ??} 運行結果如下圖所示:以上,當把sizeclass賦值給copyofsize變量的時候,是把sizeclass所指向的地址賦值給了copyofsize變量,2個變量同時指向同一個地址。所以,當改變copyofsizeclass變量的值,也相當于改變了sizeclass的值。 struct類型賦值,是完全拷貝,在棧上多了一個完全一樣的變量 class?program ??{ ????static?void?main(string[]?args) ????{ ??????sizestruct?sizestruct?=?new?sizestruct(){length?=?10,?width?=?10}; ??????console.writeline("賦值前:width={0},length={1}",?sizestruct.width,?sizestruct.length); ? ??????var?copyofsizestruct?=?sizestruct; ??????copyofsizestruct.length?=?5; ??????copyofsizestruct.width?=?5; ??????console.writeline("賦值后:width={0},length={1}",?sizestruct.width,?sizestruct.length); ??????console.readkey(); ????} ??} 程序運行結果如下圖所示:以上,當把sizestruct賦值給copyofsizestruct變量的時候,是完全拷貝,改變copyofsizestruct的值不會影響到sizestruct。 二、從參數傳值角度體驗struct和class的不同 引用類型參數傳遞的是地址 class?program ??{ ????static?void?main(string[]?args) ????{ ??????listtemp?=?new?list(){"my","god"}; ??????temp.foreach(t?=>?console.write(t?+?"?")); ??????console.readkey(); ????} ? ????public?static?void?changereferencetype(listlist) ????{ ??????list?=?new?list(){"hello",?"world"}; ????} ??} ??? 運行結果:my?god 為什么不是hello?world? →棧上的temp指向托管堆上的一個集合實例 →當temp放到changereferencetype(temp)方法中,本質是把temp指向的地址賦值給了變量list →在changereferencetype(listlist)方法內部,又把變量list的指向了另外一個集合實例地址 →但temp的指向地址一直沒有改變 我們再來改變changereferencetype(listlist)內部實現方式,其它不變。 class?program ??{ ????static?void?main(string[]?args) ????{ ??????listtemp?=?new?list(){"my","god"};????? ??????changereferencetype(temp); ??????temp.foreach(t?=>?console.write(t?+?"?")); ??????console.readkey(); ????} ? ????public?static?void?changereferencetype(listlist) ????{ ??????list.clear(); ??????list.add("hello"); ??????list.add("world"); ????} ??} ??? 運行結果:hello?world 為什么不是my?god??? →棧上的temp指向托管堆上的一個集合實例 →當temp放到changereferencetype(temp)方法中,本質是把temp指向的地址賦值給了變量list →在changereferencetype(listlist)方法內部,把temp和list共同指向的實例清空,又添加"hello"和"world"2個元素 →由于list和temp指向的實例是一樣的,所以改變list指向的實例就等同于改變temp指向的實例 以上,很好地說明了:引用類型參數傳遞的是地址。 值類型struct參數傳遞的是值 ??? class?program ??{ ????static?void?main(string[]?args) ????{ ??????size?s?=?new?size(){length?=?10,?width?=?10}; ??????changestructtype(s); ??????console.write("length={0},width={1}",?s.length,s.width); ??????console.readkey(); ????} ? ????public?static?void?changestructtype(size?size) ????{ ??????size.length?=?0; ??????size.width?=?0; ????} ??} ? ??public?struct?size ??{ ????public?int?length?{?get;?set;?} ????public?int?width?{?get;?set;?} ??}
查看全部
舉報