Tag: C#的

模数和rand()是如何工作的?

所以,我一直坚持这一点。 rand()%6将始终生成0-5之间的结果。 但是当我需要时,比如说6-12。 我应该有rand()%6 + 6 0+6 = 6. 1+6 = 7. … 5+6 = 11. ??? 所以我需要+7如果我想要6-12的时间间隔? 但是,0 + 7 = 7。 什么时候将6随机分配? 我在这里错过了什么? 哪一个是6到12之间的随机数字的正确方法? 为什么? 这似乎是我在这里失去了一些东西。

为iOS 7半透明UINavigationBar实现明亮生动的色彩

iOS 7.1更新 :看起来修改UINavigationBar中的alpha通道的解决方法在此更新中被忽略。 现在,最好的解决办法似乎是“处理它”,并希望你select的任何颜色都可以产生半透明的效果。 我仍在研究如何解决这个问题。 iOS 7.0.3更新 : 我们创build的GitHub库已经更新,以稍微解决这个问题,当使用iOS 7.0.3。 不幸的是,在iOS 7.0.2和更早版本以及iOS 7.0.3中都不支持这两种颜色。 似乎苹果改善了饱和度,但代价是不透明度(因为模糊的半透明度取决于不透明度水平)。 我和其他一些人正在努力为此创造一个更好的解决scheme。 我相信很多人已经遇到了iOS 7倾向于使UINavigationBar颜色变得半透明的问题。 我的目标是实现一个UINavigationBar与这个色调,但半透明: 但是,半透明,我得到这个。 背景视图是白色的,据我了解,这个视图会变得更轻: 有没有办法在保持透明的同时达到原有的色彩? 我注意到Facebook已经能够让他们的酒吧成为他们丰富的蓝色,如下所示: 所以我知道必须有某种方法。 背景视图显然在这里有所作为,但其大部分内容也是灰色/白色。 看起来,无论你穿什么色调的颜色,你都不会在半透明的情况下得到鲜艳的色彩。 更新与解决scheme。 这是我最终提出的解决scheme。 我采取了aprato的解决scheme,然后在UINavigationController子类中包含自定义的UINavigationController 。 我创build了一个具有下面列出的实现的存储库,以及一个示例应用程序 。 //////////////////////////// // CRNavigationBar.m //////////////////////////// #import "CRNavigationBar.h" @interface CRNavigationBar () @property (nonatomic, strong) CALayer *colorLayer; @end @implementation CRNavigationBar static CGFloat const kDefaultColorLayerOpacity = 0.5f; static […]

迭代std :: vector:unsigned与有符号的索引variables

在C ++中迭代一个向量的正确方法是什么? 考虑这两个代码片段,这个工作正常: for (unsigned i=0; i < polygon.size(); i++) { sum += polygon[i]; } 和这个: for (int i=0; i < polygon.size(); i++) { sum += polygon[i]; } 这会产生warning: comparison between signed and unsigned integer expressions 我是C ++世界中的新成员,所以unsignedvariables对我来说看起来有些可怕,而且我知道,如果使用不正确, unsignedvariables可能是危险的,所以 – 这是正确的吗?

正确使用“收益回报”

yield关键字是C#中的关键字之一,它继续使我迷惑,而且我从来没有确信我正确地使用它。 以下两段代码,哪个是首选,为什么? 版本1:使用收益率回报 public static IEnumerable<Product> GetAllProducts() { using (AdventureWorksEntities db = new AdventureWorksEntities()) { var products = from product in db.Product select product; foreach (Product product in products) { yield return product; } } } 版本2:返回列表 public static IEnumerable<Product> GetAllProducts() { using (AdventureWorksEntities db = new AdventureWorksEntities()) { var products = from product in […]

什么是std :: promise?

我很熟悉新的标准库的std::thread , std::async和std::future组件(例如见这个答案 ),这很简单。 然而,我不能完全掌握std::promise是什么,它在什么情况下最好使用。 标准文档本身并不包含除了类纲要之外的大量信息,也不仅仅是:: thread 。 有人可以给一个std::promise的情况下简短,简洁的例子,它是最习惯的解决scheme?

什么是C#或.NET中最糟糕的问题?

我最近正在使用一个DateTime对象,并写了这样的东西: DateTime dt = DateTime.Now; dt.AddDays(1); return dt; // still today's date! WTF? AddDays()的intellisense文档说,它增加了一天到date,它不会 – 它实际上返回一个date添加到它的一天,所以你必须写下来: DateTime dt = DateTime.Now; dt = dt.AddDays(1); return dt; // tomorrow's date 这个人之前已经咬了我好几次了,所以我认为对最糟糕的C#陷阱进行编目是很有用的。

面试问题:检查一个string是否是其他string的旋转

我的一位朋友今天在面试时被问到了软件开发人员的职位: 给定两个strings1和s2你将如何检查s1是否是s2的旋转版本? 例: 如果s1 = "stackoverflow"那么下面是它的一些旋转版本: "tackoverflows" "ackoverflowst" "overflowstack" 作为"stackoverflwo" 不是一个旋转的版本。 他给出的答案是: 以s2为例,find最长的s1子string前缀,这会给你一个旋转点。 一旦你find了这一点,在这一点上打破s2来获得s2a和s2b ,然后检查是否concatenate(s2a,s2b) == s1 这对我和我的朋友来说是一个很好的解决scheme。 但面试官认为不然。 他要求一个更简单的解决scheme。 请告诉我如何在Java/C/C++做到这一点? 提前致谢。

属性注入

我正在试图注入一个自定义的AuthorizeAttribute的依赖如下: public class UserCanAccessArea : AuthorizeAttribute { readonly IPermissionService permissionService; public UserCanAccessArea() : this(DependencyResolver.Current.GetService<IPermissionService>()) { } public UserCanAccessArea(IPermissionService permissionService) { this.permissionService = permissionService; } protected override bool AuthorizeCore(HttpContextBase httpContext) { string AreaID = httpContext.Request.RequestContext.RouteData.Values["AreaID"] as string; bool isAuthorized = false; if (base.AuthorizeCore(httpContext)) isAuthorized = permissionService.UserCanAccessArea(AreaID, httpContext.User); return isAuthorized; } } 这工作,但似乎是解决作为一个单身的含义,我得到的问题在我的前面描述的问题 我想要做的是使用属性注入,但作为我的属性本身不解决的统一我找不到一种方法来configuration容器来拦截和解决属性。 我已经尝试了以下内容: public class […]

如何刷新c#dataGridView更新后?

我有一个dataGridView当我点击任何行打开表单来更新行数据,但结束更新后,更新表单closures,但dataGridView数据不更新 我怎样才能做到这一点 ?

赋值使得整型指针没有强制转换

来自Java背景,我正在学习C,但是我发现那些模糊的编译器错误信息越来越令人沮丧。 这是我的代码: /* * PURPOSE * Do case-insensetive string comparison. */ #include <stdio.h> #include <string.h> #include <ctype.h> int compareString(char cString1[], char cString2[]); char strToLower(char cString[]); int main() { // Declarations char cString1[50], cString2[50]; int isEqual; // Input puts("Enter string 1: "); gets(cString1); puts("Enter string 2: "); gets(cString2); // Call isEqual = compareString(cString1, cString2); if (isEqual […]