- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我查阅了 C 标准(自 1999 年起),它只说 RAND_MAX
应该至少为 32767,但没有说明这个宏应该扩展为有符号整数还是无符号整数。单一 UNIX 规范(link 1、link 2)和 Linux 手册(link)没有增加任何清晰度。
有人会认为 RAND_MAX
应该是一个 signed int
,因为这就是 rand()
返回的值。
但是,我发现一些编译器将其定义为无符号:
这使得像下面这样看似无害的代码变得不可移植,并且由于已签名到未签名的升级而崩溃:
cos(w * t) + (rand() - RAND_MAX / 2) * 0.1 / (RAND_MAX / 2);
rand()
返回 [0,RAND_MAX
] 范围内的 signed int
。
如果 RAND_MAX
定义为 unsigned int
,则 rand()
的值将提升为 unsigned int
也是。
如果是这种情况,差值 (rand() - RAND_MAX/2)
将成为无符号整数的无符号差值,其值在 [0,RAND_MAX
-RAND_MAX
/2] & [UINT_MAX
+1-RAND_MAX
/2,UINT_MAX
-1] 而不是是有符号整数的有符号差,其值在 [-RAND_MAX
/2,RAND_MAX
-RAND_MAX
/2] 范围内。
无论如何,似乎 RAND_MAX
应该被签名并且大多数(?)编译器都这样定义它,但是是否有任何权威来源说它应该被签名?旧标准? K&R?另一个 UNIX 规范?
最佳答案
是的,这看起来像是标准中的缺陷。
首先,现在可能没有人会定义 rand()
来返回一个 int
。意图显然是返回一个正数,并且没有错误返回可以使用负数返回。如果今天引入这样的函数,它将被设计为使用无符号整数类型作为返回类型。我的猜测是它早于 C89 和无符号整数概念在该语言中的引入。
然后,很明显,人们必须期望函数返回的最大值的定义与函数之一具有相同的类型。在其他地方,宏被很好地定义为扩展到具有特定类型的表达式,所以这在这里也是可能的。
至于你的问题,我认为最简单的方法是通过执行类似 rand()/( RAND_MAX+1.0)
并从那里导出所有计算。在任何情况下,如果您的平台没有更好的伪随机生成器可用,您应该仅将 rand()
用作最后的手段。例如,在 POSIX 系统上,rand48
系列是一个方便的替代品,具有详细描述的属性。
关于c - RAND_MAX 宏 : signed or unsigned?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10708433/
我提出这个问题是因为我没有找到关于这 3 个 gpg 选项之间差异的明确解释: gpg --sign file # produces file.gpg gpg --clear-sign
以下网页介绍了将 Google 登录集成到网络应用程序中的简单工作流程: https://developers.google.com/identity/sign-in/web/sign-in 实现代码
Microsoft 最近向 Azure AD B2C 添加了新的“注册或登录”策略。 https://azure.microsoft.com/en-us/documentation/articles/
鉴于此 xml: 如何选择包含 version="@2.15"的元素?我无法弄清楚如何将 @-sign 放入 XPath。 提前致谢, 埃里克 最佳答案 此 XPath 选择所
我正在为我的网站进行 Slack 集成,包括允许用户使用“使用 Slack 登录”按钮登录。理想情况下,我希望它只要求用户授予 identity.*权限一次,然后下次当他们单击“使用 Slack 登录
在将我的第二个应用程序项目上传到 PlayStore 时,在为新版本上传 .aab 文件时出现以下错误: "Your Android App Bundle is signed with the wro
As Math.sign() 接受数字参数或数字作为字符串,如 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Gl
我已经在我的网站上实现了 Sign In with Apple。但问题是它只适用于我开发者的 Apple ID。 我尝试在同一环境中使用我的个人 Apple ID,并且登录过程也运行良好。 但是,当真
Signed Short (Signed Int16) 乘法解释? short ss = -32768; // 0x8000 SHRT_MIN ss *= (short) -1; printf ("%
class Book attr_accessor :author attr_reader :title attr_reader :comments def initialize(aut
将我面向公众的应用程序部署到 Azure。旨在将身份验证委托(delegate)给 Microsoft、Google、Facebook、Apple 等。因此,一旦用户通过其声称的身份验证并且该提供商返
好吧,我对使用 API 的理解有限 我试图掌握 Adobe Sign API 并遇到了死胡同,在测试页面上我输入了这个并且它有效 但我不知道如何在 C# 中做到这一点 我尝试了以下方法,但知道它缺
上下文 我使用 booth Cognito 用户池和 Cognito 身份池来登录用户。 我想完成一个简单的任务,让用户在 iOS 应用程序(Swift 应用程序)上登录。 我的应用程序基于自定义版本
这可能是一个非常简单的答案,但我无法在任何地方找到它。可能是我以某种方式错过了一个非常基本的 CSS 规则。 这是我的 Sass 代码: h3 { font-size: 20px; m
我见过很多将 hex 转换为 int 的问题,但这些都是 unsigned-> unsigned 的变体。如何将带符号的十六进制转换为 Int? 例如。 somefunc('0xfffff830')
我对 C# 中的准备语句有疑问: OdbcCommand cmd = sql.CreateCommand(); cmd.CommandText = "SELECT UNIQUE_ID FROM use
我想知道是否有办法在我发送授权请求之前如果用户是第一次在 Apple 注册我的应用程序,或者他/她是否已经注册,只需登录即可。 基本上我的应用程序中有一个注册屏幕,用户可以在其中创建两种类型的用户和一
我是 Rails 的新手,我正在使用“设计”gem 进行身份验证。 首先,我通过默认注册页面(例如/users/sign_up)添加一个新用户 然后,我按照从 Devise before filter
当我使用 web3.eth.sign() 方法和 web3.eth.accounts.sign() 方法对字符串进行签名时。两个签名的结果值不同。我不知道为什么这两个结果不同。 我正在使用最新的 we
我正在使用受信任的 CA 颁发的证书签署 EXE 程序。 我正在使用 Windows SDK v6.0a 中的 signtool.exe。 该证书位于计算机商店中,位于“个人”文件夹中。 我的命令行是
我是一名优秀的程序员,十分优秀!