不能將屬性以ref或out的方式傳遞

看上去屬性和字段差不多,可是屬性本質上是個方法,并不是真正指向一個内存位置,所以不能像字段那樣能以ref或out方式傳遞。

Lookup運行一個鍵對應多個值,但無法直接創建,衹能通過ToLookup方法

 

原生的值類型調用ToString方法是不會裝箱的

比較"Age = " + 3.ToString()和"Age = " + 3,前者要比後者高效,因爲後者默認會裝箱。所以值類型涉及字符串操作時,應該總是使用ToString方法

 

用R格式化字符串,可以保留精度

  1. const double number = 1.618033988749895;
  2.  
  3. string text = string.Format("{0}", number);
  4. double result = double.Parse(text);
  5.  
  6. bool same = result == number;
  7.  
  8. text = string.Format("{0:R}", number);
  9. result = double.Parse(text);
  10. same = result == number;

前一個same爲false,后一個爲true

 

類型的協變和逆變

衹有接口和委托才能聲明這兩個特性,汎型類是不支持的(出於類型安全的考慮)。

協變用out來修飾,針對的是返回值,潛臺詞是:如果能返回父類,自然也能返回子類。

// Covariance.

IEnumerable<string> strings = new List<string>();

IEnumerable<object> objects = strings;

逆變用in來修飾,針對的是參數,潛臺詞是:如果能傳入父類,自然也能傳入子類。

// Contravariant.

IComparer<object> objects = objectComparer;

IComparer<string> strings = objects;

 

衹讀字段無法直接賦值修改,但可以通過反射進行修改

 

匿名類型的屬性是衹讀的;元祖類型的屬性也是衹讀的

這樣是爲了防止匿名對象的HashCode發生改變

 

dynamic類型可以隱式轉換爲其它類型,object則不行

如:dynamic d = 1; int i = d;

編譯器認爲dynamic上的任何操作都是合法的

 

字段内聯初始化衹是一種簡化寫法,實際上初始化還是在構造函數中進行的

這也是爲什麽值類型不允許字段内聯初始化的原因,因爲值類型不允許無參構造函數

 

Lazy<T>實現延遲加載,調用其Value屬性時才會真正加載

 

不要定義值類型的靜態構造器,因爲CLR未必會調用

  1. struct MyStruct
  2. {
  3. static MyStruct()
  4. {
  5. //不會被調用
  6. Console.WriteLine("MyStruct");
  7. }
  8.  
  9. public int X;
  10. }
  11.  
  12. MyStruct[] array = new MyStruct[2];
  13. array[0].X = 2;

 

閉包

捕獲變量是從變量聲明就開始了,而捕獲的值是看調用委托時該變量是什麽值           
    var list = new List<Action>();

            for (int i = 0; i < 5; i++)

            {

                int cnt = i * 10;

                list.Add(delegate

                {

                    Console.WriteLine(cnt);

                    cnt++;

                });

            }

            list[0]();

            list[0]();

            list[1]();

有5次循環,cnt被聲明了5次,實際上就是有5個不同的捕獲變量,所以各個委托有各自獨立的捕獲值,輸出結果是0,1,10

