我第一次使用 GMP lib ,看起来这段代码做了一些脏内存作弊:
void addition (const point p,const point q,const mpz_t fp, point* result){
mpz_t ld;
mpz_init(ld);
lambda_add(p,q,fp,ld);
gmp_printf( "WTFCHECK1: %Zx, %Zx\n", p.x ,p.y);
mpz_mul(result->x,ld,ld);
gmp_printf( "WTFCHECK2: %Zx, %Zx\n", p.x ,p.y);
mpz_sub(result->x,result->x,p.x);
gmp_printf( "WTFCHECK3: %Zx, %Zx\n", p.x ,p.y);
...
}
lambda看起来像
void lambda_add (const point p,const point q,const mpz_t fp, mpz_t result){
mpz_t ydiff,xdiff;
mpz_init (ydiff);
mpz_init (xdiff);
mpz_sub (ydiff,q.y,p.y);
mpz_sub (xdiff,q.x,p.x);
...//no more usage of p or q
}
但程序输出仍然如下:
WTFCHECK1: 7cf27b188d034f7e8a52380304b51ac3c08969e277f21b35a60b48fc47669978, 7775510db8ed040293d9ac69f7430dbba7dade63ce982299e04b79d227873d1
WTFCHECK2: de8a6886d284cb85d49a93b707475ed3d277242444ba9e860207f9a59a9ef351, 7775510db8ed040293d9ac69f7430dbba7dade63ce982299e04b79d227873d1
正如您所看到的, mpz_t 的变量px (x和y是 typedef结构点中的mpz_t类型)在没有我的情况下发生了变化分配任何东西。这种行为的原因是什么?感谢。
答案 0 :(得分:0)
好吧,D问题有点在我身边,我在打电话
addition (const point p,const point q,const mpz_t fp, point* result)
具有与点p和点*结果相同的结构,因此除了修改结果,我还修改了点p。无论如何,我感谢你的帮助。