在 C 和 C++ 中选择合适的整数类型

在 c 和 c++ 中选择合适的整数类型

介绍

dennis ritc++hie 创建 c 时,他将 int (有符号整数类型)作为默认类型。 int 的大小(位数)是故意指定的。 即使 c 被标准化,所保证的也只是最小大小。 基本原理是 int 的大小应该是给定 cpu 上整数的“自然”字大小。

如果您只需要较小的有符号整数并且想节省一点空间,ritchie 给了我们short;或者,如果你需要更大的整数,他给了我们 long。 (c99 为我们提供了更大的 long long 整数。)如果您只需要无符号整数,则可以在声明中包含 unsigned。 c99 还为我们提供了特定大小的有符号整数类型别名(例如 int32_t)和无符号类型别名(例如 uint32_t)。

但是,在编程中,大多数时候不需要负整数(因此需要有符号整数类型)。 字符串的长度、对象的数量、对象的大小、文件的大小等都是无符号整数。 需要特定大小的类型别名,甚至少于有符号整数。

然而,我已经看到很多代码不恰当地使用了整数类型。 此类代码可能会向读者(包括几个月后的您自己)传达不明确或误导性的信息。 最好为正确的目的选择正确的整数类型。

立即学习“C++免费学习笔记(深入)”;

指南

以下是我选择整数类型的指南:

表示内存中字节数时,使用 size_t 标准类型别名。

这是 c 和 c++ 标准库使用的类型,例如 memcpy()、strlen()、std::string::size() 等,因此有很多先例。

当表示磁盘上文件的大小或位置时,请使用off_t posix类型别名。

如果您正在处理非常大文件,在某些平台上,您可能需要使用 -d_file_offset_bits=64 进行编译以获得 64 位版本的 off_t。

当表示内存中对象的数量时,也使用 size_t。

这也是 c 和 c++ 标准库使用的类型,例如 fread() 和 fwrite()。

仅当您需要表示包含在特定位数内的值或需要符合特定 api 时,请使用带符号类型的 int8_t、int16_t、int32_t 或 int64_t 类型别名之一;或无符号类型的 uint8_t、uint16_t、uint32_t 或 uint64_t 类型别名之一。

通常需要固定大小的整数的唯一时间是当您“外部化”一个值时,例如,将其写入磁盘或通过套接字发送它。

当您实际上不需要特定位数时使用固定大小的整数会向读者传达错误的信息。

此外:

当表示必须精确指针大小的整数值时,请使用标准 intptr_t 或 uintptr_t 类型别名。

仅当您需要负值时,才使用short、int、long或long long之一,首选int,除非您需要更小或更大的值。

最后:

否则,请使用 unsigned short、unsigned、unsigned long 或 unsigned long long 之一,除非您需要更小或更大的值,否则首选 unsigned。

也就是说,除非您正在处理上面列出的情况之一,否则默认使用无符号类型。

结论

选择正确的整数类型可以向读者传达正确的信息,并且可以消除运行时检查。

结语

最初,直到 c99,int 都是隐式类型,也就是说,如果您根本没有指定任何类型,它就会被理解为 int。 例如:

power( x, n )  /* x and n are int; returns int */{    int p;    for ( p = 1; n > 0; --n )        p *= x;    return p;}

定义一个具有 int 参数并返回 int 的函数,但声明中未使用 int。

函数原型从 c++ 向后移植到 c89,但原始的“k&r 风格”函数定义仍然被允许一直到 c23。 ansi c 委员会是一群保守派。

更奇怪的是,c99 之前的版本还允许 int 隐含在声明中,例如:

i;      // int i*p;     // int *p*a[4];  // int *a[4]*f();   // int *f()

幸运的是,这样的声明早已是非法的。

以上就是在 C 和 C++ 中选择合适的整数类型的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1459166.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月18日 11:14:38
下一篇 2025年12月18日 11:14:52

