草庐IT

try-convert

全部标签

C++11 在不使用 try/catch block 的情况下安全地加入线程

根据文档here和here,如果joinable()==false,C++11线程的join方法将抛出std::system_error。因此,等待线程完成执行的自然方式是:if(thread2.joinable())thread2.join();但是,这有可能抛出std::system_error。考虑线程1调用thread2.joinable(),返回true,说明thread2还在运行。然后调度程序暂停线程1并将上下文切换到线程2。线程2完成,然后线程1恢复。线程1调用thread2.join(),但线程2已经完成,因此抛出std::system_error。一个可能的解决方案是

c++ - 如何使用 lock_guard 和 try_lock_for

我可以使用boost::lock_guard获取boost::mutex对象上的锁,并且此机制将确定一旦boost::lock_guard超出范围将释放锁:{boost::lock_guardlock(a_mutex);//Dothework}在这种情况下,无论代码块是否因异常退出,a_mutex都会被释放。另一方面,boost::timed_mutex也支持方法try_lock_for(period),例如if(a_timed_mutex.try_lock_for(boost::chrono::seconds(1))){//Dotheworka_timed_mutex.unlock(

c++ - 函数 try block 的目的是什么?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Whenisafunctiontryblockuseful?Differencebetweentry-catchsyntaxforfunction这段代码在UseResources类中构造Dog对象时抛出一个int异常。int异常被普通的try-catchblock捕获,代码输出:Cat()Dog()~Cat()Insidehandler#includeusingnamespacestd;classCat{public:Cat(){cout现在,如果我们将UseResources()构造函数的定义替换为使用f

c++ - 为什么 std::multimap 没有实现 try_emplace?

C++17引入了try_emplacestd::map的方法,所以现在我可以编写如下代码:structTest{Test(inti,intj){}};std::maptmap;tmap.try_emplace(10,10,10);但是没有try_emplace对于std::multimap,所以piecewise_construct仍然需要。这有技术原因吗? 最佳答案 isthereatechnicalreasonforthis?是的。try_emplace()的目的是如果键已经存在于映射中则不执行任何操作。但是对于std::{un

c++ - 我如何使用 try...catch 来捕获浮点错误?

我在visualstudioexpress中使用c++生成随机表达式树,用于遗传算法类型的程序。因为它们是随机的,树经常产生:被零除、溢出、下溢以及返回“inf”和其他字符串。我可以为字符串编写处理程序,但文献让我对其他人感到困惑。如果我理解正确,我必须先设置一些标志?建议和/或指向一些文献的指针将不胜感激。编辑:double变量中返回的值为1.#INF或-1.#IND。我把它们称为字符串是错误的。 最佳答案 根据http://msdn.microsoft.com/en-us/library/aa289157%28v=vs.71%2

c++ - std::timed_mutex::try_lock* 虚假地失败

try_lock*是指try_lock()、try_lock_for()和try_lock_until()。根据cppreference,这三种方法都可能会虚假地失败。以下引用自try_lock_for()的描述Aswithtry_lock(),thisfunctionisallowedtofailspuriouslyandreturnfalseevenifthemutexwasnotlockedbyanyotherthreadatsomepointduringtimeout_duration.我知道std::condition_variable可能会发生虚假唤醒及其背后的基本原理。但

c++ - main() 函数中的 try\catch block 没有括号

VisualStudio2015;C++语言。我记得我在某处读到有关入口点(即main方法)的内容,可以这样写:#includeusingnamespacestd;intmain()try{return0;//Iamhere...}catch(...){cout即在这种情况下,try\catchblock不在括号中:intmain(){//startbrackettry{return0;}catch(...){return1;}}//endbracket这两种情况都已成功编译并且也可以正常工作,但是......在第一个变体中,当我在tryblock之后逐步按下F10键时,我也进入cat

try 中变量的 C++ 作用域

考虑这段代码:try{constAsdf&a=map1.at(index1);constBsdf&b=map2.at(index2);}catch(std::out_of_range&){returnfalse;}//std::cout使用a和b。我有两个选择:输入在tryblock中在tryblock中获取指针,然后取消引用它们第一个选项是错误的,因为如果抛出std::out_of_range该函数将返回false,这应该只在map查找失败时发生。第二个选项可能有点难看:constAsdf*a;constBsdf*b;try{a=&map1.at(index1);//What?b=&

windows - 在 Windows 8.1 : Trying to override Windows/System32/find. exe 上为 CMD 设置系统路径

我试图覆盖windowsfind命令,以便我可以调用find的另一个实现。另一个实现由MSYS提供,位于C:\MinGW\msys\1.0\bin。在Windows7上,我可以打开一个CMD,然后运行:SETPATH=C:\MinGW\msys\1.0\bin;%PATH%由于在C:\Windows\System32\路径之前添加了MSYS路径前缀,因此当在Windows7上的CMD中调用find时,将执行MSYS版本。该命令不适用于Windows8.1。当我在Windows8.1的CMD中调用find时,无论我做什么,它都默认为Windows实现。有没有办法在Windows8.1上覆

windows - 命令行 : "-" converted to "û"

我在.bat或.cmd文件中运行此命令以启动ftp脚本:ftp–v–i–s:test_script.txt命令窗口将其转换为:ftpûvûiûs:test_script.txt因此它不起作用。注意:如果我从cmd窗口手动运行上述命令,它工作正常。仅当我将其作为.bat或.cmd文件启动时才会失败。需要帮助防止转化。谢谢。 最佳答案 您提供的命令中的破折号是ASCII150,但切换到命令时使用的破折号是ASCII45。我猜您是从Word文档或电子邮件中复制/粘贴此命令的,其中编辑器“有帮助”将破折号更改为破折号。如果您将此问题中的命令