- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
函数std::mem::drop
在 Rust 中 move 它的参数,然后通过超出范围来销毁它。我在 C++ 中编写类似函数的尝试如下所示:
template <typename T,
typename = std::enable_if_t<std::is_rvalue_reference<T &&>::value>>
void drop(T &&x) {
T(std::move(x));
}
标准库中是否已经存在这样的函数?
编辑:该函数可用于在超出范围之前调用对象的析构函数。考虑一个类,它在文件句柄被销毁后立即关闭,但不会更早。为了论证,假设 ofstream
没有 close
方法。你可以这样写:
ofstream f("out");
f << "first\n";
drop(move(f));
// f is closed now, and everything is flushed to disk
最佳答案
C++的标准库没有这样的函数。但是,您可以使用此成语实现相同的效果:
SomeType var = ...;
//do stuff with `var`.
{auto _ = std::move(var);}
//The contents of `var` have been destroyed.
正如评论中所指出的,C++ 缺乏 Rust 的实际阻止您进一步使用 var
的能力。它的内容已被移出,但在 C++ 中它仍然是一个事件的、有效的对象,您甚至可以通过将其适本地转换为定义明确的状态来重用它。
当然,这要求类型是可 move 构造的。一些像 lock_guard
这样的类型不是,所以你有点受不了了。这意味着提前关闭它的唯一方法是使用其内置界面。
关于c++ - 标准库中是否有与 Rust 的 `std::mem::drop` 等效的 C++?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45362132/
在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(不要考虑安全问题!
我是一名优秀的程序员,十分优秀!