草庐IT

Double-to-Int

全部标签

c# - 将 long 转换为 double 的精度损失有多大?

我在stackoverflow上的不同帖子和C#文档中读到,将long(或任何其他表示数字的数据类型)转换为double会失去精度。由于float的表示,这一点非常明显。我的问题是,如果将较大的数字转换为double,精度损失有多大?我是否必须期望差异大于+/-X?我想知道这一点的原因是我必须处理一个long的连续计数器。这个值被我的应用程序读取为string,需要转换并且必须除以例如10或其他一些小数字,然后进一步处理。decimal是否更适合这项任务? 最佳答案 convertinglong(oranyotherdatatype

c# - 在运行内部代码之前,在锁之前和锁内设置 "double check"是否可以?

在处理线程安全时,我发现自己总是在执行锁block中的代码之前“仔细检查”,我想知道自己是否做对了。考虑以下三种做同样事情的方法:示例1:privatestaticSomeCollectionMyCollection;privatestaticObjectlocker;privatevoidDoSomething(stringkey){if(MyCollection[key]==null){lock(locker){MyCollection[key]=DoSomethingExpensive();}}DoSomethingWithResult(MyCollection[key]);}示

c# - 从集合创建 HashSet<int> 的最坏情况复杂度

我收藏了int我用来填充HashSet的值按照以下方式-varhashSet=newHashSet(myIEnumerable);假设迭代IEnumerable是O(n),创建HashSet的最坏情况复杂度是多少?以这种方式? 最佳答案 文档实际上指出:ThisconstructorisanO(n)operation,wherenisthenumberofelementsinthecollectionparameter.http://msdn.microsoft.com/en-us/library/bb301504.aspx

c# - 使用 LINQ to Entities 选择最近的记录

我有一个简单的LinqtoEnities表来使用日期字段查询和获取最新记录所以我尝试了这段代码:IQueryablealerts=GetAlerts();IQueryablelatestAlerts=fromainalertsgroupabya.UpdateDateTimeintogselectg.OrderBy(a=>a.Identifier).First();Error:NotSupportedException:Themethod'GroupBy'isnotsupported.还有其他方法吗?非常感谢! 最佳答案 我也有类似的

c# - 被拳击迷惑。将 -1 转换为 Int64 会抛出 InvalidCastException

好吧,我一定是忽略了一些非常简单的东西,但我迷路了。鉴于此objectval=-1;varfoo=(Int32)(val);varbar=(Int64)(val);转换为Int64抛出InvalidCastException。我知道这与拳击的一些奇怪之处有关,但我不明白其中的原因。据我所知,val在第一行被装箱为Int32。然后,当我尝试转换为Int32以外的其他内容时,将抛出InvalidCastException。我想这意味着当它实际上是Int32时,我正试图将val拆箱为Int64?还是很奇怪。不能转换为值拆箱然后尝试执行转换吗?类似的东西(显然这过于简单化了,也许盒装类型是未知

c# - Linq To Xml 属性的空检查

我想使用linq对此进行解析,我很好奇其他人使用什么方法来处理特殊情况。我目前的处理方式是:varbooks=frombookinbooksXml.Descendants("book")letName=book.Attribute("name")??newXAttribute("name",string.Empty)letPrice=book.Attribute("price")??newXAttribute("price",0)letSpecial=book.Attribute("special")??newXAttribute("special",string.Empty)sele

c# - 帮助我理解 "LINQ to Entities only supports casting Entity Data Model primitive types"

我有一个工作单元和一个使用EF4和POCO的存储库。由于EF在可以Skip()和Take()之前需要一个有序集,因此我添加了以下单元测试(没有模拟)只是为了提取一条记录以查看它是否有效。varmyList=UOW.EntityRepo.Get(orderbyLambda:p=>p.ID,page:1,pageSize:1);这导致表达式orderbyLambda={p=>Convert(p.ID)}和枚举期间的错误。ID是tinyint(Int16/短)那么为什么按ID排序失败呢?有关错误的更多信息Unabletocastthetype'System.Int16'totype'Syst

c# - .Net 4 : How to reference a dynamic object with property named "return"

我正在从公共(public)api检索json并使用JsonFx将其转换为动态对象。JsonFx.Json.JsonReaderreader=newJsonFx.Json.JsonReader();dynamicresponse=reader.Read(jsonAsString);json包含一个名为return的属性。例如{"result":"success","return":{"high":{"value":"3.85001","value_int":"385001","display":"3.85001\u00a0\u20ac","currency":"EUR"}}JsonFx

c# - 使用 Linq-to-sql 在 sql-server 中存储枚举

如何使用linq-to-sql在sql-server中存储枚举?我最终在我的代码中进行了大量的int转换。一定有更好的方法。我错过了什么?sqlItem.enumValue=(int)myEnumValue;...myEnumValue=(MyEnumType)sqlItem.enumValueSQLServer或LINQ在数据库中将值存储为字符串还是整数并不重要,我只是想避免所有这些散布在我的代码中的类型转换。是否可以通过我的linq-to-sql-classes的扩展方法来解决?如果可以,那会是什么样子? 最佳答案 您可以在DB

C# 将小数安全地转换为 int

我正在尝试安全地将小数转换为整数。有点像publicstaticboolDecimal.TryConvertToInt32(decimalval,outintval)如果无法转换为整数,则返回false,如果可以,则返回true并成功输出。这是为了避免在decimal.ToInt32方法中捕获OverflowException。最简单的方法是什么? 最佳答案 这里:publicstaticboolTryConvertToInt32(decimalval,outintintval){if(val>int.MaxValue||val