草庐IT

C++标准

全部标签

c++ - 如何将 float 转换为非标准编码

我正在编写一个创建ICC颜色格式的程序。这些格式指定了一种称为s15Fixed16Number的数据类型,它具有一个符号位、15个整数位和16个小数位。IEEE75432位float有一个符号位、8个指数位和23个小数位。我需要从文本框中获取输入,并将它们转换为s15Fixed16Number。一些搜索出现了this在谷歌书籍上,但这是在谈论将十进制数转换为s15Fixed16Number。我想我可以只使用链接中解释的方法,但我还没有进行任何测试来确定它的准确性。我想我也可以尝试转换从文本框中输入的字符,但我还没有考虑那么多。我正在使用Cocoa,但我认为这不重要;任何C函数都应该有效

c++ - 谁能解释一下当前C++0x标准草案的这一段?

谁能解释ISON3242§3.2第2点中的这个陈述Anon-placementallocationordeallocationfunctionforaclassisodr-usedbythedefinitionofaconstructorofthatclass.Anon-placementdeallocationfunctionforaclassisodr-usedbythedefinitionofthedestructorofthatclass,orbybeingselectedbythelookupatthepointofdefinitionofavirtualdestructor

STM32 LED编程 GPIO的初始化(标准库)

实验的电路图介绍实验的电路图类似于开漏接法要初始化GPIOC接口标准库的模板GPIO的标准库编程接口GPIO引脚的初始化GPIO作为片上外设每一个片上外设使用前一定要使能时钟为什么要使能时钟?时钟是啥时钟的使能stm32的每一个片上外设都是时序电路时序电路在使用前都要进行时钟使能通过调用图片中圈起来的函数进行时钟初始化第一个参数为初始化的GPIO口绿色的字如要初始化GPIOC第一个参数就输入RCC_APB2Periph第二个参数就输出ENABLE即可完成时钟的初始化开启gpioc的时钟GPIO_Init的初始化第一个参数写你要初始化端口以GPIOCP13为例子第一个参数就写GPIOC第二个参数

c++ - 我如何优化/改进这个哈希函数

我有一个存储四叉树条目的哈希表。哈希函数如下所示:四叉树哈希#definenode_hash(a,b,c,d)\(((int)(d))+3*(((int)(c))+3*(((int)(b))+3*((int)(a))+3)))请注意,此操作的结果始终使用模素数进行分块,如下所示:h=node_hash(p->nw,p->ne,p->sw,p->se);h%=hashprime;...与最优哈希的比较一些统计分析表明,此哈希在减少冲突方面是最佳的。给定一个包含b个桶和n个条目的哈希表。使用完美哈希的碰撞风险是:(n-b*(1-power((b-1)/b,n))))*100/n当n=b时,

【C++】详解用标准库的std::mt19937生成随机数

2023年8月16日,周三晚上写了1个半小时目录概述英文文档什么是mt19937什么是状态大小头文件std::mt19937的常用成员函数1.构造函数:2.种子操作函数:3.随机数生成函数:4.辅助函数:生成种子值方法1:使用std::random_device方法2:使用时间戳举例说明概述英文文档std::mersenne_twister_engine-cppreference.comhttps://cplusplus.com/reference/random/mt19937/什么是mt19937std::mt19937是C++标准库中的一个伪随机数生成器类,它实现了梅森旋转算法(Merse

c++ - 确认此标准库错误与 MSVC 2015 RC 中的分配器有关

这是一个SSCCE:#include#includetemplatestructmy_allocator:std::allocator{//Thisoverridingstructcausestheerrortemplatestructrebind{typedefmy_allocatorother;};//Ignoreallthis.typedefstd::allocatorbase;typenamebase::pointerallocate(typenamebase::size_typen,std::allocator::const_pointer/*hint*/=nullptr){

c++ - C++03 标准容器的堆栈分配器

对于一个软件,我必须避免在堆中使用任何内存,并且只依赖堆栈分配的内存。然后,这使我无法使用我真正想使用的任何C++标准容器,例如vector、映射、字符串(好吧,basic_string)来简化开发和数据操作。我发现了(许多)堆栈分配器的实现,例如thisone它本身引用了另外两个,或者thisone来自Chrome。其中许多并不完全符合标准,或者依赖于C++11(遗憾的是,我目前还在使用C++03)。您对C++03现有的良好堆栈分配器有任何反馈,或者我应该采用上述之一吗?谢谢! 最佳答案 HowardHinnant的short_a

c++ - 如何从 C++ 处理 C 库中不同大小的类型

我有一个从C++链接到的外部C库。该库定义了一个使用bool的结构,并为C语言包含了一个typedef。问题是这个typedef使用int,所以(在我的平台上)不是这个大小为1字节的bool,而是4个字节。然后,当我#includeheader并在C++中创建结构时,bool(作为C++标准类型)的大小为1个字节,因此该结构具有完全不同的内存布局,当我将它传递给C库以便在那里修改它时,会导致各种堆栈损坏。有没有办法在不修改外部库的情况下解决这个问题?我想用C++编译器而不是C编译器编译外部库会起作用,对吗?这是我解决这个问题的唯一机会吗?库.h:#ifndef__cplusplusty

c++ - 有没有一种符合标准的方法来用 C++ 编写可移植的 ls 实用程序?

让我们考虑以下代码,列出作为程序第一个参数给出的路径的目录内容:#include#includeintmain(intargc,char**argv){if(argc!=2)std::cerr乍一看这似乎非常精简、可移植并且符合C++标准(请忽略如果目录不存在它不会捕获异常)。但是,似乎存在一些陷阱。特别是,C++标准似乎没有强制要求argv[1]的编码与std::filesystem::path构造函数接受的编码相匹配,它似乎也没有要求std::filesystem::path::string()返回的编码与std::cout接受的编码相匹配。恰恰相反,该标准似乎引入了新术语“nat

C++ 标准 I/O 和信号

如果我调用一个像read()这样的POSIX函数,它不是C++标准库的一部分,我必须担心它会被信号中断并处理EINTR返回值。如果我根据thisdocumentation调用像fread()这样的C++标准库函数没有提到EINTR所以标准库似乎对用户隐藏了这一点。我的理解是否正确?这是否适用于所有C++标准库函数?更新:那么从响应中仍然不清楚的是,不能编写在每个平台上都能正常运行的标准C++的结论是什么?我看到人们提到不属于标准的POSIX行为,所以这很令人困惑。 最佳答案 IfIcallaPOSIXfunctionlikeread