解决“错误为Lc.exe已退出,代码为-1”

Posted snf全栈工程师

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解决“错误为Lc.exe已退出,代码为-1”相关的知识,希望对你有一定的参考价值。

今天做项目的时候突然出现编译不通过,错误为Lc.exe已退出,代码为-1。
网查了一下,原因是项目中使用了第三方组件(Developer Express v2011)造成的,分享如下:
这个第三方组件是个商业组件,他在组件的主使用类定义了 LicenseProvider(typeof(LicFileLicenseProvider)) 这个Attribute。 
VS在编译时检测到这个类的时候,会检查到组件使用的是LicFileLicenseProvider这个属性,表示有组件使用的是把许可的辅助信息保存在license.licx文件中,这个文件保存在VS中解决方案资源管理器中的Properties文件夹内。 
这个文件的内容实际上是个引用,他保存着你使用的第三方组件主使用类的名称空间+类名+文件名+文化+PublicKeyToken信息,这个文件是自动生成的。 
如果这个信息与你使用的组件dll中的实际内容不匹配,则lc.exe就会出现这个错误信息。这个信息出现的原因是你在项目中使用了商业组件的测试版,而 在发布的时候使用的是哪个商业组件的破解版。大部分的商业组件经过破解的时候,强名称签名就会消失,所以破解的组件与原来的测试版组件的引用信息是完全不 同的。故每次编译的时候,VS自动调用语言编译器之前会调用lc(许可编译器),就会出现-1错误。

解决方法:
  1、就是把Properties文件下的license.licx给删除,重新编译。
  2、如果还出现这个问题的话,必须将你的破解版的哪个组件使用lidism给翻译成il语言,然后用ilasm重新编译成dll,在编译的时候加入   /key=[你的强名称文件].snk   参数,自己加入强名称签名,然后使用VS重新编译,就可以成功了。

 注意:我原来也是在Properties文件下删除license.licx,编译,问题依旧,后来是在开发项目界面 中的解决方案资源管理器中的Properties展开项下面把license.licx删除掉,重新编译,就好了

虽然我用的不是这个第三方插件,但是用此方法同样可用!

以上是关于解决“错误为Lc.exe已退出,代码为-1”的主要内容,如果未能解决你的问题,请参考以下文章

错误为Lc.exe已退出,代码为-1

CentOS下telnet退出失败如何解决?CentOS下telnet退出失败的解决方法

退出整个应用解决方案

退出Docker后保持继续运行的解决办法 docker结束但不退出 docker退出后继续运行系统

python多进程-进程池模式退出异常解决办法

使用 set -e 解决程序退出状态的一般解决方案