- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
OpenBSD 的 C 库有一个名为 reallocarray(3) 的扩展名哪个realloc(array, size*nmemb)
如果乘法溢出而不会爆炸。 The implementation包含此片段:
/*
* This is sqrt(SIZE_MAX+1), as s1*s2 <= SIZE_MAX
* if both s1 < MUL_NO_OVERFLOW and s2 < MUL_NO_OVERFLOW
*/
#define MUL_NO_OVERFLOW (1UL << (sizeof(size_t) * 4))
Over on Programmers.SE该计算的修改版本因技术错误而受到影响。 4
显然应该是 CHAR_BIT/2
,但这不是唯一的问题。假设一个不寻常的 ABI,其中 size_t
有填充位。 (这并非难以置信:考虑一个具有 32 位寄存器但具有 24 位地址空间的微 Controller 。)那么 SIZE_MAX
小于 1 << (sizeof(size_t)*CHAR_BIT)
[无限精度算术] 计算错误。
所以,问题:你能计算出floor(sqrt(SIZE_MAX+1))
吗?仅使用 C99 整数常量表达式算法,不对 ABI 做任何假设,除了 C99 要求的内容以及您可以从中学到的内容 <limits.h>
?注意 SIZE_MAX
可能等于 UINTMAX_MAX
,即可能没有任何类型可以表示 SIZE_MAX+1
没有溢出。
编辑:我认为 SIZE_MAX
对于某个正整数 n 要求为 2n − 1,但不一定必须是 22n − 1 — 考虑 S/390,其中一个 ABI 具有 31 位地址空间。因此:如果sqrt(SIZE_MAX+1)
不是整数,则所需结果(给定此常量的使用方式)为 floor()
的真实值(value)。
最佳答案
常量 SIZE_MAX
是非负的,类型为 size_t
.为简短起见,我将定义:
#define S SIZE_MAX
数学值S+1
正如您所指出的,超出或可能超出任何整数类型的范围。
我会写 S1
对于 S+1
的数学值.
如果我们考虑 S1
的对数(如果需要,以 2 为底) ,那么我们有:
logarithm(sqrt(S1)) == (1.0/2.0) logarithm(S1)
另一方面,在几乎可以肯定的每种现实情况下,我们都会有 S
表示为只有 1
的二进制数位。编号b
通常,这些位的数量是 CHAR_BIT
乘以 2 的幂,乘以 CHAR_BIT:16、32、64、128...我将用 p
表示该幂的指数.因此,对于 CHAR_BIT == 8,我们有:
16 == CHAR_BIT * 2 ----> p == 1
32 == CHAR_BIT * 4 ----> p == 2
64 == CHAR_BIT * 8 ----> p == 3
现在我们有:
logarithm(S1) == b == CHAR_BIT * (2 ** p) (I am denoting with ** to the "power math. operator").
logarithm(sqrt(S1)) == logaritm(S1) / 2.0 == CHAR_BIT * (2 ** p) / 2.0 == CHAR_BIT * (2 ** (p - 1))
通过假设或知道 size_t
中的每一位仅用于表示整数的位,我们有这个等式,对于 p
的一些(未知)值:
sizeof(size_t) == b == CHAR_BIT * (2 ** p)
我们可以假设,对于 2014 年的最先进技术,p <= 5
的值,说(你可以在下面将这个神奇的数字 5 增加到更大的值)。
现在,考虑以下表达式,旨在“搜索并找到”b
的值,假设p <= 5
:
#define S_1 ((size_t)1ULL)
#define b (sizeof(size_t))
#define bitexpr(p) ((size_t)(CHAR_BIT * (S_1 << (p))))
#define expr(p) ((size_t) (S_1 << (p)))
#define exp2_expr_1(p) ((size_t)(S_1 << bitexpr(p-1)))
// SRSM() stands for: Square Root SizeMax
#define SRSM ( \
(expr(1)==b)? exp2_expr_1(1) : \
(expr(2)==b)? exp2_expr_1(2) : \
(expr(3)==b)? exp2_expr_1(3) : \
(expr(4)==b)? exp2_expr_1(4) : \
(expr(5)==b)? exp2_expr_1(5) : \
(size_t)0 /* Error! */ \
) /* end-of-macro*/
宏SRSM
实际上,带来了 S+1
的平方根,但我想你可以弄清楚如何处理这个数字。
这里重要的是 SIZE_MAX
的平方根可以通过使用纯整数常量表达式 获得。
如果你愿意,“神奇”的数字 5 可以换成另一个。
一种更通用的方法,旨在解决任意情况,在任何符合标准的可能机器上,它会更复杂。
这篇文章中使用的方法与具有 CHAR_BIT
的值无关, 但它使用字节数是 2 的幂。
已编辑:我稍微更改了“搜索”的方法,从 1 开始,然后逐渐增加,以避免与 <<
可能出现的“错误”匹配。运算符和大数字(一个人永远不知道...)。现在,第一场比赛肯定是正确的。
关于仅使用整数常量表达式计算 sqrt(SIZE_MAX+1),以适应奇怪的 ABI,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25625096/
我试图为此搜索答案,但我发现很难找到这种“确切”的例子。我对指向指针的指针知之甚少,我觉得除了指向某物的指针之外,还有更多东西隐藏在它的表层之下。 那么你们会如何翻译呢? void free(sham
我有一个类的属性,比如const CFoo &bar() const,这是什么意思? 最佳答案 bar 方法返回对 const CFoo 的引用(即 bar 之前的 const CFoo & 部分),
例如是 int const x = 3; 有效代码? 如果是的话,意思是一样的 const int x = 3; ? 最佳答案 它们都是有效的代码并且它们都是等价的。对于指针类型,尽管它们都是有效代码
我知道 f(const T& obj) // (1) g(T const& obj) // (2) 是一样的。(我们不能改变f和g中obj的值)。 但是什么 h(T & const) // (3) 真
本节讲解的内容 include和include_once require和require_once 常量 引入文件和常量结合案列 变量操作函数 输出语句 前言 在上篇文章中,我们讨论了函数的应用,但是
我们知道我们可以保护变量的值,因此用户无法更改现有变量的值!这对对象来说没有什么问题吗?? 例如.. const x = 5; x = 10; alert(x) // will be returned
我正准备为 CUDA 设备编写直方图内核。它基于 NVIDIA's paper . 这个想法是每个线程计算某个部分(在我的例子中是体积)的部分直方图并将其写入共享内存块。然而,我遇到了一个奇怪的算法问
常量是固定值,程序执行期间不会改变。常量可以是任何基本数据类型,比如整数常量、浮点常量、字符常量或者字符串常量,还有枚举常量。 常量可以被当作常规的变量,只是它们的值在定义后不能被修改。 整数常
在这种情况下,如何识别是否有变量或字面量传递给函数 f()? 如何实现passed_as_constant()检查(见下面代码)? sub f { my $refStr=\$_[0]; ret
我目前想知道如何在 python 中列出 win32com 中的常量, 例如使用 excel win32com.client.Dispatch('Excel.Application') 有没有办法使用
这个问题在这里已经有了答案: PHP | define() vs. const (9 个回答) 关闭8年前。 在 PHP 中遇到常量问题想知道是否有人可以解释: 这行得通 const _ROOT =
我正在学习 Rust,到目前为止,似乎有 3 种声明变量的方法: const A: u8 = 42; static A: u8 = 42; let A: u8 = 42; 我知道你不能有一个可变的 c
我正在使用函数模板 void _createAttr(T)(args..., in T[]) 并使用 测试 T 的类型函数中的 static if(is(T == char)) 。当我打电话时, _c
这可能是一个天真的问题,我怀疑答案是"is",但我没有运气在这里和其他地方搜索“erlang编译器优化常量”等术语。无论如何,erlang 编译器是否可以(将)在编译时创建一个常量或文字的数据结构,并
我刚遇到这段 Java 脚本代码: const { myKey, uname, issorted, title, hClick, } = this.props; 请告诉我这是什么意
我正在努力实现以下目标: 我有一个父类,有一些逻辑。在子类中,我“重新定义”常量/属性。有没有办法让子属性可以通过父类中定义的方法访问?或者更具体地说 - 有什么方法可以强制“out”方法在下面的示例
如果这是个愚蠢的问题,请原谅。 我有一个带有内部类接口(interface)的“fragment ”外部类。该接口(interface)仅由另一个 Activity 类使用“implements Ou
我是 python 新手,尝试使用默认值并为类实例自定义它们。 因此,在这个示例中,我定义了一个 DEFAULT_STRING 和一个 DEFAULT_SETTINGS 变量,可以使用 customi
在 integer.xml 中,其形式为 0x001 0x002 是代码和 xml 文件都需要的存储常量。 C# 识别 Droid.Resource.Integer.foo,但它有一些大的
是否有跨平台(即跨 Linux、BSD 和 OS X,最好是所有 POSIX)我可以纯粹基于字符串 以编程方式访问诸如 O_RDWR 之类的常量>“O_RDWR”?我正在编写一些(非 C)代码,这些代
我是一名优秀的程序员,十分优秀!