版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
BIGNUM的创建与释放函数原型解释示例BIGNUM*BN_new(void);创建一个BIGNUM的结构,返回新BIGNUM结构的指针BIGNUM*a=BN_new();voidBN_free(BIGNUM*);释放一个BIGNUMfree(a);
BIGNUM的值测试函数原型解释示例intBN_cmp(BIGNUM*a,BIGNUM*b);|判断a与b是否相等if(BN_cmp(a,b){printf("aequb\n");}<verbatim>intBN_ucmp(BIGNUM*a,BIGNUM*b);判断a与b的绝对值是否相等if(BN_ucmp(a,b)intBN_is_zero(BIGNUM*a);判断a是不是为0if(BN_is_zero(a))intBN_is_one(BIGNUM*a);判断a是不是1if(BN_is_one(a))intBN_is_word(BIGNUM*a,BN_ULONGw);判断a是不是值wif(BN_is_word(a,12))intBN_is_odd(BIGNUM*a);判断a是不是一个奇数if(BN_is_odd(a))
BIGNUM的赋值与取值函数原型解释示例intBN_num_bytes(BIGNUM*a);返回a的字节数printf("length:%d\n",BN_num_tytes(a));intBN_num_bits(BIGNUM*a);返回a的二进制位数printf("bits:%d\n",BN_num_bits(a));intBN_one(BIGNUM*a);设置a为1BN_one(a);intBN_zero(BIGNUM*a);设置a为0BN_zero(a);intBN_bn2bin(constBIGNUM*a,unsignedchar*to);取a为二进制到to中,返回字符串长度chars[1024];intlength=BN_bn2bin(a,s);BIGNUM*BN_bin2bn(constunsignedchar*s,intlen,BIGNUM*ret);赋二进制值s到ret中,返回retchars[]="1001001";BN_bin2bn(s,strlen(s),a);char*BN_bn2hex(constBIGNUM*a);取a的16进制值,返回一个字符串的指针。此指针要使用完后,手动使用OPENSSL_free释放char*p=BN_bn2hex(a);if(p){printf("numberis0x%s\n",p);OPENSSL_free(p);}char*BN_bn2dec(constBIGNUM*a);取a的10进制值,返回一个字符串的指针。此指针要使用完后,手动使用OPENSSL_free释放p=BN_bn2dec(a);intBN_hex2bn(BIGNUM**a,constchar*str);赋16进制值str到*a中,返回成功与否BN_hex2bn(&a,"0x123F23D12");intBN_dec2bn(BIGNUM**a,constchar*str);赋10进制值str到*a中,返回成功与否BN_dec2bn(&a,"1999");
BIGNUM的计算函数原型解释示例intBN_add(BIGNUM*r,constBIGNUM*a,constBIGNUM*b);计算a与b的和,值储存在r中。如果成功,返回1;否则,返回0BIGNUM*a=BN_new(),*b=BN_new(),*r=BN_new();BN_dec2bn(&a,"1234");BN_dec2bn(&b,"2345");BN_add(r,a,b);intBN_sub(BIGNUM*r,constBIGNUM*a,constBIGNUM*b);计算a与b的差,值储存在r中。返回1或者0BN_sum(r,a,b);intBN_mul(BIGNUM*r,BIGNUM*a,BIGNUM*b,BN_CTX*ctx);计算a与b的积,值储存在r中。返回1或者0。ctx为一个上下文相关的结构,可以用BN_CTX_new与BN_CTX_free来创建与释放它BN_CTX*ctx=BN_CTX_new();BN_mul(r,a,b,ctx);BN_CTX_free(ctx);intBN_sqr(BIGNUM*r,BIGNUM*a,BN_CTX*ctx);计算a的平方,值储存在r中。返回1或者0BN_sqr(r,a,ctx);intBN_div(BIGNUM*dv,BIGNUM*rem,constBIGNUM*a,constBIGNUM*d,BN_CTX*ctx);计算a与d的商,值储存在dv中,余数储存在rem中。返回1或者0BN_div(dv,r,a,b);intBN_mod(BIGNUM*rem,constBIGNUM*a,constBIGNUM*m,BN_CTX*ctx);计算a与m的模,值储存在rem中。返回1或者0BN_mod(r,a,m,ctx);intBN_nnmod(BIGNUM*r,constBIGNUM*a,constBIGNUM*m,BN_CTX*ctx);计算a与m的模,并且结果如果小于0,就加上m,值储存在r中。返回1或者0BN_nnmod(r,a,m,ctx);intBN_mod_add(BIGNUM*r,BIGNUM*a,BIGNUM*b,constBIGNUM*m,BN_CTX*ctx);计算a与b的和,再模m,值储存在r中。返回1或者0BN_mod_add(r,a,b,m,ctx);intBN_mod_sub(BIGNUM*r,BIGNUM*a,BIGNUM*b,constBIGNUM*m,BN_CTX*ctx);计算a与b的差,再模m,值储存在r中。返回1或者0BN_mod_sub(r,a,b,m,ctx);intBN_mod_mul(BIGNUM*r,BIGNUM*a,BIGNUM*b,constBIGNUM*m,BN_CTX*ctx);计算a与b的积,再模m,值储存在r中。返回1或者0BN_mod_mul(r,a,b,m,ctx);intBN_mod_sqr(BIGNUM*r,BIGNUM*a,constBIGNUM*m,BN_CTX*ctx);计算a的平方根,再模m,值储存在r中。返回1或者0BN_mod_sqr(r,a,m,ctx);intBN_exp(BIGNUM*r,BIGNUM*a,BIGNUM*p,BN_CTX*ctx);计算a的p次方,值储存在r中。返回1或者0BN_exp(r,a,p,ctx);intBN_mod_exp(BIGNUM*r,BIGNUM*a,constBIGNUM*p,constBIGNUM*m,BN_CTX*ctx);计算a的p次方,再模m,值储存在r中。返回1或者0BN_mod_exp(r,a,p,m,ctx);intBN_gcd(BIGNUM*r,BIGNUM*a,BIGNUM*b,BN_CTX*ctx);计算a与b的最大公约数,值储存在r中。返回1或者0BN_gcd(r,a,b,ctx);intBN_add_word(BIGNUM*a,BN_ULONGw);大数a加上w,值储存在a中,返回1或者0BN_dec2bn(a,"1234");BN_add_word(a,1);intBN_sub_word(BIGNUM*a,BN_ULONGw);大数a减去w,值储存在a中,返回1或者0BN_sub_word(a,23);intBN_mul_word(BIGNUM*a,BN_ULONGw);大数a乘以w,值储存在a中,返回1或者0BN_mul_word(a,2)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026年秦皇岛职业技术学院高职单招职业适应性测试备考试题及答案详解
- 初中历史事件评价教学中人工智能辅助课堂互动策略分析教学研究课题报告
- 2025年福建省宁德市 福安市保安员考试真题附答案解析
- 2025年海北州门源县保安员考试真题附答案解析
- 女性产后康复饮食结构
- 物流消防安全培训课件
- 古典群山古建筑背景的“即是远方心有山海”中国风商务汇报2
- 消防安全检查中心服务
- 车间整改报告
- 河源医疗器械加工协议书
- 二手房定金协议合同
- 2025-2026学年北师大版二年级数学上册期末测试题(含答案)
- 炉渣资源化处理技术方案
- 江苏省2025年普通高中学业水平合格性考试数学试卷(含答案)
- 广东省广州市越秀区2025年七年级上学期期末考试数学试卷附答案
- 大学计算机教程-计算与人工智能导论(第4版)课件 第5章 数据库与信息系统
- 九上历史“资本主义”期末考点押题
- 血液透析护理文件书写规范
- 雅培化学发光销售培训
- 2025年四年级语文知识点总结(全册高频考点)
- 2025年及未来5年市场数据中国工业液压过滤器市场竞争态势及投资战略规划研究报告
评论
0/150
提交评论