受管制的代码
其實整個.NET項目都是運行在.NET Framework上的托管代碼,這個道理和JAVA虛擬機的機制是類似的。
最簡單的說呢,受托管的代碼不能直接寫內存,是安全的,而非托管代碼是非安全代碼,可以使用指針操作內存。
一般的項目使用托管代碼都行了,也就是說在程序里面不需要用到非安全代碼。
對于一些對速度要求高的部分功能可以考慮使用非安全代碼,使用指針等讀寫內存,而對于真個項目來說還是受托管的安全代碼。
有關非安全代碼的信息請查閱MSDN unsafe。
在string方法中,如ToUpper等字符串操作方法,都會產生一個新的字符串,這樣增大了運行開支。一個替代方案是通過非托管代碼直接操作字符串。如替代ToUpper方法:
using System;
public class Test
{
public static void Main(string[] args)
{
string str = 'hello';
ToUpper(str);
Console.WriteLine(str);
}
private static unsafe void ToUpper(string str)
{
fixed(char * pfixed = str)
for(char * p=pfixed;*p!=0;p++)
{
*p = char.ToUpper(*p);
}
}
}
fixed語句:
格式fixed ( type* ptr = expr ) statement
它的目的是防止變量被垃圾回收器生定位。
其中:
type為非托管類型或void
ptr為指針名
expr為可以隱式轉換為type*的表達式
statement為可執行的語句或塊
fixed語句只能在unsafe的上下文中使用,fixed 語句設置指向托管變量的指針并在 statement 執行期間“鎖定”該變量。如果沒有 fixed 語句,則指向托管變量的指針將作用很小,因為垃圾回收可能不可預知地重定位變量。
執行完 statement 后,任何鎖定的變量都被取消鎖定并受垃圾回收的制約。因此,不要指向 fixed 語句之外的那些變量。在不安全模式中,可以在堆棧上分配內存。堆棧不受垃圾回收的制約,因此不需要被鎖定。
但在編譯時,因為使用了非托管代碼,必須要使用/unsafe才能通過。
簡單來說,托管的代碼就是把有關內存管理(內存申請,內存釋放,垃圾回收之類的)全部都是.net的CLR來管理,就是說使用托管的代碼把底層的一些操作都封裝起來了,不能直接進行內存的讀取之類的和硬件相關的操作,優點就是比較安全,不會出現諸如內存泄露之類的問題,缺點也很明顯,不能直接讀取內存,性能上會有損失,使用起來有時也不夠靈活。
非托管的剛好相反,可以直接進行硬件操作,性能比較高,但是對開發人員的要求也比較高。
最直觀的就是c#不推薦使用指針,而c++就可以使用指針來直接讀取內存;
c#使用垃圾回收,c++要手動的釋放對象……
轉載于:https://www.cnblogs.com/cjlol/archive/2010/04/02/1703456.html
總結
- 上一篇: 那一瞬...
- 下一篇: 汇编学习笔记(二)--数据处理的两个基本