草庐IT

static-libraries

全部标签

c++ - 将 C 风格的转换更改为 static_cast 总是安全的吗?

由于cppcheckcstyleCast样式警告,我正在尝试消除代码库中的所有C样式转换。将C风格的转换更改为static_cast总是安全的吗?安全,我的意思是,是否存在旧的C风格转换可以正常工作,但static_cast会引发错误或未定义行为的情况?type1a;type2b=(type2)a;//Cstylecasttype2b=static_cast(a);//Isthisalwaysavalidreplacementforabovecast? 最佳答案 C风格的转换通常是static_cast的组合或reinterpret

c++ - 如何将 `boost::static_visitor` 实例传递给函数

我正在使用boost::variant在我的项目中经常出现。我的同事们现在想出了传递特定boost::static_visitor实例的想法。以自定义访问类型。她有一些代码如下:#include#includetypedefboost::variantTVar;structVisitor1:publicboost::static_visitor{templateresult_typeoperator()(constT&){return42;}};structVisitor2:publicboost::static_visitor{templateresult_typeoperator(

c++ - C++中static的含义

我认为我的C++相当不错,事实证明我不是。我之前问过一个问题:C++constlvaluereferences其中一个答案中有以下代码:#includeusingnamespacestd;int&GenX(boolreset){staticint*x=newint;*x=100;if(reset){deletex;x=newint;*x=200;}return*x;}classYStore{public:YStore(int&x);int&getX(){returnmy_x;}private:int&my_x;};YStore::YStore(int&x):my_x(x){}intma

c++ - 从 C++ 引用静态库中的 C 函数

我有一个用C编写的静态函数库。假设头文件名为myHeader.h,如下所示:#ifndefMYHEADER_H#defineMYHEADER_Hvoidfunction1();voidfunction2();#endiffunction1和function2没什么特别的。假设它们存在于一个名为impl1.c的文件中,该文件如下所示:#include"myHeader.h"voidfunction1(){//code}voidfunction2(){//morecode}到目前为止提到的所有代码都被编译到一些名为libMyLib.a的静态库中。我宁愿不修改用于构建此库的任何代码。我还有一

c++11:为什么 std::forward 中的 static_assert 是必需的?

在move.h中,forward有两个重载templateconstexpr_Tp&&forward(typenamestd::remove_reference::type&__t)noexcept{returnstatic_cast(__t);}templateconstexpr_Tp&&forward(typenamestd::remove_reference::type&&__t)noexcept{static_assert(!std::is_lvalue_reference::value,"templateargumentsubstituting_Tpisanlvalueref

C++ - 基类和私有(private)头文件

我正在用C++编写一个库,并且有一个像这样的类层次结构:message.h文件(在./mylib/src中)classMessage{};request.h文件(在./mylib/include/mylib中)#include"message.h"classRequest:publicMessage{};response.h文件(在./mylib/include/mylib中)#include"message.h"classResponse:publicMessage{};我希望对用户隐藏mylib/src文件夹中的所有内容,并且只想分发mylib/include中的文件。但问题是re

c++ - 使用 static_assert 确定特定模板参数是否为特定无类型类模板

我想要一个将参数限制为仅派生自特定模板类的类型的函数。在这种情况下,basic_string(来自STL-docs)。例如,声明了一个wstring:typedefbasic_string,allocator>wstring;基本思路是这样的:templatevoidstrings_only_please(TStringmessage){static_assert(is_base_of::value,"Notastringtype!");}当然,虽然没有指定basic_string,但它无法编译……它需要一个真实的类型。(虽然我可能只对少数实际字符串类型进行硬编码,但我正在寻找针对此模

c++ - Windows XP 样式 : Why do we get dark grey background on static text widgets?

我们正在使用C++和Win32编写Windows桌面应用程序。我们的对话框具有“WindowsXP风格”的丑陋外观:静态文本的背景是灰色的。对话框背景也是灰色的,这不是问题,但是在选项卡控件中,背景是白色的,文本的灰色背景非常明显。过去我们自己绘制了很多控件,但现在我们正在尝试尽可能多地使用标准外观,并尽可能避免覆盖标准行为。我们使用的是Win32API,它有点过时了,但我认为即使使用ATL也会出现问题。我们正在创建一个DIALOGTEMPLATE。文本位于“静态”控件(0x0082)中。我们为样式设置的唯一标志是“SS_LEFT”。文本控件位于选项卡控件内:“SysTabContro

c++ - 如何使用 Boost Graph Library 更改图中的边权重?

我已经使用Boost图形库定义了一个图形,typedefboost::propertyEdgeWeightProperty;typedefboost::adjacency_listGraph;使用添加边相当简单boost::add_edge(vertice1,vertice2,weight,graph);我还没有弄清楚如何在设置边缘权重后更改它。一种可能的解决方案是删除边缘并使用更新后的权重值重新添加它,但是,这似乎有点过分。 最佳答案 一种解决方案是执行以下操作typedefboost::adjacency_listGraph;t

wsl2设置静态ip(固定ip)static ip

文章目录Windows设置wsl设置设置ip免密sudo权限配置DNS本方法是为了尽可能让配置在wsl中执行,有一键脚本的方法,参见给WSL2设置静态IP地址有两个地方需要设置静态ip:wsl内部的eth0网卡;假定ip为172.22.0.2;Windows的vEthernet(WSL)网卡;假定ip为172.22.0.1;Windows设置cmd命令行以管理员权限执行以下语句:powershell-c"Get-NetAdapter'vEthernet(WSL)'|Get-NetIPAddress|Remove-NetIPAddress-Confirm:$False;New-NetIPAddr