- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想实现一个处理所有简单 C++ 类型(还有 STL 容器和更多类型,但它们不会让我头疼)的函数,以及一个处理所有其他类型的通用函数,如下所示:
template <typename T>
void dostuff(T& arg)
{ cout << "generic version" << endl; }
void dostuff(int& arg)
{ cout << "something useful" << endl; }
void dostuff(unsigned int& arg)
{ cout << "something slightly different" << endl; }
void dostuff(short& arg)
{ cout << "something slightly different again" << endl; }
// ...and so on for all integer types...
这里我限制自己使用整数类型,因为它们会造成所有的麻烦。当然,如果我为同一类型实现函数两次,编译器会报错。当混合 unsigned int
和 std::size_t
时会发生这种情况;它适用于我的系统,但不能在 32 位平台上编译。我明白这个问题,但我不知道如何实现可移植的解决方案。
我认为最系统的方法是使用 std::int8_t (std::uint8_t, 16, 32, 64) 系列类型,因为它们不会重叠并且旨在覆盖可用范围。事实证明这还不够,如以下代码所示:
#include <type_traits>
#include <cstdint>
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
cout << "SIZE:" << endl;
cout << "sizeof(unsigned long) = " << sizeof(unsigned long) << endl;
cout << "sizeof(unsigned long long) = " << sizeof(unsigned long long) << endl;
cout << "sizeof(std::size_t) = " << sizeof(std::size_t) << endl;
cout << "sizeof(std::uint64_t) = " << sizeof(std::uint64_t) << endl;
cout << endl;
cout << "SIGNED?" << std::boolalpha << endl;
cout << std::is_signed<unsigned long>::value << endl;
cout << std::is_signed<unsigned long long>::value << endl;
cout << std::is_signed<std::size_t>::value << endl;
cout << std::is_signed<std::uint64_t>::value << endl;
cout << endl;
cout << "SAME?" << endl;
cout << std::is_same<unsigned long, unsigned long long>::value << endl;
cout << std::is_same<unsigned long, std::size_t>::value << endl;
cout << std::is_same<unsigned long, std::uint64_t>::value << endl;
cout << std::is_same<unsigned long long, std::size_t>::value << endl;
cout << std::is_same<unsigned long long, std::uint64_t>::value << endl;
cout << std::is_same<std::size_t, std::uint64_t>::value << endl;
}
在我的带有 clang 3.8 的 64 位 MacOS 系统上,它给出了以下输出:
SIZE:
sizeof(unsigned long) = 8
sizeof(unsigned long long) = 8
sizeof(std::size_t) = 8
sizeof(std::uint64_t) = 8
SIGNED?
false
false
false
false
SAME?
false
true
false
false
true
false
所以我有四种 64 位无符号整数类型,但它们实际上指的只是两种不同类型。还有更多候选者,例如 std::uintptr_t
、std::ptrdiff_t
和 std::uint_fast64_t
,我什至不知道如果该列表是完整的。哪些类型相同的定义在我看来是随意的,尽管我看到对于我面临的确切问题,我们希望将 long
和 long long
视为不同的。
问题:有什么方法可以针对不同整数类型的详尽列表实现上述功能,这样我就不会在不同平台上遇到麻烦吗?如果是这样,这个列表是什么?如果不是,实现所需行为的最佳方法是什么(处理所有整数类型、未知类型的有意义的默认行为、可移植解决方案)?
最佳答案
由于您要尝试为每个特定的整数类型做一些不同的事情,即使您可以枚举程序中的所有类型,您也无法组成特定的特殊逻辑。
相反,我要建议的是实现 say short
的特殊逻辑。 , int
, unsigned
, 等等,并根据需要放置一个静态断言 is_integral<T>
是false
在您的主模板中,带有一条消息,表明正在使用不受支持的整数类型调用它,需要确定和编写自定义逻辑。
关于c++ - C++ 中是否有所有不同整数类型的完整且可移植的列表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38398796/
我是 Mercurial 的新手,并且不知何故仍处于评估过程中,所以这四个概念对我来说有点困惑。有些被提到等同于 Git 的 Staging/Index 概念,有些甚至比 Git 的 Staging
如何将在某些网站 (www.example1.com) 上用某种语言即 (java) 制作的 session 传送到用其他语言制作的网站,即在某些其他网站上的 (php),即 (www.example
我有以下代码行我想移植到 Torch Matmul rotMat = xmat @ ymat @ zmat 我能知道这是不是正确的顺序: rotMat = torch.matmul(xmat, tor
我正在尝试移植一个内部有一个联合的 C 结构。 Winapi.Winsock2.pas 中的默认结构记录中缺少某些字段。 但这是正确的方法吗?谢谢。 typedef struct _WSACOMPLE
我想将基于 webkit 的浏览器移植到我的堆栈中。谁能介绍一下 webkit 浏览器引擎的组织结构?目前我所知道的是它具有用于呈现 html 和解析 javascript 的核心。我想了解更多,比如
我目前有一个 ActiveX 控件,它链接到许多 c/c++ dll。问题是我们现在需要此控件在 IE 以外的浏览器(最重要的是 Firefox)上运行。 在我看来,我有以下选择: 将控件编写为 fi
我正在尝试在 Objective-C 中重写 Java 库。我想将其重写为 API,以便需要实现某些方法。我已经开始尝试重写代码,但遇到了一些问题。 Objective-C 是否支持抽象类? 如果没有
我已经有一段时间没有接触 SQL 了,所以我需要重新学习一下。我的计算机上运行着一个 SQL 数据库,我的服务器是 localhost。我在 VB.Net 中制作了一个连接到该数据库的应用程序。一切都
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit th
运行命令时出现错误 [root@himanshi busybox-1.20.2]# make ARCH=arm CROSS_COMPILE=arm-unknown-linux-gnueabi- CON
我需要将为 iPhone 编写的现有游戏移植到 Flash。 iPhone 游戏主要是用纯 C 而不是 Objective C 编写的。 我想知道是否有任何好的工具可以将 C 代码直接转换为 Acti
我将要在 Smalltalk (Pharo) 中构建一个项目。还有一个 python 库,我打算将其用于相同的目的。现在,有 3 个选项: 那些 python 库的 Smalltalk 包装器 将 p
我必须在 GPU 上移植一个广泛使用随机数的结构。一切都可以毫无问题地移植,但随机生成器函数是唯一在该类的所有函数中被广泛调用的函数。我虽然可以简单地将它重新实现为类本身的内部设备函数。下面我放了一个
我对整个移植问题有点陌生,因为 Android SDK 提供的模拟器速度很慢,所以我解决了这个问题。 我下载了 android-x86-3.2-RC2-eeepc 和 android-x86-3.2-
我们的数据库 (PostgreSQL 9.x) 中有一些 PL/pgSQL 存储过程。 这些是严格顺序的,在某些情况下,可能会非常慢。 我们正在考虑将它们移植到 PL/Java、PL/Python 或
我有一个 Android 应用程序可以处理圆顶图像。出于性能原因,我想用 C++ 编写应用程序的某些部分,然后通过 NDK 调用这些方法。我是否需要一个特定的 C++ 编译器(例如用于嵌入式系统)或者
我正在从事一个将一大堆 OS-9(微软件)代码移植到 linux 的项目。 OS-9 中的信号处理功能允许您创建自己的信号,或者至少它是如何实现的(intercept() 函数)。我对 linux 信
目前我有这个 gtk2 代码: GList *input_devices = gdk_devices_list(); while(input_devices) { GdkDevice *devic
我正在尝试移植 Aether.Physics2D从 C# 到 Xojo 的库。这本质上是 Farseer 物理引擎的调整版本。大部分已经完成,但有一部分源代码我无法解决(可能是因为 C# 不是我的主要
我们正在开发采用 RISCV 架构的多核处理器。 我们已经为单核 RISCV 处理器移植了 Linux,它正在我们自己的基于 FPGA 的主板上使用 busybox rootfs。 我现在想为多核 R
我是一名优秀的程序员,十分优秀!