草庐IT

buffer_size

全部标签

c++ - 从重定向的 STDOUT 读取 Unicode(C++、Win32 API、Qt)

我有一个动态加载插件DLL的C++应用程序。DLL通过std::cout和std::wcout发送文本输出。基于Qt的UI必须抓取DLL的所有文本输出并显示它。由于运行时库的差异,DLL可能具有不同的cout/wcout实例,因此使用流缓冲区替换的方法并不完全有效。因此,我应用了Windows特定的STDOUT重定向,如下所示:StreamReader::StreamReader(QObject*parent):QThread(parent){//void}voidStreamReader::cleanUp(){//restorestdoutSetStdHandle(STD_OUTPU

c++ - "size_t"作为类型参数,未重现转换警告

我一直在尝试消除一些旧代码中的警告(必须使用MSVC2005,目前使用32位构建),但一直在努力消除size_t至unsignedint转换警告。我们有自己的Array实现一个不断增长的数组的实现templateconstT&at(constIi)const{returnatImpl(i);}方法。当调用为size_ti=10;myArray.at(i);我得到一个conversionfrom'size_t'to'constunsignedint',possiblelossofdata警告。一个工作理论是I理解为unsignedint,这导致编译器强制转换/转换size_t至unsig

C++ 谷歌 Protocol Buffer 。 RPC怎么来的?

我已经按照谷歌RPC上的3个教程尝试了3个不同的来源。而且总是同样的问题。我无法让它工作。我现在非常接近,我正在使用protoserv.我现在遇到的问题是在他们的教程中说:intmain(intargc,char*argv[]){EchoServiceImplecho_service;RpcManagerrpcman;...我找不到如何访问RpcManager及其位置。我对protobuf和protoserv目录进行了grep,但无济于事。只有RpcManager位于.java包中。也许它只是一个不受支持的版本,即使它有C++中的示例。如有任何帮助,我们将不胜感激。即使链接到稳定/简单

java - Google Protocol Buffer 和 UTF-16

我有一个以UTF-16格式存储数据的应用程序(主要是因为中文/Big-5字符)。它使用GoogleProtocolBuffers作为请求/响应协议(protocol)。我知道您不能以字符串格式发回UTF-16数据。我试图通过协议(protocol)以字节数据类型发回数据,并让客户端读取字节数据并创建一个UTF-16字符串。这是最好的方法吗?有没有人遇到过这样的事情?有没有一种方法可以使用字符串数据类型将UTF-8数据转换为UTF-16? 最佳答案 如果您已经拥有一个有效的UTF-8字符串,为什么不尝试string=newString

c++ - 在使用 gdb 检查核心转储时,有没有办法运行函数(如 std::string.size())?

考虑一个产生某些段错误并中止的C++程序。在使用gdb进行常规调试时,我可以执行以下操作并查看结果(gdb)r(gdb)pstr_var.size()其中str_var在文件中定义为std::string。但是,我在使用核心转储进行调试时遇到了一些问题。在我通过在gdb中加载核心转储之后gdbEXECUTABLEcore.pid然后在gdb终端运行以下命令(gdb)pstr_var.size()gdb说“如果没有调试过程,你就不能这样做。”我只能做bt(查看堆栈跟踪)或直接打印std::string变量之类的事情,但是找不到一种简单的方法来检查一些信息,例如打印std::string的

c++ - 为什么 boost::circular_buffer 在我的基准测试中这么慢?

阅读rationale,boost::circular_buffer看起来很有希望:Suitabilityforreal-timeandperformancecriticalapplications.Fastconstant-timeinsertionandremovalofelementsfromthefrontandback.当我运行一个模拟我的用例的简单基准测试时,将其用作字节缓冲区:写一个更大的block读取较小的block直到为空重复性能绝对糟糕,超过4000x比我自己的hack和spsc_queue慢。lin:101//10240xlock:109//10240xcirc:

c++ - 使用省略号的回退函数 : can we force the size of the parameters pack?

考虑以下代码:#include#includestructS{templateautof(A&&...args)->decltype(std::declval().f(std::forward(args)...),void()){std::coutvoidf(...){std::cout(42);//->hasf(int)s.f(42);//->hasnotf(int)//oopss.f();//->hasnotf(int)}如示例所示,对f的第三次调用工作正常,即使参数数量错误,因为对于回退函数来说它根本没有错.当以这种方式涉及省略号时,有没有办法强制参数的数量?我的意思是,我可以在

c++ - std::span.size() 与数组/vector 大小

我们在工作中使用std::span()(目前使用gsl实现)。最近我们发现将std::span.size()与vector.size()进行比较会产生-Wsign-compare错误:if(span.size()>vector.size())//comparisonbetweensignedandunsignedintegerexpressions[-Wsign-compare]我认为我们不想对这些比较中的每一个进行转换。我们的编码指南将这些警告视为错误。想知道是否有人有任何想法或建议? 最佳答案 您可以使用迭代器并同时使用函数st

c++ - 与 Thrift 或 Protocol Buffers 的双向通信

(对不起我的英语)是否可以构建一个应用程序(实际上是2个)来实现进程之间的双向通信?我知道两个“框架”来传达不同的进程(使用不同的语言)Thrift和Protocolbuffers。我知道thrift在客户端/服务器模式下工作,所以如果我想要双向通信,我需要像客户端和服务器一样同时构建两侧/进程。客户端/服务器客户端/服务器我不知道这种做法是否正确。但是..我无法使用ProtocolBuffers找到关于此的信息。这可能吗?我有一个C++进程和一个Node.js(Javascript)应用程序..C++进程向deNode.js应用程序发送通知(效果很好,我使用thrift进行测试)..

c++ - Valgrind 在空析构函数上给出 "Invalid write of size 8"

我有一个声明:std::map*myMap;进入某个类A。这个映射是在A的构造函数中创建的:myMap=newstd::map;MyClass类基本上是一个结构,用于存储一些带有一些getter/setter的数据。MyClass中没有任何指针或新实例,只有一对枚举值、一个无符号整数和一个bool值。所以MyClass析构函数是空的。另一方面,在A的析构函数中我正在删除映射:A::~A(){if(myMap!=NULL){deletemyMap;myMap=NULL;}}这里Valgrind在删除行上告诉我“地址0x4c389b0是一个大小为48的block内的16个字节free'd[