- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我和我的同事正在讨论使用这些方法中的哪一种来自动生成用户 ID 和帖子 ID 以在数据库中进行识别:
一个选项使用 Random 的单个实例,并采用一些有用的参数,因此它可以重复用于各种字符串生成情况(即从 4 位数字引脚到 20 位字母数字 ID)。这是代码:
// This is created once for the lifetime of the server instance
class RandomStringGenerator
{
public const string ALPHANUMERIC_CAPS = "ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890";
public const string ALPHA_CAPS = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
public const string NUMERIC = "1234567890";
Random rand = new Random();
public string GetRandomString(int length, params char[] chars)
{
string s = "";
for (int i = 0; i < length; i++)
s += chars[rand.Next() % chars.Length];
return s;
}
}
另一个选项就是简单地使用:
Guid.NewGuid();
我们都知道 Guid.NewGuid()
可以满足我们的需要,但我宁愿使用自定义方法。它做同样的事情,但控制更多。
我同事认为因为自定义方法是我们自己炒出来的,所以比较容易产生碰撞。我承认我并不完全了解 Random 的实现,但我认为它与 Guid.NewGuid() 一样随机。自定义方法的典型用法可能是:
RandomStringGenerator stringGen = new RandomStringGenerator();
string id = stringGen.GetRandomString(20, RandomStringGenerator.ALPHANUMERIC_CAPS.ToCharArray());
编辑 1:
编辑 2:
我们还使用经过精心设计的方法生成帖子 ID,与 session token 不同,它需要看起来漂亮才能在我们网站的 url 中显示(如 http://mywebsite.com/14983336 ),因此 guid 在这里不是一个选项,但是冲突仍然存在避免。
最佳答案
I am looking for a more in depth reason as to why the cooked up method may be more likely to generate collisions given the same degrees of freedom as a Guid.
首先,正如其他人所指出的,Random
不是线程安全的;从多个线程使用它会导致它破坏其内部数据结构,从而始终生成相同的序列。
其次,Random
是根据当前时间播种的。在同一毫秒内创建的两个 Random
实例(回想一下,在现代硬件上,一毫秒是几 百万 个处理器周期)将具有相同的种子,因此会产生相同的序列.
第三,我撒谎了。 Random
不根据当前时间播种;它是根据机器处于事件状态的时间来播种的。种子是一个 32 位数字,并且由于粒度以毫秒为单位,因此只有几周的时间才能完成。但这不是问题;问题是:您创建 Random
实例的时间段很可能在机器启动后的几分钟内。 每次重启一台机器,或者在集群中将一台新机器联机,会有一个小窗口,其中会创建 Random 实例,发生的次数越多,您获得之前拥有的种子的可能性就越大。
(更新:较新版本的 .NET 框架已经缓解了其中的一些问题;在那些版本中,您不再让在同一毫秒内创建的每个 Random
都具有相同的种子。但是仍然有Random
有很多问题;永远记住它只是伪随机,而不是加密强度随机。Random
实际上是非常可预测的,所以如果你依赖于不可预测性,它不合适。)
正如其他人所说:如果您想要数据库的主键,那么让数据库为您生成一个主键;让数据库完成它的工作。如果你想要一个全局唯一的标识符,那么使用 guid;这就是他们的目的。
最后,如果您有兴趣了解更多有关 guid 的使用和滥用的信息,那么您可能想阅读我的“guid 指南”系列;第一部分在这里:
关于c# - Guid.NewGuid() VS 来自 Random.Next() 的随机字符串生成器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14983336/
这个问题已经有答案了: How to modify a public field of a field of a field… As in link.next.next.next(.next*n) n
我有一个保存链接的数组。每个链接都有一个名为 next 的公共(public)字段,它可以保存另一个链接,该链接可以保存更多链接等。当我想删除东西时我可以做 array[x].next = array
文档概述了在中间件中使用“await next()”的用例,导致中间件暂停并触发下游的下一个中间件,直到所有中间件都执行完毕,此时上游级联将开始并且中间件将完整执行。如果用户想要缩短级联,那么单独写“
我今天遇到了一个用例,我试图让我的 nextjs 应用程序在 android webview 中工作,不幸的是 android 不解析以 _next 开头的路径并且我的大部分块文件都在_next/st
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 8 年前。 Improve th
next-with-apollo npm 库和 the approach shown in next.js docs 中选择的“next.js 中的 apollo-client”方法对比. next.
我尝试使用 next-auth 获取凭据身份验证,但我没有使用它的经验,无论我做什么,我都会收到以下消息:[next-auth][error][callback_credentials_jwt_err
更改语言时需要更改路线名称。例如,我有一条路线 /en/career但是当我改成捷克语时,我需要一条路线 /cs/kariera .基本上我需要本地化 URL。现在,当我在 /en/career 上时
更好/优雅的方法是什么? jQuery(this).find('title').next().next().next().eq(0).text(); //THIS WORKS 我尝试使用 jQuery
我只是对 node 感到好奇。 node.next 和 node.next。到目前为止,我们已经了解到节点有两个部分,其中存储数据和下一个节点的地址(node.next),然后是 node.next.
好的,我正在尝试单独隐藏这组信息。 这有效: $(".arrow").click(function() { $(this).next().next().slideToggle(); }); Mo
我开发了一个 Web 应用程序,它使用 Nextjs 应用程序作为前端和一个 Python (Django) API 服务器作为后端。我的大多数前端页面都有对后端服务器的 API 调用(在 Compo
如果我没有通过身份验证,我正在尝试使用NextJS中间件保护一些路由,我正在使用Next-auth进行身份验证,从文档中看,这就是MIDDLEWAR.TS文件应该是什么样子。Rn的问题是,即使当我通过
我正在使用 nextJs,需要添加对 less 和 css 的支持。我想要一个项目同时拥有 next-css 和 next-less 。但它一次接受一个。这是我正在使用的 const withCSS
我正在构建下一个项目的 typescript 。如果我将此配置文件保留为 next.config.js , 我在 tsconfig.json 收到警告说“找不到next.config.ts”。所以 t
我有一个自定义登录网址/ View /模板。我对页面使用 @login_required 装饰器(让 称为 my_page) 需要登录。试图访问 my_site.com/my_page 正确调用 my
下面的代码工作正常: class String def foo next! end end puts 'hh'.foo # hi 这个也很好用: class String d
我在我的Next.js应用程序中使用Next-auth进行身份验证。成功登录后,我立即被重定向到登录页面,表明该会话已变为未经身份验证。。相关代码片段:。_app.tsx:。Layout.tsx:。L
我想在 nextjs 中创建动态页面以匹配以下路由 users/[user]/[dashboard]。我的文件结构 pages/ users/ -[user].js // will
我直接按照官网的步骤操作: https://nextjs.org/docs/ 第一步。 npm install --save next react react-dom 步骤 2. 将脚本添加到 pac
我是一名优秀的程序员,十分优秀!