• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            tqsheng

            go.....
            隨筆 - 366, 文章 - 18, 評論 - 101, 引用 - 0
            數據加載中……

            [導入]托管C++中函數調用的雙重轉換(Double Thunking)

            在VC.Net中使用默認設置/clr編譯時,一個托管函數會產生兩個入口點,一個是托管的,供托管代碼調用,另外一個是非托管的,供非托管代碼調用。但是函數地址,特別是虛函數指針只能有一個值,所以需要有一個默認的入口。 非托管入口點可能是所有調用的默認入口(在 Visual Studio .NET2003 中,編譯器總是會選擇非托管入口,但是在Visual Studio 2005中,如果參數或者返回值中包含托管類型,那么編譯器會選擇托管入口),而另外一個只是使用托管C++中的互操作功能對默認入口的調用。在一個托管函數被另一個托管函數調用的時候,這可能會造成不必要的托管/非托管上下文切換和參數/返回值的復制。如果函數不會被非托管代碼使用指針調用,那么可以在聲明函數時用VC2005新增的__clrcall修飾符阻止編譯器生成兩個入口。 現在用簡單的冒泡排序算法來比較一下使用__clrcall之后的性能改善程度。 using namespace System; #define ARRAY_SIZE 1000 struct bubbleBase { int value;
            文章來源:http://blog.csdn.net/jiangsheng/archive/2005/10/08/497936.aspx

            posted on 2006-03-06 09:10 tqsheng 閱讀(211) 評論(0)  編輯 收藏 引用

            久久久久亚洲精品天堂| 丰满少妇高潮惨叫久久久| 久久久久久无码国产精品中文字幕| 久久精品国产72国产精福利| 奇米影视7777久久精品人人爽| 亚洲综合日韩久久成人AV| 国产AⅤ精品一区二区三区久久| 久久综合九色综合网站| 99热都是精品久久久久久| 亚洲国产精品无码久久久不卡| 国产精品免费看久久久香蕉| 狠狠色婷婷久久综合频道日韩 | 亚洲精品tv久久久久| 国产精品久久久久久| 婷婷久久香蕉五月综合加勒比 | 亚洲中文久久精品无码ww16| 91精品日韩人妻无码久久不卡| 亚洲精品tv久久久久久久久| 日本国产精品久久| 国产免费久久精品99久久| 69久久精品无码一区二区| 婷婷久久久亚洲欧洲日产国码AV| 久久综合精品国产一区二区三区 | 久久婷婷五月综合97色直播| AV狠狠色丁香婷婷综合久久| 亚洲人成网亚洲欧洲无码久久| 欧美成a人片免费看久久| 99久久国产亚洲高清观看2024| 久久久久久久久久久久中文字幕 | 久久久国产视频| 亚洲人成无码www久久久| 人妻系列无码专区久久五月天| 久久男人AV资源网站| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 精品99久久aaa一级毛片| 青青草原1769久久免费播放| 久久青草国产精品一区| 伊人久久免费视频| 无码8090精品久久一区| 色综合久久中文字幕无码 | 久久久久香蕉视频|