自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

C#指針使用簡析

開發(fā) 后端
C#指針在.net的時(shí)代指針已經(jīng)被封裝起來為什么還在使用,還能使用呢?本文將向你介紹C#指針的特點(diǎn)等等內(nèi)容。

C#指針的存在狀況簡析:指針在C\C++里面可是一個(gè)好東西,但是到j(luò)ava,.net的時(shí)代指針已經(jīng)被封裝起來,對用戶不可見,這點(diǎn)java做的非常的徹底。.net可能因?yàn)檫€存在一個(gè)托管C++,因此指針并沒有完全廢除,C#還是保留了指針的操作。

要使用指針首先要對使用指針的代碼用unsafe進(jìn)行進(jìn)行聲明,聲明和public聲明一樣,可以對整個(gè)類進(jìn)行聲明,也可以是類里面某個(gè)方法或者屬性。在代碼里什么后,還需要修改工程項(xiàng)目的Build屬性,讓編譯器支持指針的操作。

做好事前的工作就可以使用指針了。指針的使用方法和C++下使用沒有太多差別。只要編譯器不報(bào)錯(cuò)就沒有太大問題。

下面就C#指針來看其他指針的一些使用上的理解:

1. 指針類型可以是實(shí)體變量(int,double)也可以是enum,同時(shí)也支持結(jié)構(gòu)體變量struct。但不能是類。不過空指針可以指向類,只不過空指針不能進(jìn)行任何操作,也只能把空指針作為傳遞對象來使用。

2. C#提供一個(gè)的關(guān)鍵字stackalloc用于申請堆棧內(nèi)存。注意,這個(gè)申請內(nèi)存分配的是棧內(nèi)存,當(dāng)函數(shù)執(zhí)行完畢后,內(nèi)存會(huì)被自動(dòng)回收。不過我想用這個(gè)棧內(nèi)存基本可以解決40%的問題,而且使用的時(shí)候不必?fù)?dān)心內(nèi)存泄漏問題。

3. .net 好像不直接支持堆內(nèi)存的申請(這個(gè)對.net來說很危險(xiǎn)),不過我們可以通過調(diào)用win32 api 的方法進(jìn)行申請。這樣就可以解決剩下40%的問題。堆內(nèi)存申請的方法在MSDN里面有相關(guān)的文檔,具體實(shí)現(xiàn)代碼見附。

4.  結(jié)構(gòu)體是一個(gè)特殊的對象。他與類的定義就差一個(gè)關(guān)鍵字,使用方法也和類一樣,可以定義屬性,可以定義方法。但是在進(jìn)行指針操作的時(shí)候雙方就有很大的差別了。結(jié)構(gòu)體可以通過sizeof()取得大小,大小與結(jié)構(gòu)體里有多少實(shí)體變量有關(guān),但是如果struck里定義了類的對象,或者指針,sizeof可能會(huì)編譯不過(void* 的空指針例外,不過需要在結(jié)構(gòu)體聲明處加上unsafe)。

