托管代码 (managed code)
由公共语言运行库环境(而不是直接由操作系统)执行的代码。托管代码应用程序可以获得公共语言运行库服务,例如自动垃圾回收、运行库类型检查和安全支持等。这些服务帮助提供独立于平台和语言的、统一的托管代码应用程序行为。
托管代码是可以使用20多种支持Microsoft .NET Framework的高级语言编写的代码,它们包括:C#, J#, Microsoft Visual Basic .NET, Microsoft JScript .NET, 以及C++。所有的语言共享统一的类库集合,并能被编码成为中间语言(IL)。运行库编译器(runtime-aware ompiler)在托管执行环境下编译中间语言(IL)使之成为本地可执行的代码,并使用数组边界和索引检查,异常处理,垃圾回收等手段确保类型的安全。
在托管执行环境中使用托管代码及其编译,可以避免许多典型的导致安全黑洞和不稳定程序的编程错误。同样,许多不可靠的设计也自动的被增强了安全性,例如 类型安全检查,内存管理和释放无效对象。程序员可以花更多的精力关注程序的应用逻辑设计并可以减少代码的编写量。这就意味着更短的开发时间和更健壮的程序。
非托管代码 (unmanaged code)
在公共语言运行库环境的外部,由操作系统直接执行的代码。非托管代码必须提供自己的垃圾回收、类型检查、安全支持等服务;它与托管代码不同,后者从公共语言运行库中获得这些服务。
.net中托管代码的含义
问题:什么是托管?托管是什么意思?
托管代码就是基于.net元数据格式的代码,运行于.net平台之上,所有的与操作系统的交换有.net来完成,就像是把这些功能委托给.net,所以称之为托管代码。非托管代码则反之。
举个例子l
Vc.net还可以使用mfc,atl来编写程序,他们基于MFC或者ATL,而不是.NET,所有是非托管代码,如果基于.net比如C#,VB.net则是托管代码
非托管代码是指.NET解释不了的
简单的说,托管代码的话,.net可以自动释放资料,非托管代码需要手动释放资料.
什么是托管C++
托管是.NET的一个专门概念,它倡导一种新的编程理念,因此我们完全可以把“托管”视为“.NET”。由托管概念所引发的C++应用程序包括托管代码、托管数据和托管类三个组成部分。
托管代码
.Net环境提供了许多核心的运行(RUNTIME)服务,比如异常处理和安全策略。为了能使用这些服务,必须要给运行环境提供一些信息代码(元数据),这种代码就是托管代码。所有的C#、VB.NET、JScript.NET默认时都是托管的,但Visual C++默认时不是托管的,必须在编译器中使用命令行选项(/CLR)才能产生托管代码。
托管数据
与托管代码密切相关的是托管数据。托管数据是由公共语言运行的垃圾回收器进行分配和释放的数据。默认情况下,C#、Visual Basic 和 JScript.NET 数据是托管数据。不过,通过使用特殊的关键字,C# 数据可以被标记为非托管数据。Visual C++数据在默认情况下是非托管数据,即使在使用 /CLR 开关时也不是托管的。
托管类
尽管Visual C++数据在默认情况下是非托管数据,但是在使用C++的托管扩展时,可以使用“__gc”关键字将类标记为托管类。就像该名称所显示的那样,它表示类实例的内存由垃圾回收器管理。另外,一个托管类也完全可以成为 .NET 框架的成员,由此可以带来的好处是,它可以与其他语言编写的类正确地进行相互操作,如托管的C++类可以从Visual Basic类继承等。但同时也有一些限制,如托管类只能从一个基类继承等。
为什么要在C#项目中使用托管的C++
答:● 需要快速地将未托管的C++应用程序合并到.NET框架中
对于以前开发的传统未托管的C++应用程序,因为开发人员可以在同一个应用程序中(甚至是在同一个文件中)混合使用两种类型的代码,所以托管扩展为实现两种代码的无缝转化提供了一种平滑的转化方式。
开发人员可以继续使用未托管的C++来编写组件,以利用语言本身强大的功能和灵活性。然后,为了让.NET 框架应用程序顺利访问这个传统组件,开发人员可以使用托管扩展编写一个很小的、转换效率很高的包装(wrapper)程序。
● 需要让任何一种与.NET框架相容的语言可以访问C++组件
托管扩展支持从任何.NET 框架相容语言来调用C++类。调用之所以可以实现,是因为使用托管扩展可以编写简单的包装类来对访问方暴露对应的C++类和方法。这些包装类都是托管的,并可以从其他.NET框架相容程序中进行调用。在调用过程中,外包类在托管的类和未托管的类之间扮演了映射层的角色—— 它让方法调用直接传递到未托管的类中。另外,需要特别指出的是,托管扩展支持对任何未托管的DLL或库的调用。
● 需要从未托管的代码中访问.NET框架类
为了得到更多的功能,在未托管的代码中,可以访问.NET 框架中的类。使用托管扩展,可以从C++代码中直接创建、调用一个.NET 框架类。在实际编程中,可以像处理普通未托管的C++类一样对待对托管的类的处理。另外,在.NET框架中提供了对未托管的COM的调用支持,可以编写未托管的代码直接访问。
托管代码如何调用非托管代码(c sharp如何调用c++代码)?
两种常用的做法:
下载:
http://download.microsoft.com/download/f/2/7/f279e71e-efb0-4155-873d-5554a0608523/CLRInsideOut2007_01.exe
1. COM interop
具体操作:
a. 用atl写com服务程序
b. 使用Tlbimp将atl写的com程序转换成 COM DLL
用如下命令:
tlbimp 你写的com.dll
tlbimp是 .NET Framework SDK中附带的类型库导入程序。用这个命令即是把生成一个非托管com dll的托管包装。
c. 托管客户端非常简单
直接new一下,然后调用对应的方法即可。
2. P/Invoke
a. 在托管客户端增加一条 DllImport语句和一个方法的调用。
介绍一个P/Invoke网站,http://pinvoke.net/
这个网站主要是一个wiki,允许开发者发现,编辑,增加PInvoke的签名,用户自定义类型和从托管代码(指c#和VB.net开发语言)访问win32和其他非托管api的信息。
世界各地的.Net开发者可以很容易分享自己有价值的东西给社区,
托管代码和非托管代码效率的对比
一直以来只知道托管代码的效率要比非托管代码低,至于低多少也没有可参考的数据。今天在csdn看到的英特尔多核平台编程优化大赛的广告,把里面的代码下载回来,分别用非托管c/托管cpp/c#做了个简略的性能测试,不比不知道,一比吓了一跳。且看数据说话。
第一步:原始代码如:
/* compute the potential energy of a collection of */
/* particles interacting via pairwise potential */
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <windows.h>
#include <time.h>
#define NPARTS 1000
#define NITER 201
#define DIMS 3
int rand( void );
int computePot(void);
void initPositions(void);
void updatePositions(void);
double r[DIMS][NPARTS];
double pot;
double distx, disty, distz, dist;

int main() {
int i;
clock_t start, stop;

initPositions();
updatePositions();
start=clock();
for( i=0; i<NITER; i++ ) {
pot = 0.0;
computePot();
if (i%10 == 0) printf("%5d: Potential: %10.3f\n", i, pot);
updatePositions();
}
stop=clock();
printf ("Seconds = %10.9f\n",(double)(stop-start)/ CLOCKS_PER_SEC);
int e;
scanf("%d",&e);
}
void initPositions() {
int i, j;
for( i=0; i<DIMS; i++ )
for( j=0; j<NPARTS; j++ )
r[i][j] = 0.5 + ( (double) rand() / (double) RAND_MAX );
}
void updatePositions() {
int i, j;
for( i=0; i<DIMS; i++ )
for( j=0; j<NPARTS; j++ )
r[i][j] -= 0.5 + ( (double) rand() / (double) RAND_MAX );
}
int computePot() {
int i, j;

for( i=0; i<NPARTS; i++ ) {
for( j=0; j<i-1; j++ ) {
distx = pow( (r[0][j] - r[0][i]), 2 );
disty = pow( (r[1][j] - r[1][i]), 2 );
distz = pow( (r[2][j] - r[2][i]), 2 );
dist = sqrt( distx + disty + distz );
pot += 1.0 / dist;
}
}
return 0;
}
执行结果如下:

执行时间4.609s。
第二步:托管
新建一个 C++ CLR Console Aplication,命名为mcpp。打开mcpp.cpp文件,将原始代码粘贴进来即可(代码太长这里就不贴出来了,可以在全贴下面的下载全部源码)。
执行结果如下:

执行时间:15.1720s。
第二步:c#
笔者将原始代码翻译成CS代码,如下:
using System;
using System.Collections.Generic;
using System.Text;


namespace cs
{
class Program
{
private const int RAND_MAX = 0x7fff;
private const int NPARTS = 1000;
private const int NITER = 201;
private const int DIMS = 3;
private double pot;
private double distx, disty, distz, dist;
private Random random = new Random(Environment.TickCount);
private double[][] r = new double[DIMS][];

public void main()
{
int i;
int start, stop;

for (int ii = 0; ii < DIMS; ii++)
{
r[ii] = new double[NPARTS];
}

initPositions();
updatePositions();

start = Environment.TickCount;
for (i = 0; i < NITER; i++)
{
pot = 0.0;
computePot();
if (i % 10 == 0)
Console.WriteLine("{0}: Potential: {1:##########.###}", i, pot);
updatePositions();
}
stop = Environment.TickCount;
Console.WriteLine("Seconds = {0:##########.#########}", (double)(stop - start)/1000);
}

private void computePot()
{
int i, j;

for (i = 0; i < NPARTS; i++)
{
for (j = 0; j < i - 1; j++)
{
distx = Math.Pow((r[0][j] - r[0][i]), 2);
disty = Math.Pow((r[1][j] - r[1][i]), 2);
distz = Math.Pow((r[2][j] - r[2][i]), 2);
dist = Math.Sqrt(distx + disty + distz);
pot += 1.0 / dist;
}
}
}

private void updatePositions()
{
int i, j;

for (i = 0; i < DIMS; i++)
for (j = 0; j < NPARTS; j++)
r[i][j] -= 0.5 + ((double)random.Next(RAND_MAX)/(double)RAND_MAX);
}

private void initPositions()
{
int i, j;
for (i = 0; i < DIMS; i++)
for (j = 0; j < NPARTS; j++)
r[i][j] = 0.5 + ((double)random.Next(RAND_MAX)/(double)RAND_MAX);
}

static void Main(string[] args)
{
Program p = new Program();
p.main();
Console.ReadLine();

}
}
}
执行结果如下:
分享到:
相关推荐
托管代码与非托管代码是编程领域中的两个重要概念,它们主要与.NET框架和C++等语言的使用密切相关。本文将深入探讨这两个概念,以及DLL动态链接库调用的相关知识。 首先,我们来理解什么是托管代码。在.NET环境中,...
### 托管代码与非托管代码详解 #### 一、托管代码的概念与优势 托管代码是一种新型的技术,尤其在Visual Studio .NET 2003发布后,许多开发者开始关注和使用这一技术。托管代码主要指由Visual Basic .NET和C#等...
CLR 完全介绍--托管代码与非托管代码之间的封送处理 CLR(Common Language Runtime)是 .NET Framework 的核心组件之一,负责管理托管代码的执行和内存管理。在 .NET 应用程序中,CLR扮演着非常重要的角色,因为它...
ASP.NET中的托管代码和非托管代码是两种不同的代码执行方式,它们在.NET框架中扮演着重要的角色。了解这两种代码类型对于开发高效、安全且可维护的.NET应用至关重要。 托管代码,顾名思义,是由.NET运行时环境(也...
### 非托管代码访问托管代码 #### 概述 在.NET框架中,代码主要分为两种类型:托管代码(Managed Code)与非托管代码(Unmanaged Code)。托管代码是指通过.NET运行时(如Common Language Runtime, CLR)进行管理...
非托管代码回调方法的实现是将托管代码与非托管代码(如C++或原生DLL)集成的关键技术。在.NET框架中,托管代码是由CLR(Common Language Runtime)管理的,而非托管代码则不受其控制。当需要从非托管代码调用托管...
C#托管代码与C++非托管代码互相调用实例 在软件开发中,C#托管代码和C++非托管代码是一种常见的开发模式。这两种语言的结合可以充分发挥它们各自的优势,C#托管代码可以提供高级的开发体验和强大的安全机制,而C++...
然而,有时我们可能需要访问非托管代码,例如操作系统API、硬件驱动或者第三方库,这些功能并未封装在.NET框架内。这时,我们可以使用C#的`extern`关键字来实现对外部非托管代码的调用。本文将详细介绍如何使用`...
"C#与非托管代码交互操作"这个主题就是探讨如何在C#应用中调用和管理非托管代码资源。 1. **P/Invoke(Platform Invoke)** P/Invoke是.NET Framework提供的一种机制,允许C#代码调用Windows API或其他非托管DLL中...
托管与非托管代码是编程领域中的两个重要概念,主要涉及.NET框架和C++等语言的使用。这篇文章将深入探讨这两者的差异,以及它们在实际开发中的应用。 托管代码(Managed Code)是指能够在.NET Framework的公共语言...
《Delphi.NET 托管与非托管代码》是由知名IT专家李维撰写的一本书,主要探讨了.NET框架下的编程模型,特别是如何在托管代码和非托管代码之间进行交互。这本书对于理解.NET平台的核心机制和跨语言互操作性具有重要的...
#### 三、托管代码与非托管代码对比 - **托管代码**:运行在CLR中,享有CLR提供的所有服务。例如,内存管理、异常处理、安全检查等。这些服务使得托管代码更加安全、稳定。 - **非托管代码**:指那些不在.NET环境...
此段代码展示了如何将非托管环境中的`std::string`类型转换为托管环境中的`System::String^`类型。通过使用`gcnew`关键字创建一个新的`System::String^`实例,并传入`std::string`对象的`c_str()`返回值作为构造函数...
### C#调用非托管代码的关键知识点 #### 1. 不返回值的参数 当C#需要调用一个不返回值的非托管函数时,主要关注的是如何将参数正确地从C#传递到非托管环境中。 **C++ 原型:** ```cpp bool SendNewSms(char* szTel,...
在C#中,由于.NET框架的特性,它既支持托管代码(由.NET运行时管理的代码),也支持非托管代码(如C++或WinAPI函数),这使得在C#中进行DLL注入成为可能。 描述中提到的“FastWin32 dll注入库”是这个项目的核心...
现在很多人都使用C#来开发windows mobile上的应用程序,因此,有必要给出这个“使用托管代码开发WINCE自带数据库”的例子。这篇文章参考了Joao Paulo Figueira在2005年写的文章《CEDB .NET》,并对作者给出的代码...
托管代码则是指在CLR环境中执行的代码,它享有.NET框架提供的多种服务,如类型安全、垃圾回收、异常处理和内存管理。 1. **托管代码的概念** 托管代码是在.NET框架下编译的高级语言代码(如C#、VB.NET或F#等)。...
【托管平台与非托管的互操作】是指在编程中,如何让使用托管代码(如C#)的应用程序与非托管代码(如C++)进行通信和数据交换。COM(Component Object Model)组件是这种互操作性的一个关键工具,因为它们可以被不同...
通过这个特性,我们可以精确地指定字段在内存中的位置,这对于与非托管代码交互特别重要,因为非托管代码通常依赖于特定的内存布局。例如,`LayoutKind.Explicit` 使我们能够使用 `[FieldOffset]` 特性为每个字段...