Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/ant/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Openssl BN_为_零,top==0_Openssl - Fatal编程技术网

Openssl BN_为_零,top==0

Openssl BN_为_零,top==0,openssl,Openssl,在OpenSSL中 #define BN_is_zero(a) ((a)->top == 0) 我不明白。我以为会是这样的 #define BN_is_zero(a) ((a)->top == 1 && (a)->d[0] == 0) 谢谢。这就是OpenSSL如何定义零bignum的。它们不需要浪费一个BN_ULONG,也就是无符号长或无符号长,来存储零。当top为0时,bignum被认为是零。您可以查看bn\u correct\u

在OpenSSL中

#define BN_is_zero(a)       ((a)->top == 0)
我不明白。我以为会是这样的

#define BN_is_zero(a)       ((a)->top == 1 && (a)->d[0] == 0)

谢谢。

这就是OpenSSL如何定义零bignum的。它们不需要浪费一个
BN_ULONG
,也就是无符号长或无符号长,来存储零。当
top
为0时,bignum被认为是零。您可以查看
bn\u correct\u top(a)
,它在
bn\u usub()之前调用。它将更正
top
,以指示
a
使用了多少
BN_ULONG
s。当
a
为零时,
bn\u correct\u top(a)
使
a->top=0
。下面是一个例子:

#include <stdio.h>
#include <openssl/bn.h>

void print_r(BIGNUM *r){
    if (BN_is_zero(r)) {
        printf("r is zero\n");
     } else {
        printf("r is ");
        BN_print_fp(stdout,r);
        printf("\n");
     }
}

int main() {
    BIGNUM *r,*a,*b;

    r = BN_new();
    print_r(r);

    a = BN_new();
    b = BN_new();

    BN_dec2bn(&a,"6");
    BN_dec2bn(&b,"6");

    BN_uadd(r,r,a);
    print_r(r);
    BN_usub(r,a,b);
    print_r(r);

    BN_free(r);
    BN_free(a);
    BN_free(b);

    return 0;
}
请注意,在
r=BN_new()
之后,bignum
r
为零,因为
r->top=0

r is zero
r is 6
r is zero