VS C# 嵌入互操作类型

SQLDMO.Restore oRestore = new SQLDMO.RestoreClass();
SQLDMO.SQLServer oSQLServer = new SQLDMO.SQLServerClass();

 

      在VS2010中编译上述代码,提示“无法嵌入互操作类型“SQLDMO.BackupClass”。请改用适用的接口。” 经过查阅相关资料发现,将引用的Interop.ADOX和Interop.SQLDMO引用属性中的嵌入互操作类型设置为False即可。

      具体原理还不是特别理解,见http://www.cnblogs.com/pnljs/archive/2012/02/20/2359313.html

      这里面提到一点,“嵌入互操作类型”设定为true,实际上就是不引入互操作集(编译时候放弃Com程序集),仅编译用户代码的程序集。而设定为false的话,实际就是需要从互操作程序集中获取 COM 类型的类型信息。这是不是意味着,嵌入是更轻量化的引用,只编译需要编译的部分,将引用的部分代码编译到本地的程序集中。而可以不依赖于原始的dll,比如Interop.ADOX。程序可以脱离该dll运行,因为所需要的代码已经“嵌入”到程序里了。

     如此看来,这样确实可以减轻程序的负担,然而一旦遇到像这种,无法嵌入的话,只能老老实实引用这个dll,将“嵌入互操作类型”设置为False,即可。

转载于:https://www.cnblogs.com/liwenqiao/p/4799038.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值