相关推荐

  • 泛型编程:打造 C++ 代码的通用工具

    泛型编程可让 c++++ 代码独立于数据类型,使用模板实现。具体包括:创建通用的函数,使用类型参数接受不同类型的输入,返回较大值。创建通用的类,使用类型参数存储和检索不同类型的键值对。例如,可以使用泛型函数计算不同形状容器的最大体积,避免针对不同形状编写特定代码。泛型编程的优势包括代码重复利用率高、…

    2025年12月18日
    000
  • 使用 C++ 重载函数提高代码可读性

    c++++ 中的函数重载可提高代码可读性,减少重复代码,并实现面向对象原则。它允许为相似功能创建具有不同参数签名的重载函数,以明确指定不同操作并消除重复代码。 使用 C++ 重载函数提高代码可读性 函数重载是 C++ 中一项有用的特性,它允许我们在同一个函数名下创建具有不同签名(即参数列表)的多个函…

    2025年12月18日
    000
  • C++ 函数的超级进化:发掘constexpr与归一

    c++++中的constexpr和noexcept特性提升了代码性能、简洁性和可移植性。constexpr将函数或变量标记为常量表达式,实现编译时求值,例如计算斐波那契数列。noexcept指示函数不会引发异常,编译器优化调用,例如优化异常处理。 C++ 函数的超级进化:发掘 constexpr 与…

    2025年12月18日
    000
  • C++ 函数重载:深入理解其优势

    函数重载允许在 c++++ 中声明具有相同名称但不同参数列表的函数。优势包括:提高代码可读性减少代码冗余支持多种场景 C++ 函数重载:深入理解其优势 在 C++ 中,函数重载是一种声明具有相同名称但采用不同参数列表的多个函数的能力。这提供了极大的灵活性,使程序员能够根据特定需求定制函数的行为。 优…

    2025年12月18日
    000
  • C++ 函数的进阶指南:匿名函数的使用与滥用

    匿名函数(lambda 表达式)是一种在 c++++ 中创建无名称函数的方式,使用起来简洁灵活,可闭包访问创建函数的局部变量。使用场景:简洁排序:用匿名函数作为比较器,对容器元素排序。条件筛选:用匿名函数作为谓词,筛选满足条件的元素。回调交互:用匿名函数作为回调,与其他代码交互。滥用问题:可读性差:…

    2025年12月18日
    000
  • C++ 函数的艺术:并发编程与多线程,提升程序性能

    如何使用 c++++ 并发库进行并发编程?使用 c++ stl 并发原语,包括:std::thread、std::mutex、std::condition_variable 和 std::future。创建线程、使用互斥锁同步共享资源访问,使用条件变量等待事件,使用 future 处理异步操作。实践…

    2025年12月18日
    000
  • 函数指针与 lambda:C++ 函数式编程的权衡

    函数指针与 lambda 在 c++++ 函数式编程中各有优劣:简洁性:lambda 表达式语法更简洁,尤其是在参数较多或函数体较短的情况下。类型安全:函数指针需要显式类型转换,这可能会导致类型错误。lambda 则提供了类型推断,提高了代码安全性。效率:函数指针可以实现比 lambda 更直接的函…

    2025年12月18日
    000
  • C++ 函数的艺术品:探寻函数式编程与模式匹配

    答案: 在 c++++ 中应用函数式编程和模式匹配可以提高代码质量。详情:函数式编程 (fp) 特性:不修改状态、使用纯函数、强调不可变数据。c++ 中的 fp 技术:lambda 表达式、函数对象、stl。c++20 引入了模式匹配,用于更简洁的数据匹配和分解。实战案例展示了 fp 和模式匹配的应…

    2025年12月18日
    000
  • C++ 函数的进阶指南:多线程注意事项

    C++ 函数的进阶指南:多线程注意事项 引言 在多线程编程中,函数的正确使用至关重要,以确保数据一致性、避免竞争条件和死锁。本文将深入探讨 C++ 函数在多线程环境下的注意事项,并提供实战案例进行说明。 共享变量和互斥锁 立即学习“C++免费学习笔记(深入)”; 当多个线程同时访问共享变量时,会出现…

    2025年12月18日
    000
  • C++ 函数的艺术:内存管理的艺术,避免泄露与访问违规

    c++++ 内存管理至关重要,不当管理会导致内存泄漏和访问违规。内存泄漏是由未释放分配给对象的内存引起的,而访问违规是由尝试访问已释放或无效的内存引起的。为了有效管理内存,可以使用智能指针(如 std::unique_ptr 和 std::shared_ptr),它们自动管理内存,防止泄漏。内存池是…

    2025年12月18日
    000
  • C++ 函数调试的刺客法则:致命精准

    C++ 函数调试的刺客法则:致命精准 在 C++ 开发中,调试函数是确保代码正确性的关键。然而,与变量或对象不同,调试函数具有独特的挑战。本文将揭示 C++ 函数调试的终极法则,帮助你成为无情的调试刺客。 法则 1:使用 GDB 陷阱 GDB 陷阱可以帮助你在函数执行特定点暂时停止代码。这对于诊断堆…

    2025年12月18日
    000
  • C++ 函数调试的涅槃重生:从绝望中崛起

    c++++ 函数调试的涅槃重生之道:使用 gdb 调试器,提供逐步执行、检查变量和设置断点等功能。使用 lldb 调试器,具有图形界面和 python 脚本自动化功能,操作更灵活。实战案例:用 gdb 调试 calculate_average 函数,发现输入为空时 sum 未定义,添加默认值解决问题…

    2025年12月18日
    000
  • C++ 函数的锋利边缘:剖析函数指针与函数变量

    函数指针和函数变量在 c++++ 中非常强大,但使用不当也会带来问题。函数指针存储指向函数地址的变量,而函数变量存储实际函数定义。它们在回调函数和事件处理等场景中很有用,但需要仔细使用以避免空指针引用、类型不匹配和内存泄漏等问题。最佳实践包括检查空值、仔细检查类型并使用智能指针管理生存期。 C++ …

    2025年12月18日
    000
  • C++ 函数的进阶指南:内存分配最佳实践

    c++++ 函数中内存分配最佳实践包括:使用智能指针自动管理内存分配,如 std::unique_ptr、std::shared_ptr 和 std::weak_ptr。使用内存池预先分配内存块,提高内存分配性能并减少碎片。使用分配器自定义内存分配行为,控制粒度、对齐方式等属性。避免内存泄漏,在退出…

    2025年12月18日
    000
  • C++ 函数调试的疗养院:修复破损的代码

    c++++ 函数调试技巧:使用断点设置陷阱分而治之阅读编译器消息输入/输出检查使用调试器寻找模式求助于他人 C++ 函数调试的疗养院:修复破损的代码 在 C++ 编程中,函数是代码的基本构建块。然而,当函数行为不佳时,调试它们可能会让人抓狂。本文将提供一系列经过实战验证的技巧,帮助您修复病态函数,恢…

    2025年12月18日
    000
  • C++ 函数的进阶指南:constexpr 的威力

    c++++ constexpr 关键字允许在编译时计算函数表达式。其优势包括编译时计算、内存开销更低、代码重构和优化编译器。应用场景包括查找表初始化、元编程和模板元编程。 C++ 函数的进阶指南:constexpr 的威力 简介 C++11 引入了 constexpr 关键字,它允许在编译时计算函数…

    2025年12月18日
    000
  • 使用 C++ 重载函数处理不同参数类型

    函数重载允许使用相同函数名,但不同参数列表处理不同类型参数。#include 提示:可用于函数名称空间重载return_type function_name(parameter_list)实战案例:计算不同形状面积的函数 area。 使用 C++ 重载函数处理不同参数类型 函数重载允许我们在不同的参…

    2025年12月18日
    000
  • 指针和 lambda:C++ 函数式编程的双刃剑

    指针和 lambda 可在 c++++ 中用于编写函数式代码,但结合使用时须注意以下潜在风险:悬空指针: lambda 捕获的局部变量超出作用域后仍被调用,导致指针失效。数据竞争: 多线程同时访问捕获的数据,引发竞态条件。内存泄漏: 捕获的指针在 lambda 执行后不再使用,造成内存泄漏。为避免这…

    2025年12月18日
    000
  • C++ 函数式编程的心路历程:指针与 lambda 的更迭

    c++++ 函数式编程历经指针时代(采用函数指针)和 lambda 表达式时代(使用 lambda 表达式定义和传递函数)。lambda 表达式更简洁紧凑,提高代码可读性,在现代 c++ 函数式编程中更受欢迎。指针仍提供低级内存模型访问优势,但 lambda 表达式简化了比较逻辑等操作,例如查找容器…

    2025年12月18日
    000
  • 从指针到 lambda:C++ 函数发展的里程碑

    c++++ 的函数发展历经了指针、引用和 lambda 表达式三个里程碑:指针允许函数间接访问和修改变量的值。引用提供了一种更安全的方式来访问变量,指向变量本身而不是其地址。lambda 表达式是匿名函数语法,简化了函数的定义和传递。 从指针到 Lambda:C++ 函数发展的里程碑 前言 函数是 …

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信