草庐IT

basic_person_info

全部标签

c++ - std::basic_fstream::put() 无效

我有以下代码:#include#includeintmain(intargc,char*argv[]){if(argc!=2){std::cout"stream;stream.open(argv[1],std::fstream::out);stream.put('T');stream.put('E');stream.put('S');stream.put('T');stream.flush();stream.close();return0;}正在创建文件,但当我在编辑器中打开它时,里面什么也没有。我的编译器是gccversion4.8.2(Ubuntu4.8.2-19ubuntu1)。

c# - WCF 服务应用程序 - 使用 C++ 对象调用导致 Visual Basic 6.0 DLL 文件挂起

我们目前正在移动系统以使用WCF遇到了一个我们无法弄清楚的问题。设置是有一个C#DLL文件,它包装了一个C++和一个VisualBasic6.0DLL文件。C#DLL文件对这两者都有包装器,并实例化这两个对象。C++对象被初始化(从文件中获取数据),然后传递给VisualBasic6.0对象,该对象使用C++对象中的数据运行报表。这一切都是作为WCF服务应用程序发生的,并且在大多数情况下它工作得很好,但是当VisualBasic6.0代码调用C++对象中的方法时,整个事情就会挂起。我仅使用一个调用相同C#DLL文件(在WCF之外)的简单应用程序进行了测试,它可以完美运行。所以,WCF和

c++ - 关于 std::type_info 中的反射扩展的一般感觉是什么?

我注意到反射是其他语言的开发人员发现c++非常缺乏的一项功能。对于某些应用程序,我真的明白为什么!如果你有反射,那么编写IDE的自动完成之类的东西就容易多了。当然,如果我们拥有序列化API,世界会变得更简单。另一方面,C++的主要原则之一是不要为不用的东西付费。这是完全有道理的。这是我喜欢C++的地方。但我想到可能会有妥协。为什么编译器不对std::type_info结构添加扩展?不会有运行时开销。二进制文件最终可能会更大,但这可能是一个简单的编译器开关来启用/禁用,老实说,如果您真的关心空间节省,您可能会禁用异常和RTTI。有些人提到模板存在问题,但编译器已经很高兴地为模板类型生成了

c++ - 添加多个相同类型的 boost::error_infos 到一个 boost::exception

#include#includestructmyexception:virtualboost::exception,virtualstd::exception{};typedefboost::error_infoinfo;voidmain(){try{BOOST_THROW_EXCEPTION(myexception()这将输出[structtag_info*]=2我明白为什么会这样,但宁愿让它输出[structtag_info*]=1[structtag_info*]=2我当然可以typedefinfo作为boost::error_info>然后将所有信息累积在std::vector

c++ - 为什么 basic_stringbuf 和 basic_filebuf 移动构造函数具有实现定义的行为?

来self的C++标准拷贝[§27.8.2.1p4]:basic_stringbuf(basic_stringbuf&&rhs);Effects:Moveconstructsfromthervaluerhs.Itisimplementation-definedwhetherthesequencepointersin*this(eback(),gptr(),egptr(),pbase(),pptr(),epptr())obtainthevalueswhichrhshad.Whethertheydoornot,*thisandrhsreferenceseparatebuffers(ifan

c++ - 错误:无法将 std::vector<std::basic_string<char>> 转换为 std::string*

作为C++的新手,我曾尝试在我的一个程序中创建一个简单的void函数以显示数组。但是,如标题所示,存在错误。我认为这是一个问题,因为我试图用与函数参数不同形式的数组来调用它。我不确定如何修改它。#include#includeusingnamespacestd;voiddisplay_array(stringarr[]){inti;for(i=0;ipaths;cout>current;while(current!="0"){paths.push_back(current);cin>>current;}display_array(paths);}感谢任何帮助。

c++ - ROS_INFO_STREAM 不打印

我正在尝试在叠瓦式try...catch中使用ROS_INFO_STREAM,但我只有顶级输出这是一小段代码:voidfailure(){try{//throwstd::length_errorstd::string("abc").substr(10);}catch(...){ROS_ERROR_STREAM("ROSfailure()");//printOKstd::cout输出:ROScallingROSfailure()coutfailure()coutcallfunction我的猜测是ROS_ERROR_STREAM看起来缓冲了,但作为错误输出它不应该。我正在运行ROSGroo

c++ - 'boost::exception_detail::clone_impl<boost::exception_detail::error_info_injector<boost::system::system_error>>

我创建了客户端应用程序。当我发送单个消息clientsever时它工作正常。但是当我出于性能目的发送大量消息时,客户端会以两种不同的方式崩溃:(gdb)runStartingprogram:/home/x64joxer/workerGenerators/Worker2/worker-t-i192.168.0.6-p6000-d5-l//home/x64joxer/workerGenerators/Worker2/[Threaddebuggingusinglibthread_dbenabled]Usinghostlibthread_dblibrary"/lib/x86_64-linux-

c++ - 对 Visual Basic 6 ListView 的自动化支持

我需要通过自动化接口(interface)(使用C++/C#编码)获取控件的值/文本。我试过UIAutomationAPI这是Inspect捕获的一些结果:UIAutomation将这些控件识别为pane,我无法正常获取ListView文本项或获取/设置slider值。尝试使用其他工具,如MSAA,AutomationSpy给出相同的结果。经过研究,发现类名如ListView20WndClass,Slider20WndClass,...的控件属于VisualBasic6控件。那么,有没有API也可以支持这些类型的控制呢?备注1:有一个名为Ranorex的工具可以支持这些控件(遗憾的是,

c++ - 我们能否在运行时确定两个 type_info 是否可转换?

有没有办法从两个const::std::type_info中判断对象,让我们将它们命名为B和D如果D描述的类型是从类型B派生的?我问是因为我想删除我得到的对象的类型,但稍后能够检查它是否可以安全地提升。void*data;const::std::type_info*D;templatevoidstore(D&&object){D=&typeid(object);data=::std::addressof(object);}templateB&load(){//if(typeid(B)!=(*D))throw::std::bad_cast{};return*reinterpret_cas