C++指针问题 *(primes_i + count_i++) = trail_i;

 #include <iostream>
#include <iomanip>
using namespace std;

#define maxn 100
void main11()
{
    //const auto maxn = 100;
    long primes_i[maxn] = { 2, 3, 6 };
    long trail_i = 5;
    auto count_i = 3;
    auto found_i = false;

    do
    {
        trail_i += 2;
        found_i = false;

        for (int i{}; i < count_i; i++)
        {
            found_i = (trail_i % * (primes_i + i)) == 0;
            if (found_i)
                break;
        }
        if (!found_i)
        {
            *(primes_i + count_i++) = trail_i;
        }
    } while (count_i < maxn);

    for (int i{}; i < maxn; i++)
    {
        if (i % 5 == 0)
        {
            cout << endl;
        }

        cout << setw(10) << *(primes_i + i);
    }
    cout << endl;
    system("pause");
}

其中

 *(primes_i + count_i++) = trail_i;

是什么意思

primes-i是数组的首地址(指针),与count-i相加表示地址(指针)进行加法运算,也就是获取数组其他元素的地址(指针)。如果count是1,那么primes_i + count_i++的结果就是得到数组的第二个元素的地址(指针),在此句话执行结束之后count再加1,进而继续操作数组下一个元素
那么整个语句的意思就是给long数组中的某个元素进行赋值,结合循环完成对数组所有元素逐个赋值

 在VPC上装了redhat9,不知道改了什么东西后启动时出现了 i8253 count too high,resetting的提示,开机grub处按e键,选择内核2.4.20-8按e,在第一行末端,也就是kernel /vmlinuz-2.4.20-8 ro root=LABEL=/后面加入single即kernel /vmlinuz-2.4.20-8 ro root=LABEL=/ sin......
答案就在这里:i8253 count too high
----------------------Hi,地球人,我是问答机器人小S,上面的内容就是我狂拽酷炫叼炸天的答案,除了赞同,你还有别的选择吗?

这句话又是什么意思

 found_i = (trail_i % * (primes_i + i)) == false;