- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当使用这个表达式时:
mem::size_of::<T>() * 8
像这样:
value % (mem::size_of::<T>() * 8);
value * (mem::size_of::<T>() * 8);
编译器能否将其优化为:
value & ((mem::size_of::<T>() * 8) - 1);
value >> LOG2_OF_EXPRESION;
是否有与 C++ 的 constexpr
等效的东西,以便我可以从函数返回它并在需要编译时表达式的地方使用它?
最佳答案
mem::size_of
现在被声明为 const
fn,这意味着它保证能够在编译时被评估。您可以在 const 上下文中使用它:
use std::mem;
const BYTES: usize = mem::size_of::<f64>();
fn main() {}
唯一确定的方法是查看 LLVM IR 或程序集。它允许随着时间的推移而改变,所以如果它非常重要,你需要自己跟踪它。
从 Rust 1.14 开始,这段代码:
#![crate_type="lib"]
use std::mem;
pub fn use_it() -> usize {
mem::size_of::<String>() * 8
}
在调试模式下编译时产生这个 LLVM IR:
; Function Attrs: norecurse nounwind readnone uwtable
define i64 @_ZN10playground6use_it17h005e773511657405E() unnamed_addr #0 {
entry-block:
ret i64 192
}
如您所见,对size_of
的调用变成了常量值192
。然后 Rust 和/或 LLVM 能够进行他们想要的任何正常优化。
我相信可以安全地假设这个 函数将始终是一个编译时常量。
Is there something equivalent to C++'s
constexpr
参见 Equivalent of constexpr from C++?
还没有。 RFC 911引入了 const
函数,可以在编译时计算的函数。诀窍在于,实际上为它应该使用的所有东西启用它是困难的,并且取决于编译器的一些内部重写。
在 nightly Rust 中,您可以执行以下操作:
#![feature(const_fn)]
const fn adder(a: usize, b: usize) -> usize {
a + b
}
const BITS: usize = adder(1, 2);
fn main() {
println!("{}", BITS);
}
关于rust - 'mem::size_of' 是否在编译时评估?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41306546/
在mutagen , 我正在注入(inject)各种代码中的突变。我想改变的一件事是模式 if let Ok(x) = y { .. } .然而,这构成了相当大的挑战,因为我不知道 y 的类型– 用户
在多处理器中,我们知道 lock inc mem :锁可以保证没有其他操作可以访问地址mem . 但是当一个处理器正在执行 mov eax,mem首先,然后在完成之前,第二个处理器执行 lock in
在通过 /metrics 端点公开的 Spring Boot 指标中,mem 和 mem.free 的含义是什么? 我们正在对部署在三个节点上的新 Spring Boot 微服务进行负载测试,每个盒子
我看了perf list的手册,找到了memory load/store的PMU事件定义: mem-loads OR cpu/mem-loads/ [Ke
Grub 是一个兼容多重引导的引导加载程序。当它启动操作系统时,它会创建一个定义可用内存的结构,并在内存中留下指向该结构的指针。 我在这里得到了这些信息: http://wiki.osdev.org/
我正在尝试实现 Wildfly 8.1.0。最终域设置,配置文件 full-ha,具有 1 个主服务器和 2 个从服务器,并通过 mod_cluster 进行负载平衡。 我的环境:1) VPS (Di
在 x86 上,如果 mem 是 32 位对齐的,那么 mov 操作保证是原子的。 如果 [mem] 不是 32 位对齐,可以 lock inc [mem]窗台工作正常吗? 工作正常:提供原子性而不是
基本上,我的问题是以下代码是否有效。 void* mem = operator new(sizeof(T)); T* instance = new(mem) T; delete instance; 如
int a[10]; int b[10]; memcmp(a, b, sizeof(int) * 10); memcmp() 只告诉我们哪个内存块更大/更小,因为它只返回 -1,0,+1。有没有一种方
fn main() { let k = "fire"; drop(k); println!("{:?}", k); } Playground 为什么删除后仍然可以使用k? dr
我有这个问题: let list = [(1,2);(2,3);(1,4);(5,0)];; List.mem (1,2) list;; - : bool = true 但是我需要修改这个函数,例如
我正在试验的问题与正确执行的 open() 或 mmap() 函数无关。我在内核中禁用了 CONFIG_STRICT_DEVMEM,所以我可以毫无问题地从 /dev/mem 中读取。实际上,我可以执行
如果我希望直接使用其他应用程序的虚拟地址访问数据,我可以使用虚拟地址访问 proc/[pid]/mem 吗?偏移量与虚拟地址相同吗? 从代码角度来看,如果我 fseeko(the-proc/[pid]
我正在开发 Raspberry PI (Linux rpi 3.12.28+),并且我有以下 C 代码,可用于操作 GPIO 端口: // IO Acces struct bcm2835_periph
我正在尝试为一个类(class)项目完成一个内存分配器的编写,这不是必要的作业,因为它没有被分配,我自己选择了这个项目。 我有两行标记为 #1 和 #2,两者都不起作用并给出不同的错误消息,以下是详细
这是我想写的代码: template class record : public record { using baseT = record; T1 elem; public: re
当使用这个表达式时: mem::size_of::() * 8 像这样: value % (mem::size_of::() * 8); value * (mem::size_of::() * 8);
我正在使用我的 Raspberry Pi,我正在编写一个 cgi python 脚本来创建一个网页来控制我的 gpio 输出引脚。当我尝试将 RPi.GPIO 导入为 GPIO 时,我的脚本崩溃了。这
我想控制对 dev/mem 的访问。 为了做到这一点,我正在考虑创建一个假的 dev/mem,以便进程访问它而不是实际的 dev/mem。 然后,我的进程将根据假进程中的更改修改 dev/mem。 这
我尝试打开/dev/mem。访问 /dev/mem 需要 root 权限才能打开该文件。 但是我无法在 super 用户中使用我的程序。所以我将/dev/mem访问权限更改为666(不要考虑安全问题!
我是一名优秀的程序员,十分优秀!