草庐IT

this_file

全部标签

c++ - C/C++ : header file not found

一些头文件存在于/src/dir1/中(例如:a.h、b.h、c.h等)。我的源文件存在于/src/dir2/file.cpp中.我使用了一些存在于/src/dir1/中的头文件但是在编译过程中我得到了类似headerfilenotfound的错误.然后我将包含路径更改为#include"../src/dir1/a.h",然后错误消失在file.cpp但我得到notfound/src/dir1中存在的头文件中存在错误.因为我包含了头文件说a.h,那a.h包含了一些存在于/src/dir1/中的其他头文件(比如b.h和c.h出现在a.h中)。如何在a.h中添加头文件(/src/dir2/

c++继承私有(private)复制构造函数: how doesn't this yield a compile time error?

在C++中,如果我们有这个类classUncopyable{public:Uncopyable(){}~Uncopyable(){}private:Uncopyable(constUncopyable&);Uncopyable&operator=(constUncopyable&);};然后我们有一个派生类classDervied:privateUncopyable{};我的问题是:当编译器在派生类中生成默认的复制构造函数和赋值运算符时,为什么这不会生成编译时错误?生成的代码不会尝试访问基类私有(private)成员吗? 最佳答案

c++ - fatal error LNK1104 : cannot open file "Debug/

我正在尝试在MicrosoftVisual6.0版中运行C++代码。代码编译良好,但我收到错误“fatalerrorLNK1104:当我尝试构建时无法打开文件“Debug/Assignment.exe”。该文件保存在名为Assignment的项目中。我是C++的新手,并且微软视觉的东西。我不知道从哪里开始绕过错误。请帮助。 最佳答案 听起来exe(Debug/Assignment.exe)的拷贝已经在运行,因此visualstudio无法覆盖该文件。查看任务管理器/进程资源管理器并终止所有正在运行的拷贝,然后重试。

NameNode是Hadoop Distributed File System(HDFS)中的主服务器

NameNode是HadoopDistributedFileSystem(HDFS)中的主服务器,负责管理文件系统的元数据。以下是NameNode的具体职责:文件系统的一致性维护:NameNode负责管理HDFS的元数据,包括文件系统的目录树、文件和数据块的具体信息等。它确保整个文件系统的一致性,即任何时候都能提供准确的元数据信息。数据块的映射:NameNode维护着文件和数据块的映射关系。当客户端请求读取或写入文件时,NameNode会根据需要将数据块的位置信息提供给客户端,以支持文件的读取或写入操作。文件系统的目录结构:NameNode维护着整个文件系统的目录结构,包括目录的创建、删除和修

c++ - 为什么 sizeof(this - id) 返回 8?

我的代码中有一个非常愚蠢的拼写错误...is.read((char*)&this->id,sizeof(this-id));在this-之后缺少>字符有趣的是sizeof(this-id)返回了8!我的想法是...因为this是一个指针,对this做减法将导致另一个指针被id的值关闭,它可以是任何东西取决于id的值。还有...在64位系统上,指针通常是8个字节!我说的对吗?还是遗漏了什么?下面是我的类(class)。classIndexItem:publicSerializable{public:IndexItem(uint32_tid,std::streampospos):id(id

C++ 函数名称分解 : What does this name suffix mean?

当我反汇编Chromium二进制文件时,我注意到有一些函数以这种模式命名:_ZN6webrtc15DecoderDatabase11DecoderInfoD2Ev.part.1如果我把这个字符串给c++filt,输出是webrtc::DecoderDatabase::DecoderInfo::~DecoderInfo()[克隆.part.1]那么这个.part.1后缀的真正含义是什么?如果它表明同一个函数有多个拷贝,他们为什么需要那个?是因为位置独立的要求吗?我使用g++作为编译器。 最佳答案 它表示析构函数是partialinli

c++ - Lambda 的 "this"捕获返回垃圾

我正在实现我自己的类,该类提供其成员的惰性初始化。而且我遇到了在lambda中捕获this的奇怪行为。这是一个重现此错误的示例。//Baz.h#include#include#include"Lazy.hpp"structFoo{std::stringstr;Foo()=default;Foo(std::stringstr):str(str){}Foo(Foo&&that):str(that.str){}};classBaz{std::stringstr;Lazy>foo;public:Baz()=default;Baz(conststd::string&str):str(str){/

c++ - 从自身内部替换 std::function(通过 move 赋值到 *this?)

是否可以用另一个std::function替换一个std::function?以下代码无法编译:#include#includeintmain(){std::functionfunc=[](){std::cout可以修改编译吗?现在的错误消息是:'this'wasnotcapturedforthislambdafunction-我完全理解。但是,我不知道如何捕获func的this指针。我想,它甚至不是lambda中的std::function吧?!如何做到这一点?背景:我想要实现的是:在给定std::function的第一次调用中,我想做一些初始化工作然后替换具有优化功能的原始功能。我

c++ - 将从唯一指针移动到共享指针也会初始化 enable_shared_from_this

当我继承std::enable_shared_from_this,但是我创建了一个unique_ptr,std::enable_shared_from_this里面的weak_ptr也会被初始化吗当我通过std::move或移动构造函数“移动”到shared_ptr时?例如下面的代码会发生什么:#include#includeclassA:publicstd::enable_shared_from_this{public:std::shared_ptrgetA(){returnshared_from_this();}};intmain(){std::unique_ptru(newA()

c++ - std::reference_wrapper *this 周围

我有一个场景,我需要转换一个可以被*this链接的函数返回std::optional>而不是T&(原因超出了这个问题的范围)。我使用std::reference_wrapper的原因是因为std::optional不能引用,至少在C++11中不能。但是,这不起作用,因为我似乎遇到了终身问题。这是一个最小的例子:#include#includestructtest{std::reference_wrapperfoo(){val=42;return*this;}test&foo2(){val=50;return*this;}intval;};voidbar(testt){std::cout