在使用.hpp/.cpp模板创建新类时,是否有可能(以及如何)在Eclipse CDT中自动生成的包含保护的名称中添加命名空间?
对我来说,Eclipse很好地生成了一个带有命名空间的新类,但是包含保护不包含命名空间,因此如果相同的头文件在两个不同的目录中存在两次,则只能包含一个.
在我的例子中,命名空间的名称,Eclipse项目名称和源目录的名称都是相同的,因此这些可以作为include guard的前缀.
请注意,我不想用我的问题解决任何问题 - 我正在考虑事情发生的可能性,因此想知道一些事情:
如果你删除对象并使用gcc作为编译器会发生什么?
上周我正在调查一次撞车事故,其中一场竞赛条件导致双重删除一个物体.
调用对象的虚析构函数时发生崩溃,因为已经覆盖了指向虚函数表的指针.
虚拟函数指针是否被第一次删除覆盖?
如果没有,那么第二次删除是否安全,只要在此期间没有进行新的内存分配?
我想知道为什么我之前没有识别出的问题,唯一的例外是虚拟功能表在第一次删除时立即被覆盖,或者第二次删除不会崩溃.
(第一个意味着如果发生"竞赛",崩溃总是发生在同一个位置 - 第二个,通常在竞赛发生时没有发生 - 并且只有在第三个线程覆盖删除对象的同时才会出现问题. )
编辑/更新:
我做了一个测试,下面的代码崩溃了一个segfault(gcc 4.4,i686和amd64):
class M
{
private:
int* ptr;
public:
M() {
ptr = new int[1];
}
virtual ~M() {delete ptr;}
};
int main(int argc, char** argv)
{
M* ptr = new M();
delete ptr;
delete ptr;
}
Run Code Online (Sandbox Code Playgroud)
如果我从dtor中删除'virtual',程序将被glibc中止,因为它检测到双重释放.使用'virtual'时,在对析构函数执行间接函数调用时会发生崩溃,因为指向虚函数表的指针无效.
在amd64和i686上,指针指向一个有效的内存区域(堆),但是那里的值是无效的(一个计数器?它非常低,例如0x11或0x21)所以'call'(或编译时为'jmp')做了返回优化)跳转到无效区域.
程序收到信号SIGSEGV,
分段故障.0x0000000000000021
在??? ()(gdb)
#0 0x0000000000000021?()
#main()中的1 0x000000000040083e
因此,在上述条件下,指向虚函数表的指针总是被第一次删除覆盖,因此如果该类具有虚拟析构函数,则下一次删除将跳转到必杀技.
有没有人有任何想法可能导致这一点.
我赢了7.我已经使用本教程成功设置了所有内容:
http://www.kgx.net.nz/2010/03/cygwin-sshd-and-windows-7/
我完成了这个命令:
SSH-主机配置
..但我收到标题中的错误.我搜索了谷歌和许多其他地方.我找不到有这个问题的人的一个实例.
有任何想法吗?
我需要使用 Eclipse (gdb) 在 Linux 上调试程序。该程序以 root 身份运行并且相当大。带有调试符号的二进制文件大约有250MB大,启动后有超过60个正在运行的线程。
我正在考虑最好的解决方案:
我认为第 1 号(gdbserver)将是最好的解决方案,不幸的是它工作不可靠。gdb 和 gdbserver 之间的连接丢失。我认为eclipse <-> gdb <-> gdbserver之间传输的大量数据存在问题。
数字 2(以 root 身份运行 eclipse)意味着以 root 身份运行每个进程,因此也会干扰版本控制系统,因为 Eclipse 插件将使用 root 用户而不是我的用户来更改版本控制文件。
我没有尝试第三个(suid gdb)。你怎么看待这件事?它到底有用吗?我知道 suid root gdb 和没有 root 密码一样安全,但该机器仅供我用于开发和调试。当然,可能有一个“启用/禁用”脚本,仅在必要时设置 suid 位。
你有什么其他的建议?
c++ ×2
eclipse ×2
eclipse-cdt ×2
c ×1
cygwin ×1
gcc ×1
gdb ×1
gold-linker ×1
linker ×1
linux ×1
migration ×1
namespaces ×1
openssh ×1
probability ×1
suid ×1
windows-7 ×1