草庐IT

合法化

全部标签

c++ - shared_future<void> 是 condition_variable 的合法替代品吗?

Josuttis指出[“标准库”,第2版,第1003页]:Futuresallowyoutoblockuntildatabyanotherthreadisprovidedoranotherthreadisdone.However,afuturecanpassdatafromonethreadtoanotheronlyonce.Infact,afuture'smajorpurposeistodealwithreturnvaluesorexceptionsofthreads.另一方面,shared_future可以被多个线程使用,以识别另一个线程何时完成了它的工作。另外,一般来说,高级并发

c++ - 类模板特化从不同的基类继承是否合法?

我遇到过这样一种情况,我的类模板部分特化共享大量代码,将它们移到基类中是有意义的。然而,所有的特化都具有相同基类是没有意义的。以下示例代码在GCC7.1中编译无误:structfoo_base_1{voidbar(){std::coutstructfoo{};templatestructfoo:foo_base_1{};templatestructfoo:foo_base_2{};intmain(){foox;fooy;x.bar();y.bar();}我意识到尽管它们是同一类的特化,但它们实际上是不同的类型。仍然,感觉同一个类可以从不同的基础继承是错误的。我想要的是一些保证,这没关系

c++ - Visual Studio 2017 允许在构造函数中使用自身初始化引用成员。它真的是合法的 C++ 吗?

我刚刚在我的代码中发现了一个非常危险的错误,我觉得它应该被编译器捕获。我错了吗?本质上,允许类的引用成员在构造函数中自行初始化。下面是在VisualStudio2017中编译而没有错误或警告的测试代码:structfoo{foo():reference(reference){}int&reference;};intmain(){foofooOb;}更新:我看到这里有一个2009年的类似问题。其他编译器在2017年的行为是否相同,还是VS2017问题?如果他们这样做了,这有点向我暗示这是合法的C++,但我不明白它怎么可能。 最佳答案

c++ - 将宏名称传递给 X-Macro 列表是否合法

我想到以下是X-macro的更可取的样式技巧:#defineLIST_OF_COLOURS(X)\X(RED)\X(GREEN)\X(BLUE)#defineLIST_OF_FRUIT(X)\X(APPLE)\X(ORANGE)\X(TOMATO)具体来说,将X宏传递给列表,而不是在每次实例化列表时取消定义并重新定义它。这允许:#defineX_LIST(x)x,#defineX_STRING_LIST(x)#x,#defineCOMPREHENSIVE_SETUP(n,l)\enumn{l(X_LIST)};\charconst*n##Names[]={l(X_STRING_LIST

c++ - 这样的初始化列表在 C++11 中合法吗?

我阅读了C++入门第5版,其中介绍了最新的标准支持列表初始化程序。我的测试代码是这样的:#include#include#include#includeusingstd::cin;usingstd::cout;usingstd::endl;usingstd::string;usingstd::vector;usingstd::ispunct;intmain(intargc,char*argv[]){vectora1={0,1,2};vectora2{0,1,2};//shouldbeequaltoa1return0;}然后我使用Clang4.0:bash-3.2$c++--versio

c++ - 通过这样的 const 指针修改非常量指针是否合法?

考虑以下函数:voidf(intconst*p){*const_cast(id(p))=0;}假设f总是得到一个int*作为参数,这是合法的吗?我不是在问这是否是一件好事,我只是想要一个严格正式的答案。让我有点担心的是,如果你能做到这一点,优化器就会更难利用常量。考虑一个更复杂的例子://identity,alwaysreturnswhatitgetsuintptr_tid(uintptr_tp){staticunsignedintconstar[5]{0x12345678,0x87654321,0x02468ACE,0xECA86420,0x88888888};for(size_ti

c++ - `type *var = (int)0` ,合法与否?

下面的例子:char*var=(int)0;在gcc和cl.exe上编译,但在clang中导致错误:cannotinitializeavariableoftype'char*'withanrvalueoftype'int'谁是正确的?对于它的值(value),C++11说(强调我的)4.10/1Anullpointerconstantisanintegralconstantexpression(5.19)prvalueofintegertypethatevaluatestozerooraprvalueoftypestd::nullptr_t.Anullpointerconstantca

c++ - 获取 const 左值引用的地址是否合法?

#includeintfoo(){return0;}intmain(){constint&a=foo();std::cout在这段代码中,a绑定(bind)到一个右值。取它的地址合法吗?(我的法律意思是:在代码中格式不正确?我是否导致了未定义的行为?) 最佳答案 这很好。在C++11中,您甚至可以这样做:int&&a=foo();a=123;您可以这样考虑临时对象(概念上和一般情况下):x=func();//translatedas:auto__temporary=func();x=__temporary;__destruct_va

利用RSA加密打造强大License验证,确保软件正版合法运行

 概述:C#软件开发中,License扮演着确保软件合法使用的重要角色。采用RSA非对称加密方案,服务端生成带签名的License,客户端验证其有效性,从而实现对软件的授权与安全保障。License应用场景:License(许可证)在C#软件开发中被广泛应用,以确保软件在合法授权的环境中运行。常见场景包括商业软件、桌面应用、服务端应用等。Licence实现方案:一种常见的License实现方案是使用非对称加密技术,将License信息加密,并在软件中内置公钥,从而确保只有使用私钥签名的License才会被验证通过。Licence验证流程图:以下是一个简单的License验证流程图:+-----

c++ - 在 C++ 的 for 循环中声明结构是否合法?

我刚刚在Gcc编译器中试验了以下程序。我想知道,在for循环中声明结构并在GCC中工作正常。#includeintmain(){inti=0;for(structst{inta{9};}t;i那么,在for循环中声明结构是否合法?DEMO 最佳答案 是的,在for循环(从C99开始)的子句1中声明(带有初始值设定项)是合法的。让我们将您的C++转换为C代码(因为当我写这篇文章时您的问题被标记为“c”):$catx.c#includeintmain(void){for(struct{inta;}t={0};t.a相关C99:6.8.5