草庐IT

Determine_if_a_string_is_numeric

全部标签

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

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

c# - 清理病态嵌套 "if { } else { if { } else { if { ... } } }"

我目前不幸在处理其他人的C#代码,这让我大吃一惊。我不知道我之前的人是如何维护这段代码的,因为它的各种病症已经使IDE、编译器、运行时环境崩溃......我今天面临的问题涉及一个15兆字节的源文件,该文件具有真正令人惊叹的病态嵌套程度。代码如下:if(var==0){//dostuff}else{if(var==1){//dostuff}else{if(var==2){//dostuff,identicalwordforwordtothe`var==1`case}else{//etc.}}}在最好的情况下,这是一个有问题的风格选择。然而,这与代码的另一种病态相结合:其中一些block将

c# - 是否有带谓词的 String.IndexOf?

我需要能够说类似myString.IndexOf(c=>!Char.IsDigit(c))的东西,但我在.NET框架中找不到任何这样的方法。我错过了什么吗?以下是有效的,但我自己的滚动在这里似乎有点乏味:usingSystem;classProgram{staticvoidMain(){stringtext="555ttt555";intnonDigitIndex=text.IndexOf(c=>!Char.IsDigit(c));Console.WriteLine(nonDigitIndex);}}staticclassStringExtensions{publicstaticint

c# - 一对一关系导致异常 : AssociationSet is in the 'Deleted' state. 给定多重约束

我首先按照此处规定的方法使用EF代码建立了一对一的关系:UnidirectionalOne-To-OnerelationshipinEntityFramework我的映射看起来像这样......protectedoverridevoidOnModelCreating(DbModelBuildermodelBuilder){modelBuilder.Entity().HasRequired(i=>i.NewsItem).WithOptional(e=>e.Asset).Map(m=>m.MapKey("NewsItemId"));}但是当我得到这个异常时......Arelationsh

c# - `ReadAsAsync<string>` 和 `ReadAsStringAsync` 应该用来做什么?

应该做什么HttpContentExtensions.ReadAsAsync和HttpContent.ReadAsStringAsync用来做什么?他们似乎在做类似的事情,但工作方式却很奇怪。下面是几个测试及其输出。在某些情况下JsonReaderException被抛出,在某些情况下,输出JSON但带有额外的转义字符。我最终在我的代码库中同时使用了这两个函数,但如果我能理解它们应该如何工作,我希望能在其中一个上保持一致。//CreatedataandserialisetoJSONvardata=new{message="helloworld"};stringdataAsJson=Js

c# - 将 C# 中的 String^ 转换为 C++/CLI 中的 CString

我在用MFC编写我的应用程序时遇到了一个问题,需要帮助。我在我的应用程序中使用CLR即CommonLanguageRuntime来集成c#API。但现在我坚持将System::String^转换为CString。我做不到。我正在使用以下代码。String^csPass=gcnewString(strPassword.GetBuffer());array^Value=Encoding::UTF8->GetBytes(csPass);for(inti=0;iLength;i++){csPass+=String::Format("{0:X2}",Value[i]);}现在我想将csPass转

c# - ASP.NET 用户控件 : Page_Load fires before property is set

这让我发疯。我有一个非常简单的用户控件:publicint?ImageId{set;get;}protectedvoidPage_Load(objectsender,EventArgse){...dosomethingwithImageId...}然后我将此控件放在UpdatePanel中带有ListView的页面上:'ID="cipPreview"runat="server"/>问题是Page_Load在ASP.NET设置ImageId之前触发。在调试器的帮助下,我发现由于某种原因,MyControl中的ImageId已设置,但它仅在Page_Load完成处理后才会发生。怎么了?

c# - 如何实现 StringBuilder 和/或调用 String.FastAllocateString?

我很想知道我是否可以创建一个优化版本的StringBuilder(尝试稍微加快它的速度,因为它目前是我的一个应用程序的瓶颈)。对我来说不幸的是,它似乎利用了我无法使用(或者看起来如此)的“神奇”系统调用。反编译System.Text.StringBuilder的源代码后,我注意到它使用了以下内部(因此无法调用)系统调用:[SecurityCritical][MethodImpl(MethodImplOptions.InternalCall)]internalstaticstringFastAllocateString(intlength);还有这个未记录的属性被大量使用:[ForceT

c# - String.comparison 性能(带修剪)

我需要做很多高性能的不区分大小写的字符串比较,并意识到我这样做的方式.ToLower().Trim()真的很愚蠢,因为所有的新字符串都被分配了所以我仔细研究了一下,这种方式似乎更可取:String.Compare(txt1,txt2,StringComparison.OrdinalIgnoreCase)这里唯一的问题是我想忽略前导或尾随空格,即Trim()但如果我使用Trim,我会遇到与字符串分配相同的问题。我想我可以检查每个字符串,看看它是StartsWith("")还是EndsWith(""),然后才修剪。或者找出每个字符串的索引、长度并传递给string.Compareoverr

c# - PropertyChanged 事件测试 : is this a good way?

我正在使用MVVM模式开发WPF应用程序。我的ViewModel代码如下:publicboolEditModeEnabled{get{return_EditModeEnabled;}set{_ModeEditModeEnabled=value;OnPropertyChanged("EditModeEnabled");OnPropertyChanged("CommentTextBoxVisibility");}}OnPropertyChanged是基类的虚方法,它只是引发PropertyChanged事件。我想测试PropertyChanged事件引发和我的测试方法:publicvoid