草庐IT

EXC_Bad_ACCESS

全部标签

c++ - 为什么 shared_ptr 可以访问 ingoring "protected access right"

我用shared_ptr做了一些测试,我想不出下面的问题。我刚开始学习boost库。有谁能告诉我原因吗?#include#includeclassA{public:virtualvoidsing(){std::coutpa(newB());pa->sing();deletestatic_cast(pa.get());deletepa.get();//thislinehasaproblemerrorC2248:“A::~A”:can'taccessprotectedmemmber(declaredinclass“A")return0;}intmain(){foo();return0;}但

c++ - Visual C++ 2010 拒绝在调试时显示 std::string 值。显示 <Bad Ptr>

我有一种奇怪的感觉,好像这是最近才出现的问题,并且发生在两台不同的计算机上。当我调试并尝试查看来自STL的std::string的值时,它显示为值。它说它的大小是15,容量是一些乱码。数组值本身都显示CXX0030:错误:无法计算表达式。这非常令人沮丧,如果我在字符串上调用c_str并将其分配给char*或在需要时使用监视表达式,我仍然可以在调试时访问字符串值,但它非常乏味并且让生活变得非常艰难连续3天调试复杂问题。其他STL容器的内容显示得很好。这发生在两台不同计算机上的多个项目上,我很确定我已经为该项目设置了所有调试选项。没有优化,肯定会生成调试信息。

c++ - 使用 -fno-access-control 进行单元测试

我见过很多在单元测试时访问私有(private)变量的疯狂方法。我见过的最令人兴奋的是#defineprivatepublic。但是,我从未见过有人建议在编译器级别关闭私有(private)变量。我一直以为你做不到。我曾向许多开发人员提示说,如果您可以只告诉编译器为这个文件后退,单元测试会容易得多。然后我偶然发现了-fno-access-controlGCC编译器选项。这显然是单元测试的完美方式。你的原始源文件没有被修改,没有注入(inject)friend只是为了单元测试,没有用奇怪的预处理器魔法重新编译。编译单元测试时,只需轻按“无访问控制”开关即可。我错过了什么吗?这是我希望的单

c++ - 如何调试 std::bad_cast 异常

classGAGenome{virtualvoidmethod(){};};templateclassGAArray{};templateclassGA1DArrayGenome:publicGAArray,publicGAGenome{};intmain(){GA1DArrayGenomegenome;constGAGenome&reference=genome;autocast=dynamic_cast&>(reference);}这个明显错误的程序(因为模板参数不同)崩溃了terminatecalledafterthrowinganinstanceof'std::bad_cast

Git报错解决_fatal: unable to access ‘https://github.com: Recv failure: Connection was reset

报错fatal:unabletoaccess'https://github.com:Recvfailure:Connectionwasreset致命:无法访问https://github.com:接收失败:连接被重置产生情况向GithubPush时解决办法关掉系统代理找到系统代理关闭系统代理产生的原因因为开启了代理导致无法正常连接到Github小结使用系统代理可能导致Github内容推送失败

c++ - XP : Is turning off "last access time" safe? 上的文件

我正在拼命寻找廉价的方法来缩短我家用PC上的构建时间。我刚读了一个articleaboutdisablingtheLastAccessTimeattributeWindowsXP上的文件,因此简单的读取不会将任何内容写回磁盘。It'sreallysimpletoo.AtaDOS-promptwrite:fsutilbehaviorsetdisablelastaccess1有没有人在构建C++项目的环境中尝试过它?有什么缺点吗?[编辑]有关主题的更多信息here. 最佳答案 来自SetFileTime'sdocumentation:“

c++ - 避免 std::bad_alloc。 new 应该返回一个 NULL 指针

我将一个中型应用程序从C移植到C++。它不会在任何地方处理异常,这一点不应该改变。我(错误!)对C++的理解是(直到我昨天艰难地学习它)(默认)new运算符在出现分配问题时返回NULL指针。然而,直到1993年(左右)才出现这种情况。现在,它抛出一个std::bad_alloc异常。是否可以在不重写所有内容以在每次调用时使用std::nothrow的情况下返回到旧行为? 最佳答案 你可以重载operatornew:#includevoid*operatornew(size_tpAmount)//throw(std::bad_allo

c++ - boost 共享指针 : Simultaneous Read Access Across Multiple Threads

我有一个线程A,它分配内存并将其分配给一个共享指针。然后该线程生成另外3个线程X、Y和Z,并将共享指针的拷贝传递给每个线程。当X、Y和Z超出范围时,内存将被释放。但是是否有可能2个线程X、Y在完全相同的时间点超出范围并且引用计数存在竞争条件,因此它不会将其递减2,而只会递减一次。所以,现在引用计数newer下降到0,所以存在内存泄漏。请注意,X、Y和Z仅读取内存。不写入或重置共享指针。长话短说,引用计数是否存在竞争条件,这会导致内存泄漏吗? 最佳答案 boost::shared_ptr使用锁(或无锁原子访问)来确保引用计数以原子方式

【ARMv8M Cortex-M33 系列 7.3 -- EXC_RETURN 与 LR 及 PC 的关系详细介绍】

请阅读【嵌入式开发学习必备专栏之ARMCortex-Mx专栏】文章目录背景EXC_RETURN与LR及PCcortex-m33从异常返回后各个寄存器出战顺序ARM栈增长方式背景接着上篇文章:【ARMv8MCortex-M33系列7.2–HardFault问题定位1】,后面定位到是在cortex-m33/context_gcc.S执行完BXLr之后就发生了HardFault,通过JLink发现LR的值为0xfffffffd所以又继续调查了EXC_RETURN的具体含义。pendsv_exit:/*restoreinterrupt*/MSRPRIMASK,r2ORRlr,lr,#0x04BXlrE

c++ - string::iterator 一定是 random_access_iterator 吗?

This页面声明string::iterator和string::const_iterator是“编译器特定的迭代器类型”。这是否意味着string::iterator属于random_access_iterator以外的类别? 最佳答案 ISOC++03,21.3-2声明:(...)Additionally,becausetheiteratorssupportedbybasic_stringarerandomaccessiterators(...)是的,这些必然是随机访问迭代器。 关于