草庐IT

system_foo

全部标签

c++ - 错误 : jump to label 'foo' crosses initialization of 'bar'

以下C++示例无法使用gcc或clang进行编译,但仅使用ICC生成警告,而使用MSVC则完全不生成任何警告:intmain(intargc,char*argv[]){if(argcg++:init.cpp:13:error:jumptolabel‘clean_up’init.cpp:4:error:fromhereinit.cpp:7:error:crossesinitializationof‘inti’clang++:init.cpp:4:9:error:cannotjumpfromthisgotostatementtoitslabelgotoclean_up;^init.cpp:

c++ - 为什么 std::chrono::system_clock::to_time_t() 不是 constexpr?

C++标准(github.com/cplusplus/draft)有time_t转换函数(std::chrono::system_clock::to_time_t和std::chrono::system_clock::from_time_t)用于列为static和noexcept但不是constexpr。鉴于time_point和duration上的所有操作基本上都是constexpr(包括duration_cast和time_point_cast),我想不出任何理由来排除它们。在我的本地机器上快速检查libstdc++源代码确认这些函数是作为简单的持续时间/时间点转换实现的。这两个函

C++:可以将 "try { foo(); } catch (...) { throw; }"优化为 "foo();"吗?

在C++中,是如下代码try{foo();}catch(...){throw;}在语义上等同于像这样调用foo吗?foo();如果是这样,我是否可以期望最先进的编译器避免第一个版本到第二个版本(在启用优化的情况下编译时)?换句话说,如果我使用NDEBUG编译这段代码并启用优化try{foo();}catch(...){assert(some_check());throw;}我可以假设这个丑陋的版本永远不会慢吗#ifndefNDEBUGtry{#endiffoo();#ifndefNDEBUG}catch(...){assert(some_check());throw;}#endif

C++11(或 Boost)system_error 策略

我正在开发一个系统,该系统旨在使用名为error_code、error_condition和error_category的类——一个新的方案std:在C++11中,尽管目前我实际上正在使用Boost实现。我读过ChrisKholkoff的seriesofarticles,现在三遍了,我想我了解了如何创建这些类。我的问题是这个系统需要处理存在于单个DLL中的插件,而插件可能会出错。我最初的设计是计划一个特定于系统的错误类别,该类别将包含所有各种错误代码和未真正映射到errno值的特定错误条件的候选列表。这里的问题是,要使DLL能够使用这些错误代码之一,它需要访问应用程序中error_ca

c++ - 如何在不抛出的情况下构造 <stdexcept> 或 <system_error> 异常?

中定义的异常(例如std::logic_error、std::runtime_error及其子类,例如std::system_error)具有需要字符串参数的构造函数,例如:domain_error(conststring&what_arg);domain_error(constchar*what_arg);有后置条件strcmp(what(),what_arg.c_str())==0strcmp(what(),what_arg)==0分别。没有要求传递给构造函数的这些参数在这些异常的生命周期内保持有效,因此确保后置条件成立的唯一方法是复制并存储这些动态字符串。这需要内存,所以我假设他

c++ - 我可以使用 foo<T..., int, U...> 这样的模式部分特化模板吗?

如果可能的话,可以在不递归的情况下索引可变参数模板参数包。但是,GCC是refusingtopickupmypartialspecialization这里:templatestructelement_impl;templatestructelement_impl...,pair,pair...>>{typedefTtype;};prog.cpp:Ininstantiationof'element>':prog.cpp:52:34:instantiatedfromhereprog.cpp:47:79:error:invaliduseofincompletetype'structeleme

c++ - std::vector<Foo> 当 Foo 的一些成员是引用时

只要有可能,我通常更喜欢使用引用而不是指针,在我看来,它使语法更清晰。在这种情况下,我有一个类:classFoo{public:Foo(Bar&bar):bar_(bar){}private:Bar&bar_;};operator=()被编译器隐含地删除了这样一个类,因为一旦设置了引用,它就不能改变(我可以在技术上定义我自己的不改变bar_,但这不是必需的行为,所以我宁愿如果我尝试分配一个foo,编译器会提示)。我需要的是std::vectorv;.这在C++11之前是不可能的,因为模板参数必须是CopyAssignable。事实上,当我调用v.push_back(Foo(bar));

C++ std::system_error 与 common catch std::exception block 的用法

std::system_error处理带有相关错误代码的异常。是否可以使用公共(public)catchblock来获取std::system_error异常消息及其代码?像这样try{//codegeneratingexception}catch(conststd::exception&ex){//catchallstd::exceptionbasedexceptionslogger.log()唯一的方法是直接捕获std::system_error类型并在捕获基本异常类型之前获取其代码吗?广泛使用std::system_error的最佳方法是什么? 最佳答

c++ - 如何在 C/C++ 中捕获 system() 的结果

这个问题在这里已经有了答案:关闭12年前。PossibleDuplicate:HowcanIrunanexternalprogramfromCandparseitsoutput?你好,有人可以告诉我们如何在执行system()函数时捕获结果吗?实际上,我写了一个显示机器IP地址的c++程序,称为“ipdisp”,我希望当服务器程序执行此ipdisp程序时,服务器捕获显示的IP地址。那么,这可能吗?如果是,怎么办?感谢您的回复

Ubuntu扩容报错:Unable to resize read-only file system /dev/sda3

当我们给Ubuntu新划分了空间,但是去给磁盘划分的时候,会报错:Unable to resize read-only file system /dev[sda3The file system can not be resized while it is mounted read-only.Either unmount the file system or remount it read-write.这是因为磁盘没有挂载起来,因此需要查看该磁盘的挂载路径,首先右键/dev/sda3点击信息,进去后就可以看到挂载的路径,分别是/和/var/snap/firefox/common/host-hun