草庐IT

LOG_TYPE

全部标签

c# - "Predefined type ' System.* ' is not defined or imported"错误,visual studio 代码,omnisharp

我在几个.net核心应用程序中遇到上述错误的问题。我正在使用vscode版本1.18.0,但错误已经开始出现在以前的版本中。错误出现在每个.cs文件中的每种数据类型(如字符串、整数、void等)以及类导入。所有项目仍然可以正常编译和运行。同样在另一个工作站上,我没有在同一个项目中遇到问题,所以它似乎是本地omnisharp/vscode或windows?问题。有没有人遇到过类似的问题并设法修复它或对我可以尝试的方法有任何建议?我已经重新安装了vscode和omnisharp,但我仍然遇到问题。示例错误:未定义或导入预定义类型“System.Object”[GG]

c# - 如何保证 Array 中 "reference type"项目的更新对其他线程可见?

privateInstrumentInfo[]instrumentInfos=newInstrumentInfo[Constants.MAX_INSTRUMENTS_NUMBER_IN_SYSTEM];publicvoidSetInstrumentInfo(Instrumentinstrument,InstrumentInfoinfo){if(instrument==null||info==null){return;}instrumentInfos[instrument.Id]=info;//needtomakeitvisibletootherthreads!}publicInstru

c# - 如何在运行时加载的程序集中使用公共(public) log4net 引用?

我有一个单线程应用程序,它使用以下代码在运行时加载多个程序集:objDLL=Assembly.LoadFrom(strDLLs[i]);我希望以这种方式加载的程序集使用与其余程序集相同的log4net.ILog引用。但是看起来运行时加载的程序集有一个完全不同的引用并且需要它们自己的配置。有谁知道单个log4net.ILog是否可以跨使用.NET接口(interface)在运行时加载的程序集使用?这是Program类中的log4net.ILog创建和支持代码://Configurelog4netusingthe.configfile[assembly:log4net.Config.Xml

c# - 我应该在 #if (DEBUG) 中包装对 Debugger.Log() 的调用吗?

是否有必要在#if(DEBUG)预处理器指令中包装对Debugger.Log()的调用以优化代码,或者C#编译器是否会在构建RELEASE配置时仍然生成优化代码? 最佳答案 在RELEASE模式下,this调用没有任何类型的优化。调用出现在IL中。唯一的区别是如果没有DEBUGGER则它没有任何效果。来自文档Debugger.Log:Ifthereisnodebuggerattached,thismethodhasnoeffect.我建议衡量您应用的性能,然后选择要遵循的步骤。如果没有显着差异(从您的应用的角度来看),我会保留该日志

c# - Mono.Cecil type.IsAssignableFrom(derivedType) 等效项

我正在使用Mono.Cecil在Assembly中查找派生自给定的类型。通常可以使用IsAssignableFrom()方法来完成,但我无法确定它在Cecil中是等效的。有没有这样的方法或其他方法来检查它?谢谢迈克 最佳答案 继承检查和“赋值兼容性”检查实际上是不同的东西。您要检查继承还是“分配兼容性”?赋值兼容性包括很多东西,包括有符号/无符号转换、枚举到基类型的转换、char至short转换、通用方差转换、从接口(interface)到object的转换,从数组到IList和IList以及它们的基本接口(interface)、数

c# - log4net smtp appender 不发送电子邮件

我正在尝试实现log4net来发送电子邮件。以下是我的代码,但它不发送电子邮件。和在AssemblyInfo.cs中[assembly:log4net.Config.XmlConfiguratorAttribute(Watch=true)]这就是我创建日志对象的方式privatestaticreadonlylog4net.ILoglog=log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);此配置适用于文件输出,即RollingFileAppender,但不

c# - Linq 和相等运算符 : Expression of type 'System.Int32' cannot be used for parameter of type 'System.Object'

我试图重写C#中的相等(==)运算符来处理任何类型与自定义类型的比较(自定义类型实际上是null周围的包装器/框)。所以我有这个:internalsealedclassNothing{publicoverrideboolEquals(objectobj){if(obj==null||objisNothing)returntrue;elsereturnfalse;}publicstaticbooloperator==(objectx,Nothingy){if((x==null||xisNothing)&&(y==null||yisNothing))returntrue;returnfal

c# - log4net 一般故障。无法获取文件锁定

我是第一次尝试配置log4net,我确定我已正确配置所有内容,但是,在获得空日志文件后,我打开了log4net调试器。我现在不断看到以下错误:log4net:ERROR[RollingFileAppender]ErrorCode:GenericFailure.Unabletoacquirelockonfile"filepath\filename"Theprocesscannotaccessthefile"filepath\filename"becauseitisbeingusedbyanotherprocess.我目前通过我的Web.config文件配置了log4net:求助!!!

c# - EF6 : Code First Complex Type

我无法让EntityFramework将具有值对象(复杂类型)字段的域实体类展平到一个表中。如果我告诉我的模型构建器忽略我的值对象/复杂类型,一切正常,但这会导致我的表中丢失值对象的所有属性。一旦删除忽略语句,我就会得到“在多个位置创建跨实体共享的值”。如果我查看生成的CESQL文件,我会看到一个额外的表,该表以我的域类命名并附加了1,并且仅包含值对象参数。一些代码:我的领域类:publicUser{privateUser(){}publiclongId{get;privateset;}//dontask,inheritedlegacydatabasepublicstringUserI

c# - Log4net - 禁止将 "exception"附加到自定义 "PatternLayout"

当使用自定义“PatternLayout”时,log4net会将“异常”信息(如果存在)附加到每个日志条目。我正在尝试控制消息和堆栈跟踪信息的输出,并希望“抑制”此信息。我四处搜寻,但找不到办法。有什么想法吗?示例web.config条目(对于RollingFileAppender):谢谢 最佳答案 像这样配置布局:...将IgnoresException设置为false告诉appender布局将处理异常。因此您可以选择不打印堆栈跟踪。 关于c#-Log4net-禁止将"exceptio