草庐IT

box-container

全部标签

Java - String.contains() 行为异常

这段代码在我的开发机器上运行良好(使用NetbeansIDE在VirtualBoxjre8上安装的Windows7),但在另一台机器上(Windows7jre8)总是返回true。它应该只查找名称为“town_house.html”的文件,而不是它总是为文件夹中的每个文件返回true。从提示符运行jar文件我没有得到任何异常。也许这只是我通常用C/C++编程的一个小错误……有什么想法吗?for(Filef:files){if(f.toString().contains("_")&&f.toString().contains(".html")){System.out.print("Pro

windows - Vagrant Windows Box 在 'vagrant up' 之后需要永远启动

我在MacOSXMavericks上尝试运行VagrantWindows7机器(http://aka.ms/vagrant-win7-ie11)。此外,我还安装了vagrant-windows插件并使用以下属性配置了Vagrantfile:PS:不要考虑下面的语法。它只是代表我的文件中配置的内容。gui=truememory=2048cpu=2所以当我运行“vagrantup”命令时,我得到了这个输出:gyo-macbook:Win7gyo$vagrantupBringingmachine'default'upwith'virtualbox'provider...==>default:

c# - .NET、.Contains() 或 .Count() 哪个更快?

我想将修改后的记录数组与从数据库中提取的记录列表进行比较,并从数据库中删除传入数组中不存在的那些记录。修改后的数组来自维护数据库的客户端应用程序,并且此代码在WCF服务应用程序中运行,因此如果客户端从数组中删除一条记录,则应从数据库中删除该记录。下面是示例代码片段:publicvoidUpdateRecords(Record[]recs){//lookfordeletedrecordsforeach(RecordrecinUnitOfWork.Records.ToList()){varcopy=rec;if(!recs.Contains(rec))//usethisone?if(0==

c# - 为什么 ICollection<>.Contains 会忽略我重写的 Equals 和 IEquatable<> 接口(interface)?

我对EntityFramework项目中的导航属性有疑问。这是类MobileUser:[DataContract][Table("MobileUser")]publicclassMobileUser:IEquatable{//constructorsomitted....//////Theprimary-keyofMobileUser.///ThisisnottheVwdIdwhichisstoredinaseparatecolumn///[DataMember,Key,Required,DatabaseGenerated(DatabaseGeneratedOption.Identit

c# - 为什么为泛型发出 'box' 指令?

这是一个相当简单的泛型类。泛型参数被限制为引用类型。IRepository和DbSet也包含相同的约束。publicclassRepository:IRepositorywhereTEntity:class,IEntity{protectedreadonlyDbSet_dbSet;publicvoidInsert(TEntityentity){if(entity==null)thrownewArgumentNullException("entity","Cannotaddnullentity.");_dbSet.Add(entity);}}编译后的IL包含box指令。这是发布版本(调试

c# - LINQ: ...Where(x => x.Contains(以 "foo"开头的字符串 ))

给定以下类的集合:publicclassPost{...publicIListTags{get;set;}}有没有一种简单的方法可以使用LINQ获取所有包含以“foo”开头的标签的Post?varposts=newList{newPost{Tags=new[]{"fooTag","tag"}},newPost{Tags=new[]{"barTag","anyTag"}},newPost{Tags=new[]{"someTag","fooBarTag"}}};varpostsWithFooTag=posts.Where(x=>[somefancyLINQqueryhere]);posts

c# - "Compile with/main to specify the type that contains the entry point."

根据下面的代码,我收到以下消息。我相当确定我得到它的“原因”,我只是不知道如何重新排列代码以移动/删除/替换导致错误的语句之一。“使用/main编译以指定包含入口点的类型。”"staticvoidMain(string[]args)"下有一堆代码,我从http://support.microsoft.com/kb/816112为了从自动递增中获取ID,所以当其余代码填充Access数据库时,我可以让它自动递增。任何帮助表示赞赏。也欢迎使用更简单的代码获得结果的建议!namespaceWindowsFormsApplication1{publicpartialclassForm1:For

c# - Box 和 Unbox 是什么意思?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicates:WhydoweneedboxingandunboxinginC#?Whatisboxingandunboxingandwhatarethetradeoffs?在C#中,“装箱和拆箱”是什么意思?这是我在其中找到文本的MSDN的摘录。Butthisconveniencecomesatacost.AnyreferenceorvaluetypethatisaddedtoanArrayListisimplicitlyupcasttoObject.Iftheitemsarevaluetypes,theymustbeb

c# - List<T>.Contains() 是线程安全调用 - C#

我的理解是,如果您在C#中使用泛型列表(List),那么它可以支持多个并发读取器,但只能支持一个写入器。当您将编写器引入混合时,您还必须提供同步结构以使操作线程安全。List.Contains是否被视为读取操作?换句话说,如果我调用这个方法,我是否需要担心写入者可能同时写入这个列表? 最佳答案 是的,你应该。基本上,如果列表可能同时用于写入,我会同步任何操作。一般来说,我发现集合分为两类-一种是创建、初始化然后再也不会更改(线程安全),另一种是随着时间的推移而发生变化(非线程安全,所有访问都锁定)。

c# - 为什么具有 T : class result in boxing? 约束的泛型方法

这个问题在这里已经有了答案:BoxingwhenusinggenericsinC#(2个答案)关闭3年前。为什么将T限制为类的泛型方法会在生成的MSIL代码中包含装箱指令?我对此感到非常惊讶,因为既然T被限制为引用类型,那么生成的代码应该不需要执行任何装箱。这是C#代码:protectedvoidSetRefProperty(refTpropertyBackingField,TnewValue)whereT:class{boolisDifferent=false;//forreferencetypes,weuseasimplereferenceequalitychecktodeterm