草庐IT

auto-format

全部标签

c++ - auto 作为函数参数

在C++14中,这样的事情是合法的(对于lambdas):-autol=[](autox,autoy){returnx+y;};但是这样的事情仍然是不合法的:-autosum(autox,autoy){returnx+y;}我的好奇心是为什么没有将第二个添加到标准中(尽管它应该有望添加到C++17中)?第二个的优点和缺点是什么? 最佳答案 它没有被添加,因为添加是另一回事,而且时间不是无限的。我们不能指望一次性添加所有有用的增强功能,对吗?正如您所确定的,它将在C++17中。 关于c++

c++ - 在 boost::format 中使用 * 宽度和精度说明符

我正在尝试将宽度和精度说明符与boost::format一起使用,如下所示:#include#includeintmain(){intn=5;std::strings=(boost::format("%*.*s")%(n*2)%(n*2)%"Hello").str();return0;}但这不起作用,因为boost::format不支持*说明符。Boost在解析字符串时抛出异常。有没有办法实现相同的目标,最好是使用直接替代品? 最佳答案 试试这个:#include#includeusingnamespacestd;usingname

c++ - 有什么方法可以将 varargs 与 boost::format 一起使用吗?

我有点讨厌使用固定大小的缓冲区和vnsprintf通常的嫌疑人。像这样的东西可以让boost::format与可变参数列表一起工作吗?遗憾的是,我不能使用C++11中的任何东西。voidformatIt(constchar*msg,...){va_listargs;va_start(args,msg);boost::formatf(msg);forloopsomehow{f%va_arg(args,constchar*);//doesthiswork?}va_end(args);} 最佳答案 我用这个:inlinestaticstd

c++ - 从 C++ 调用 NSLog : "Format string is not a string literal (potentially insecure)"

当我从C++调用NSLog时,Xcode提示传递给NSLog的格式字符串不是文字字符串。这是触发警告的一行代码:NSLog(CFSTR("Leaking?"));我不知道有什么方法可以在C++中编写NSString文字,而且我没有看到可以在项目设置中关闭的相关警告。有没有办法在不触发此消息的情况下从C++调用NSLog?我正在使用Xcode4.2.1。编辑:这确实是C++代码。我通常避免使用Objective-C++,坚持使用Objective-C或普通的旧C++,因为没有官方文档说明什么在Objective-C++中有效,什么无效。我只发现模糊的警告(例如)STL的某些部分可能存在问

c++ - `auto` 类成员上下文中的返回类型

如何对类成员使用自动类型推导?比如下面的代码structA{autofoo();//fooisdefinedinanotherfile};intmain(){Aa;a.foo();}其中foo的返回类型为auto会导致以下错误:error:function'foo'withdeducedreturntypecannotbeusedbeforeitisdefineda.foo();^错误是可以理解的,因为编译无法在不知道其定义的情况下知道foo的返回类型是什么。我的问题是,如果函数的声明和定义分离,是否有任何变通方法或某种编程模式可以规避自动返回类型不能用于类成员函数的问题。

C++:auto 关键字 & 范围for

目录auto关键字:起源:  auto的使用细则:auto不能推导的场景:范围for:范围for的使用条件: C++的空指针:注意: auto关键字:起源: 随着程序越来越复杂,程序中用到的类型也越来越复杂,经常体现在:类型难于拼写含义不明确导致容易出错例如:std::map::iterator于是就有了auto关键字,C++11中,标准委员会赋予了auto全新的含义即:auto不再是一个存储类型指示符,而是作为一个新的类型指示符来指示编译器,auto声明的变量必须由编译器在编译时期推导而得。简单来说,auto可以从获取的数值中推导出我们想要得到的类型。intmain(){inti=0;int

c++ - 代码审查问题——我应该允许将 auto_ptr 作为参数传递吗?

考虑我最近在我们的代码库中看到的以下示例代码:voidClassA::ExportAnimation(auto_ptranimation){...doessomething}//callingmethod:voidclassB::someMethod(){auto_ptranimation(newCAnimation(1,2));ClassAclassAInstance;classAInstance.ExportAnimation(animation)...dosomemorestuff}我不喜欢这样——我宁愿这样写:voidClassA::ExportAnimation(CAnima

c++ - 如何显式查看auto类型推断的结果?

最近在学习C++11/14的auto特性。出于教育目的,我想明确显示我的代码的类型推断结果。我尝试了typeid().name(),但我发现这种方法有两个问题。输出有时难以理解。(例如,“NSt3__16vectorIiNS_9allocatorIiEEEE”)似乎没有显示const/volatile修饰符。@πìνταῥεῖ我试过使用你指出的abi::__cxa_demangle()。问题1解决了,谢谢,但是typeid().name()好像没有包含CV修饰符信息。我认为使用auto关键字有一些陷阱,所以我想看看类型推断的确切结果,包括CV修饰符和引用类型。我在macos10.10.

c++ - 如何使 clang-format 跳过 c++ 代码的部分

有什么方法可以配置clang-format工具来跳过我的Qt::connect函数调用吗?我的构造函数中有几个连接,如下所示:connect(m_Job,SIGNAL(error(constQString&,constQString&)),this,SLOT(onError(constQString&,constQString&)));connect(m_Job,SIGNAL(message(constQString&)),this,SLOT(onMessage(constQString&)));connect(m_Job,SIGNAL(progress(int,int)),this,

C++11: "auto"关键字是否完全检索 cv 限定符?我有矛盾的样本

我有如下程序:structA{inti;};intmain(){constinti=0;autoai=i;ai=2;//OKconstAbuf[2];for(auto&a:buf){a.i=1;//error!}std::cout第一个autoai=i;没有问题,好像auto没有检索c/v限定符,因为ai可以修改的但是for循环编译失败——错误:成员A::i在只读对象中的赋值我知道auto不会检索&功能,我的问题是:auto是否像我的情况一样检索c/v限定符?我的测试程序似乎给出了相互矛盾的提示。 最佳答案 你在这里复制ai,而不是