草庐IT

string.format

全部标签

c++ - string s怎么改成char * a[]?

我要转型字符串s="aaa,bbb,ccc"进入:char*a[]={"aaa","bbb","ccc"}你能帮我编写程序来处理这个过程吗?我会尝试这样编程:strings="aaa,bbb,ccc";char*a[];charid[]="";strcpy(id,s.c_str());constchar*split=",";char*p;p=strtok(id,split);while(p!=NULL){inti=0;printf("%s\n",p);a[i]=p;i++;p=strtok(NULL,split);}我哪里错了?谁能指点一下? 最佳答案

c++ - 为什么 Boost Format 和 printf 在相同的格式字符串上表现不同

TheBoostFormatdocumentation说:Oneofitsgoalistoprovideareplacementforprintf,thatmeansformatcanparseaformat-stringdesignedforprintf,applyittothegivenarguments,andproducethesameresultasprintfwouldhave.当我使用相同的格式字符串比较boost:format和printf的输出时,我得到了不同的输出。在线例子是here#include#includeintmain(){boost::formatf("

c++ - 用双花括号初始化 vector :std::string vs int

在这个问题的回答中:Initializingvectorwithdoublecurlybraces表明vectorv={{"a","b"}};将调用带有initializer_list的std::vector构造函数和一个元素。因此vector中的第一个(也是唯一一个)元素将从{"a","b"}构造。这会导致未定义的行为,但这超出了这里的重点。我发现的是std::vectorv={{2,3}};将使用两个元素的initializer_list调用std::vector构造函数。造成这种行为差异的原因是什么? 最佳答案 类类型列表初始

c++ - boost::interprocess : cout a string variable when iterating through a map that references an object from a struct

我正在使用boost::interprocess在进程之间共享对象。我有两个文件,一个生成结构对象并将该对象传递到具有int索引的映射中的“server.cpp”;和一个“client.cpp”文件,它检索内存数据并遍历数据,输出到控制台。结构看起来像这样:structmydatao{stringMY_STRING;intMY_INT;};和对象:mydatao;o.MY_STRING="hello";o.MY_INT=45;服务器和客户端都能正确编译。但是出于某种原因,如果我尝试访问客户端中的字符串而不是float或整数,客户端可执行文件会抛出段错误。例如下面的second.MY_I

c++ - 如何使用 Boost.Sort string_sort 函数使 C++ 结构快速运行

与成对的指针+长度和std::string相比,我发现对std::string对象进行排序时性能差异非常大我在我的应用程序中进行了大量排序,我发现性能瓶颈在于对大型字符串数组进行排序。我知道进行此类排序的两种好方法-使用std::sort和Boost.sort函数。我正在使用指针和字符串长度信息对大文件的各个部分进行排序我尝试将我的性能与对std::string对象进行排序进行比较,而我的简单指针+长度结构要慢得多。我无法想象-为什么?sizeof(std::string)是32,而sizeof(my_struct)是16字节。两者都是在内部使用::memcmp函数进行比较为了描述这个

c++ - 在没有 std::string 的情况下构造字符串

我正在做一个不允许我们使用的项目完全没有库——我们只能使用字符串作为字符指针,我们必须为它们编写自己的函数(strcpy、strlen等)。我正在尝试使用以下头文件构建RentalCar类:#ifndefRENTALCAR_H#defineRENTALCAR_HclassRentalCar{public:RentalCar();RentalCar(char*make,char*model);char*getMake()const;char*getModel()const;voidsetMake(char*make="");voidsetModel(char*model="");priv

c++ - std::basic_string 的使用

basic_string类显然被设计为通用容器,因为除了c_str()函数外,我在其规范中找不到任何特定于文本的函数。出于好奇,除了存储人类可读的字符数据之外,您是否曾将std::basic_string容器类用于其他用途?我问这个问题的原因是,人们常常不得不在通用或具体之间做出选择。设计者选择将std::basic_string类设为通用类,但我怀疑它是否曾经以这种方式使用过。 最佳答案 它被设计为一个字符串类(因此,例如length()和所有那些查找函数),但是在将STL引入标准库之后,它也被装备为一个STL容器(因此size(

标准库中的string类(下)——“C++”

各位CSDN的uu们你们好呀,这段时间小雅兰的内容仍然是C++string类的使用的内容,下面,让我们进入string类的世界吧!!! string类的常用接口说明string-C++Referencestring类的常用接口说明string类对象的修改操作 insert这是在第五个位置插入xxxx这个字符串!下面的代码的意思是头插4个x字符! 头插还可以这么写,用迭代器的方式!#include#includeusingnamespacestd;intmain(){ strings1("helloworld"); s1.insert(5,"xxxx"); coutinsert最常见的用法还是插

c++ - 使用 int 和 string boost::interprocess 映射

我有以下代码使用boost进程间将映射保存到共享内存中usingnamespaceboost::interprocess;//Sharedmemoryfront-endthatisabletoconstructobjects//associatedwithac-string.Eraseprevioussharedmemorywiththename//tobeusedandcreatethememorysegmentatthespecifiedaddressandinitializeresourcesshared_memory_object::remove("MySharedMemory

c++ - 为什么 Boost.Spirit 正确地将标识符解析为 std::string,而不是解析为仅由 std::string 组成的适配结构?

我为标识符定义了一条规则:以字母字符开头,后跟任意数量的字母数字字符。当我直接解析为std::string与包含单个std::string的改编结构时,我得到不同的结果。如果我的语法属性是std::string,Qi会正确地将字符序列调整到其中。但是对于结构,只存储第一个字符。我不太确定这是为什么。(请注意,如果结构是“真正”改编的,或者它是由Fusion内联定义的,这没有区别。)这是一个SSCCE,可配置调试://Options://#defineDEFINE_STRUCT_INLINE//#defineDEBUG_RULE#defineBOOST_SPIRIT_USE_PHOENI