5. fixed關(guān)鍵字:目前了解的不多,不過有一個(gè)很實(shí)用的例子可以讓指針能夠和.net里的數(shù)組進(jìn)行交互操作: 

  1. byte[] buffer = new byte[100];  
  2. fixed (byte* p = buffer)  
  3. {  
  4.     P[0] = 123;  
  5.     ……  

附C#指針的實(shí)現(xiàn):

  1. public unsafe class Memory  
  2.     {  
  3. // Handle for the process heap.  
  4. // This handle is used in all calls to the  
  5. // HeapXXX APIs in the methods below.  
  6. static int ph = GetProcessHeap();  
  7. // Private instance constructor to prevent instantiation.  
  8. private Memory() { }  
  9. // Allocates a memory block of the given size.   
  10. //The allocated memory is  
  11. // automatically initialized to zero.  
  12. public static void* Alloc(int size)  
  13. {  
  14.     void* result = HeapAlloc(ph, HEAP_ZERO_MEMORY, size);  
  15.     if (result == nullthrow new OutOfMemoryException();  
  16.     return result;  
  17. }  
  18. // Copies count bytes from src to dst.   
  19. //The source and destination  
  20. // blocks are permitted to overlap.  
  21. public static void Copy(void* src, void* dst, int count)  
  22. {  
  23.     byte* ps = (byte*)src;  
  24.     byte* pd = (byte*)dst;  
  25.     if (ps > pd)  
  26.     {  
  27. for (; count != 0; count--) *pd++ = *ps++;  
  28.     }  
  29.     else if (ps < pd)  
  30.     {  
  31. for (ps += count, pd += count;   
  32. count != 0; count--) *--pd = *--ps;  
  33.     }  
  34. }  
  35. // Frees a memory block.  
  36. public static void Free(void* block)  
  37. {  
  38.     if (!HeapFree(ph, 0, block))   
  39. throw new InvalidOperationException();  
  40. }  
  41. // Re-allocates a memory block.   
  42. //If the reallocation request is for a  
  43. // larger size, the additional region of memory is automatically  
  44. // initialized to zero.  
  45. public static void* ReAlloc(void* block, int size)  
  46. {  
  47.     void* result = HeapReAlloc(ph, HEAP_ZERO_MEMORY, block, size);  
  48.     if (result == nullthrow new OutOfMemoryException();  
  49.     return result;  
  50. }  
  51. // Returns the size of a memory block.  
  52. public static int SizeOf(void* block)  
  53. {  
  54.     int result = HeapSize(ph, 0, block);  
  55.     if (result == -1) throw new InvalidOperationException();  
  56.     return result;  
  57. }  
  58. // Heap API flags  
  59. const int HEAP_ZERO_MEMORY = 0x00000008;  
  60. // Heap API functions  
  61. [DllImport("kernel32")]  
  62. static extern int GetProcessHeap();  
  63. [DllImport("kernel32")]  
  64. static extern void* HeapAlloc(int hHeap, int flags, int size);  
  65. [DllImport("kernel32")]  
  66. static extern bool HeapFree(int hHeap, int flags, void* block);  
  67. [DllImport("kernel32")]  
  68. static extern void* HeapReAlloc(int hHeap, int flags,  
  69.    void* block, int size);  
  70. [DllImport("kernel32")]  
  71. static extern int HeapSize(int hHeap, int flags, void* block);  
  72.     } 

C#指針方面的內(nèi)容就向你介紹到這里,希望對你了解學(xué)習(xí)C#指針有所幫助。

【編輯推薦】

  1. C#結(jié)構(gòu)體構(gòu)造函數(shù)的應(yīng)用
  2. C#結(jié)構(gòu)體定義的詳解
  3. C#的結(jié)構(gòu)體使用實(shí)例淺析
  4. C#結(jié)構(gòu)體變量學(xué)習(xí)淺談
  5. 解析C#結(jié)構(gòu)體指針
責(zé)任編輯:仲衡 來源: 編程論壇
相關(guān)推薦

2009-08-13 10:27:28

C#讀取Excel數(shù)據(jù)

2009-09-03 17:10:57

2009-08-12 10:07:51

C#運(yùn)算符

2009-09-03 14:20:21

C#日期格式化

2009-09-03 10:52:41

C#遞歸樹

2009-08-13 14:36:40

C#結(jié)構(gòu)體構(gòu)造函數(shù)

2009-08-12 16:38:35

C#讀取XML節(jié)點(diǎn)

2009-08-18 17:29:02

C#使用指針

2009-08-19 12:58:19

C#操作Word

2009-08-20 16:02:15

C#正則表達(dá)式

2009-08-21 15:16:23

C#使用指針

2009-08-20 09:58:06

C#操作文本文件

2009-09-09 18:41:42

C# 加密散列算法

2024-12-23 09:09:54

2010-01-20 14:25:56

函數(shù)調(diào)用

2010-01-25 10:10:42

C++函數(shù)參數(shù)

2011-07-12 14:04:58

2010-01-18 15:53:27

C++析構(gòu)函數(shù)

2009-09-02 10:49:46

C#調(diào)用析構(gòu)方法

2009-07-30 15:24:13

C#析構(gòu)函數(shù)C#構(gòu)造函數(shù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號