前置增量和后置增量哪个更好?

现在的编译器已经足够聪明了,它们根据需求优化代码。 post 和 pre-increment 都有自己的重要性,我们需要根据要求使用它们。如果您通过字符指针逐字节读取闪存,那么在这里您必须使用后增量,否则将跳过数据的第一个字节。在预递增的情况下,指向地址将先递增,然后再读取该值。
在下面的示例代码中,创建一个字符数组并使用想要读取数组值的字符指针。但是如果使用预增量运算符会发生什么? 这个问题的答案是“A”将被跳过而 B 将被打印出来。

#include <stdio.h>
int main(void)
{
    char acData[5] = {'A','B','C','D','E'};
    char *pcData = NULL;
    pcData = acData;
    printf(%c ,*++pcData);
    return 0;
}

输出:B

但是如果使用后增量代替前增量,那么问题就会得到解决,将得到 A 输出

#include <stdio.h>
int main(void)
{
    char acData[5] = {'A','B','C','D','E'};
    char *pcData = NULL;
    pcData = acData;
    printf(%c ,*pcData++);
    return 0;
}

输出:A

除此之外,当我们需要一个循环或者只需要递增操作数时,预递增比后递增要好得多,因为在后递增的情况下,编译器可能已经创建了旧数据的副本,这需要额外的时间。 这不是 100% 正确的,因为现在编译器非常聪明,以一种在前后增量之间没有区别的方式优化代码。 所以建议,如果不需要后增量,那么必须使用前增量。

注意:一般后置增量与数组下标和指针一起使用来读取数据,否则如果不需要,则使用 pre 代替后置增量。 一些编译器还提到避免在循环条件中使用后增量。
iLoop = 0

while (a[iLoop ++] != 0)
{
// Body statements
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


在C语言中声明变量:变量声明仅在编译时向编译器提供以给定类型和名称存在的变量的确定性,以便编译器继续进行进一步编译,而不需要该变量的所有细节。 在 C 语言中,当我们声明一个变量时,我们只将信息提供给
全局变量和静态全局变量有不同的联系。 这就是全局变量可以在文件外部访问但静态全局变量只能在声明它的文件内访问的原因。
存储类决定程序中变量或函数的范围(生命周期)和范围(可见性)。 每个变量都在内存中的某个位置以位的形式存储变量的值。 存储类决定这些变量值将存储在 CPU 寄存器、堆栈内存、BSS 或 DS 中的位置。
在C语言中,外部静态变量有内部链接,内部静态变量没有链接。 这就是它们具有不同范围但两者都将在整个程序中存活的原因。
让我们先来看一下 typedef 和宏的简短描述,以了解它们之间的区别。 typedef C语言提供了一个非常重要的关键字 typedef,用于为现有类型定义新名称。 typedef 是编译器指令,主要与用户定义的数据类型(结构、联
编译器错误。 解释:typedef 已被视为部分存储类,因此不能一次混合两个存储类。
C语言中的变量定义了一个位置名称,可以在其中放置值,并且可以在程序中需要时使用这些值。 换句话说,可以说变量是一个名称(或标识符),它指示内存中的某个物理地址,其中数据以字符串位的形式存储。
变量 p 对应的声明如下: 1. int p; // An integer 2. int p[5]; // An array of 5 integers 3. int *p; // A pointer to an integer
数据类型是数据的分类,它告诉编译器或解释器程序员打算如何使用数据。 换句话说,您可以说它定义了变量的大小(BYTE)和范围。C语言中数据类型的分类:1、预定义数据类型(int、char、float等)2、用户定义的数据类
在 C 语言中,static 关键字非常重要。 如果在变量或函数中使用了 static 关键字,那么只有内部链接或无链接有效。1、静态变量只初始化一次,因此在函数体内声明为静态的变量在函数调用之间保持其先前值。2、带
C语言有3种链接,外部链接、内部链接和无链接。
可以,我们可以在头文件中声明静态变量。
C标准解释了整数的最小大小应该是 16 位。 一些编程语言解释说整数的大小取决于实现,但可移植程序不应该依赖它。整数的大小主要取决于编译器编写者为底层处理器编写的编译器类型。可以看到编译器根据便利性和底
在标准 C 语言中,整数数据类型默认是有符号的。 所以如果创建一个整数变量,它可以存储正值和负值。
有符号和无符号整数类型具有相同的存储(根据标准至少 16 位)和对齐方式,但它们仍然存在很多差异,在下面的行中,描述有符号和无符号整数之间的一些差异。
宏和函数的区别如下所示:
输出:编译器错误。说明: 扩展宏时,var 将被替换为 0(Rvalue)。 因为正在尝试增加 Rvalue,所以将收到编译器错误。
C语言中的枚举是用户定义的数据类型。 它由一组命名的常量整数组成。 使用 enum 关键字,我们可以通过使用枚举标签(可选)和命名整数列表来声明枚举类型。基本上,我们使用枚举来增加代码的可读性,并且与符号常
const 限定符仅向编译器指示无法更改限定对象的值。 简单来说, const 表示不可修改(不能在运行时给对象赋值)。
在程序中有以下地方需要使用 const 关键字: 在引用函数参数调用中,如果不想更改已传入函数的实际值。