- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我经常看到与 vba 的 Overflow
错误相关的问题.
我的问题是为什么使用integer
变量声明而不是仅仅将所有数值变量(不包括double
等)定义为long
?
除非您在 for 循环中执行类似操作,可以保证该值不会超过 32,767 限制,否则是否会对性能产生影响或导致不使用 long
?
最佳答案
Integer variables are stored as 16-bit (2-byte) numbers
Long (long integer) variables are stored as signed 32-bit (4-byte) numbers
因此,好处是减少了内存空间。 Integer 占用的内存是 Long 的一半。现在,我们讨论的是 2 个字节,因此它不会对单个整数产生真正的影响,只有在处理大量整数(例如大型数组)并且内存使用至关重要时才需要考虑。
但是在32位系统上,内存使用量减半是以性能为代价的。当处理器实际使用 16 位整数执行某些计算(例如递增循环计数器)时,该值会默默地转换为临时 Long,而不会受益于更大范围的数字。溢出仍然会发生,并且处理器用于存储计算值的寄存器将占用相同数量的内存(32 位)。 Performance may even be hurt因为必须转换数据类型(在非常低的级别)。
不是我正在寻找的引用,但是......
My understanding is that the underlying VB engine converts integers to long even if its declared as an integer. Therefore a slight speed decrease can be noted. I have believed this for some time and perhaps thats also why the above statement was made, I didnt ask for reasoning.
这是我正在寻找的引用。
Short answer, in 32-bit systems 2 byte integers are converted to 4 byteLongs. There really is no other way so that respective bits correctly lineup for any form of processing. Consider the following
MsgBox Hex(-1) = Hex(65535) ' = True
Obviously -1 does not equal 65535 yet the computer is returning the correctanswer, namely"FFFF" = "FFFF"
However had we coerced the -1 to a long first we would have got the rightanswer (the 65535 being greater than 32k is automatically a long)
MsgBox Hex(-1&) = Hex(65535) ' = False
"FFFFFFFF" = "FFFF"
Generally there is no point in VBA to declare "As Integer" in modernsystems, except perhaps for some legacy API's that expect to receive anInteger.
最后我找到了msdn documentation我真的很认真地在寻找。
Traditionally, VBA programmers have used integers to hold smallnumbers, because they required less memory. In recent versions,however, VBA converts all integer values to type Long, even if they'redeclared as type Integer. So there's no longer a performance advantageto using Integer variables; in fact, Long variables may be slightlyfaster because VBA does not have to convert them.
根据评论进行澄清:整数仍然需要更少的内存来存储 - 一个大的整数数组将需要比具有相同尺寸的 Long 数组少得多的 RAM(几乎正好是一半)尽可能多,您可以在任务管理器中自行检查)。但由于处理器需要使用 32 位内存块,因此 VBA 在执行计算时暂时将整数转换为长整型
<小时/>因此,总而言之,现在几乎没有充分的理由使用 Integer
类型。 除非您需要与需要 16 位 int 的旧 API 调用进行互操作,或者您正在使用小整数的大型数组并且内存非常宝贵。除非 p>
One thing worth pointing out is that some old API functions may be expecting parameters that are 16-bit (2-byte) Integers and if you are on a 32 bit and trying to pass an Integer (that is already a 4-byte long) by reference it will not work due to difference in length of bytes.
感谢 Vba4All 指出这一点。
关于integer - 为什么使用整数而不是长整型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26409117/
我正在尝试学习 Fortran,并且看到了很多不同的定义,我想知道他们是否正在尝试完成同样的事情。以下有什么区别? 整数*4 整数(4) 整数(kind=4) 最佳答案 在 Fortran >=90
我以前从未编程过,最近(1 周前)才开始学习!第一门类(class)是函数式编程,使用 Haskell。 我有一项学校作业,我想通过删除一两个步骤来改进它,但我遇到了一个讨厌的错误。 基本上,我创建了
给定以下GraphQL请求和变量: 请求: query accounts($filter:AccountFilter, $first_:String, $skip_:Int) { accounts
我已经搜索了 StackOverflow,但找不到关于如何检查计算器应用程序的数字输入正则表达式的答案,该计算器应用程序将检查每个 keyup 的以下格式(jquery key up): 任何整数,例
类似于我上一篇致歉的文章,但没有那么长篇大论。基本上我想知道当每次重绘调用只重绘屏幕的一小部分时,优化重绘到 JFrame/JPanel 的最佳选择是什么。 此外,除了重绘重载之外,我并不是 100%
所以在我的教科书中有一个使用 f# 的递归函数的例子 let rec gcd = function | (0,n) -> n | (m,n) -> gcd(n % m,m);; 使用此功能,我的教科书
我有一个数据结构,例如表达式树或图形。我想添加一些“测量”功能,例如depth和 size . 如何最好地键入这些函数? 我认为以下三个变体的用处大致相同: depth :: Expr -> Int
这样写比较好 int primitive1 = 3, primitive2 = 4; Integer a = new Integer(primitive1); Integer b = new Inte
我是 Java 8 新手,想根据键对 Map 进行排序,然后在值内对每个列表进行排序。 我试图寻找一种 Java 8 方法来对键和值进行排序。HashMap>映射 map.entrySet().str
这就是我的目标... vector ,int> > var_name (x, pair (y),int>); 其中 x 是 vector var_name 的大小,y 是对内 vector 的大小。
这里是 an answer to "How do I instantiate a Queue object in java?" , Queue is an interface. You can't i
这个问题在这里已经有了答案: Weird Integer boxing in Java (12 个答案) Why are autoboxed Integers and .getClass() val
我们可以使用 C++ STL 做这样的事情吗?如果是,我将如何初始化元素?我试图这样做,但没有成功。 pair,vector>p; p.first[0]=2; 最佳答案 Can we do som
您好,我正在尝试为百分比和整数数组中的数字找到索引。假设 arraynum = ['10%','250','20%','500'] 并且用户发送一个值 15%,这个数字在哪个范围内居住?我可以使用这段
我与三列有关系:ProductName、CategoryID 和 Price。我需要选择仅那些价格高于给定类别中平均产品价格的产品。(例如,当apple(ProductName)是fruit(Cate
我已经坚持了一段时间,我正在尝试将一些数据配对在一起。这是我的代码。 #include #include using namespace std; int main() { pair data(
我收到错误:'(Int, Int)' 与 'CGPoint' 不相同 如何将 (Int, Int) 转换为 CGPoint let zigzag = [(100,100), (100,150)
我在 .cpp 文件中发现了以下代码。我不理解涉及头文件的构造或语法。我确实认识到这些特定的头文件与 Android NDK 相关。但是,我认为这个问题是关于 C++ 语法的一般问题。这些在某种程度上
我将这些输入到 Scala 解释器中: val a : Integer = 1; val b : Integer = a + 1; 我收到消息: :5: error: type mismatch;
C++:vector>v(size);当我试图打印出值时显示 0 作为值,但是当未声明 vector 大小时它显示正确的输出?为什么这样?例如: int x; cin>>x; vector>v(x);
我是一名优秀的程序员,十分优秀!