但如果把變量聲明放在循環外,隻聲明一次:

    int cnt;

            for (int i = 0; i < 5; i++)

            {

                cnt = i * 10;

那麽這些委托就共享同一個捕獲變量,而當委托方法調用時,由於cnt已經被循環了5次,成爲40,所以輸出結果是40,41,42

C#的一些知識點的更多相关文章

  1. JavaScript基礎知識

    JavaScript基礎知識 1.標籤組使用 <script charset='utf-8' //設置字元集 defet //使腳本延遲到文檔解析完成,Browser已忽略 language=' ...

  2. BootStrap基礎知識

    BootStrap基礎知識 1. .lead //突出 .text-left //文字居左 .text-right //文字居右 .text-center //文字居中 .text-justify / ...

  3. CSS1-3基礎知識

    CSS1-3基礎知識 1.css排版 css在html內排版: <style type='text/css'> 標記名{} .類型名{} #ID名{} 標記名,.類型名,#ID名{} &l ...

  4. jQuery基礎知識

    jQuery基礎知識 $(function(){}) //jQuery先執行一遍再執行其他函數 $(document).ready(fn) //文檔加載完後觸發 1. 刪除$:jQuery.noCon ...

  5. Python开发 基礎知識 (未完代補)

    一.Python基本知識 1.Python屬高階語言,所編築的是字節碼 2.一般狀態statement 終止於換行,如需使用多數行編寫,可在行末加上 \,以表延續 但在 parentheses ( ) ...

  6. HTML 4.01+5基礎知識

    HTML 4.01+5 1.Html結構:html>head+body 2.Html快捷鍵:!加Tab(在sublime中) 3.雙標籤: ①常用標籤 h1.h2.h3.h4.h5.h6 p.c ...

  7. Python开发 基礎知識 3.類別&方法 (bool & str) (未完待續)

    類別 可使用type()查看 內建 [ 布爾:bool (Boolen) 字串:str (String) 數字:int (Integer) 小數:float 列表:list 元祖:tuple 字典:d ...

  8. 最近做group assignment需要些加密的知識

    需求:A給B單向發的數據需要被加密,A和B都可以看到原文.加密后,就算傳輸的過程被竊取,也無法得知數據原文.A可以是任何客戶端. 解決:常用的MD5,sha1等常用的加密算法為單向不可逆,顯然不符合需 ...

  9. Linux基礎知識 —— open&close

    下面說一下在用戶空間調用open/close/dup跟驅動中的open和release的對應. 下面是測試驅動: #include <linux/module.h> #include &l ...

随机推荐

  1. kendo grid Hierarchy

    Hierarchy grid中不能使用下面的这段代码,会造成传值传不过来,把下面的代码注释,不用models,直接用form表单传值就行,暂时没搞明白为什么 //parameterMap: funct ...

  2. Tomcat配置文件server.xml(转)

    前言 Tomcat隶属于Apache基金会,是开源的轻量级Web应用服务器,使用非常广泛.server.xml是Tomcat中最重要的配置文件,server.xml的每一个元素都对应了Tomcat中的 ...

  3. Android GIS开发系列-- 入门季(3) GraphicsLayer添加点、线、面

    GraphicsLayer是图形图层,可以自定义图形添加到地图上.调用GraphicsLayer的addGraphic方法就能添加图形,此方法要一个Graphic对象,此对象的构造方法是Graphic ...

  4. JAVA学习第四十一课 — 泛型的基本应用(一)

    泛型是JDK1.5以后出现的安全机制,简化机制,提高安全性 泛型的长处 1.将执行时出现的问题ClassCastException转移到了编译时期 2.避免了强制转换的麻烦 <>在当操作的 ...

  5. vim 快速搜索的快捷键

    当光标在某个单词上面的时候 按 shift + #键(或 shift + * )就可以了!!! ----------------------------------- If you are worki ...

  6. 多个线程对hashmap进行put操作的异常

    多个线程对hashmap进行put操作的异常 Exception in thread "Thread-0" java.lang.ClassCastException: java.u ...

  7. #HDU 3790 最短路径问题 【Dijkstra入门题】

    题目: 最短路径问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  8. B1072 [SCOI2007]排列perm 状压dp

    很简单的状压dp,但是有一个事,就是...我数组开大了一点,然后每次memset就会T,然后开小就好了!!!震惊!以后小心点这个问题. 题干: Description 给一个数字串s和正整数d, 统计 ...

  9. [luoguP4142]洞穴遇险

    https://www.zybuluo.com/ysner/note/1240792 题面 戳我 解析 这种用来拼接的奇形怪状的东西,要不就是轮廓线\(DP\),要不就是网络流. 为了表示奇数点(即\ ...

  10. Hadoop 的使用

    hadoop:hadoop启动:./sbin/start-dfs.shhadoop关闭:./sbin/stop-dfs.shbin文件用于在HDFS创建数据HDFS 中创建用户目录:./bin/hdf ...