一个输出表达式中连续用指针输出遇到的问题

#include<stdio.h>
struct sample{
    int a;
    int *b;
    }s[4]={{1,&s[0].a},{3,&s[1].a},{5,&s[2].a},{7,&s[3].a}},*p;
    
int main()
{
    p=&s[0];
    p++;
    printf("%d,%d\n",p->a,*(++p)->b);

    return 0;
}

我是这样理解的:p++后p指向s[1],那么p->a的值为3;++p后p指向的s[2],(++p)->b是b所指向s[2].a的地址,*(++p)->b就是s[2].a的值;这样的话最后应该输出3 5才对。但是编译运行后却输出了5 5。这是为什么?
还有一个:

#include<stdio.h>

int main()
{
    int i=5;
    int *p=&i;
    printf("%d %d",*p,++(*p));
    
    return 0;
}

这里 *p不就是i的值5,++(*p)不就是i的值5再加1吗,为什么结果却输出了6 6 呢?当我把++(*p) 改成了(*p)++时,输出的是6 5。难道它是先看后面的语句,先输出后面的再输出前面的吗?

逗号表达式从左到右执行,从右往左取值。
其实这里不用记,反正考试没几分,你真正编程的时候,敢在表达式里用++,就要有被砍死的觉悟。
这不是可读性差的问题,在不同编译器下、不同系统下,执行顺序都可能不同,真正写代码没人敢这么写
这完全是考试内卷卷出来的产物