除0错检测器
目录
DIVALARM - 实验要求
DIVALARM - 环境配置
DIVALARM - 基础运行
DIVALARM - LLVM基本指令结构
DIVALARM - 可达定义与污点分析
DIVALARM - 代码实现
DIVALARM - 问题
实验要求
基于LLVM和Z3,在基本的代码框架下,实现一个基于数据流分析的简单C程序和除0错漏洞分析器。
环境配置
- 安装llvm
- 下载z3 配置系统环境
版本号
软件 | 版本 |
---|---|
llvm | 8.0.1 |
z3 | 4.7.1 |
开发软件
Clion
基础运行
- 导入动态库搜索路径
- 如果在build下添加libz3.dylib文件(mac下,linux下为.so,windows下为.dll)
- 添加动态库搜索路径
export DYLD_LIBRARY_PATH=../build
- 运行
cd test
clang -emit-llvm -S -fno-discard-value-names -c xxx.c
../build/constraint xxx.ll
LLVM基本指令结构
- Alloca
%x = alloca i32, align 4
为变量分配空间
2. Store
// store Ins : store [volatile] <ty> <value>, <ty>* <pointer>
store i32 0, i32* %retval, align 4
store i32 %1, i32* %y, align 4
向变量中存储值, 第一个变量是value,第二个是pointer
3. Call
%call = call i32 (…) @tainted_input()
函数调用
4. Load
// loadIns: load [volatile] <ty>, <ty>* <pointer>
%1 = load i32, i32* %x, align 4
将pointer中的值复制到变量中,例子是将%x的值赋值到%1.
- BinaryOperator
%5 = add i32 %4, 2
在我们的例子中,它指向一个代表数字2的Constant对象和另一个对应于寄存器%4的Instruction,(由于LLVM IR采用静态单一赋值形式,所以寄存器和Instruction其实是一个整体。寄存器号码是文本表示的产物。
- ret
ret i32 %4
返回变量 %4的值
- branch
- 有条件
br i1 %cmp, label %if.then, label %if.else
根据%cmp判断跳转,如果是真则跳转到标签%if.then
- 无条件
br label %if.end
直接跳转到%if.end
8. Cmp
%cmp = icmp sgt i32 %0, 2
比较指令
9. SExt
%idxprom = sext i32 %3 to i64
符号拓展
10. Getelementptr - inbounds
%arrayinit.begin = getelementptr inbounds [1 x [6 x i32]], [1 x [6 x i32]]* %a, i64 0, i64 0
- 为了得到复合数据结构子元素的地址。
- 仅仅执行地址计算,不访问内存。
- 还可用于计算地址的向量。
- 第一个参数始终是用作计算基础的类型。
- 第二个参数始终是指针或指针向量,并且是从中开始的基址。
可达定义与污点分析
关系定义
可达定义
- Def(X,Y): 变量X在指令Y处定义
- Use(X,Y): 变量X在指令Y处被使用
- Next(X,Y): 指令Y是指令X的后继
- Gen(Y,X): 定义X通过指令Y生成
污点分析
- Def(X,Y): 变量X在指令Y处定义
- Use(X,Y): 变量X在指令Y处被使用
- In(X,Y): 数据流X可以到达Y
- Taint(X): 指令X处存在一个污染函数
- Sanitizer(X): 指令X处存在一个保护函数(不被污染)
- Div(X,Y): 指令Y处存在一个除法指令,除数是X
规则定义
可达定义
- KILL(X,Z) :- Def(X,Y) && Def(X,Z)
- Out(X,Y) :- Gen(Y,X)
- Out(X,Y) :- In(X,Y) && !KILL(X,Y)
- In(X,Y) :- Out(X,Z) && Next(Z,Y)
污点分析
- Edge(Y,Z) :- Def(X,Y) && Use(X,Z) && In(X,Z)
- Path(X,Y) :- Edge(X,Y) && Taint(X)
- Path(X,Z) :- Path(X,Y) && Edge(Y,Z) && !Sanitizer(Y)
- Alarm(Z) :- Path(Y,Z) && Div(X,Z)
代码框架分析
文件分析
- include文件夹
- Utils.h
工具函数的头文件 - Extractor.h
定义了Extractor class。 内含Z3不动点,规则关系提取方法,不动点求解方法。
- src文件夹
- Constraint.cpp
主函数所在文件。代码主要流程如下:
定义规则关系提取器
初始化规则和关系
z3不动点求解器初始化
添加fact
运用Z3求解器进行求解
(我们主要实现初始化规则和关系 以及 添加fact) - Uitils.cpp
一些方法的实现:
将llvm指令类转化为字符串
获取llvm指令的前继指令
判断指令是否有污点函数
判断指令是否有保护函数 - Extractor.cpp
该文件是初始化规则和关系以及fact的实现处
执行流程分析
通过 clang llvm工具将.c文件生成为 .ll的llvm中间代码。
constraint 首先读取 .ll文件提取规则和关系。
其次开始根据llvm代码添加事实
利用Z3不动点进行求解。
如果Alarm存在满足的条件则会报除0错。
代码实现
规则添加
根据可达定义和污点分析的规则添加如下规则:
z3::expr X = C.bv_const(“X”, 32);
z3::expr Y = C.bv_const(“Y”, 32);
z3::expr Z = C.bv_const(“Z”, 32);z3::expr r1 = z3::forall(X, Y, Z,z3::implies(Def(X, Y) && Def(X, Z), Kill(X, Z)));
z3::expr r2 = z3::forall(X, Y,z3::implies(Gen(Y, X), Out(X, Y)));
z3::expr r3 = z3::forall(X, Y,z3::implies(In(X, Y) && !Kill(X, Y), Out(X, Y)));
z3::expr r4 = z3::forall(X, Y, Z,z3::implies(Out(X, Z) && Next(Z, Y), In(X, Y)));z3::expr t1 = z3::forall(X, Y, Z,z3::implies(Def(X, Y) && Use(X, Z) && In(X, Z), Edge(Y, Z)));
z3::expr t2 = z3::forall(X, Y,z3::implies(Edge(X, Y) && Taint(X), Path(X, Y)));
z3::expr t3 = z3::forall(X, Y, Z,z3::implies(Path(X, Y) && Edge(Y, Z) && !Sanitizer(Y), Path(X, Z)));
z3::expr t4 = z3::forall(X, Y, Z,z3::implies(Path(Y, Z) && Div(X, Z), Alarm(Z)));Solver->add_rule(r1, C.str_symbol(“KILL”));
Solver->add_rule(r2, C.str_symbol(“OUT_1”));
Solver->add_rule(r3, C.str_symbol("OUT_2"));
Solver->add_rule(r4, C.str_symbol(“IN”));
Solver->add_rule(t1, C.str_symbol("EDGE”));
Solver->add_rule(t2, C.str_symbol("PATH_1"));
Solver->add_rule(t3, C.str_symbol("PATH_2"));
Solver->add_rule(t4, C.str_symbol(“ALARM”));
事实添加
针对不同指令添加相应的事实。在这里只大概列出几条指令事实添加的范例:
// loadIns: load [volatile] <ty>, <ty>* <pointer>
if (LoadInst *LI = dyn_cast<LoadInst>(I)) {//std::cout << toString(LI->getPointerOperand()) <<“\n”;//std::cout << toString((Value *)&*I) << “\n”;addDef(InstMap, LI, LI);addUse(InstMap, LI->getPointerOperand(), LI);addGen(InstMap, LI, LI);
}// call Ins
if (CallInst *CI = dyn_cast<CallInst>(I)) {if (isTaintedInput(CI)) {addTaint(InstMap, CI);}if (isSanitizer(CI)) {addSanitizer(InstMap, CI);}if (CI->getCalledFunction()->getName().equals(“not_sanitizer”)) {addTaint(InstMap, CI);}if (CI->getCalledFunction()->getName().equals("untainted_input")) {addSanitizer(InstMap, CI);}addGen(InstMap, CI, CI);addDef(InstMap, CI, CI);
}
数组除0错
代码同时对数组中的元素支持除0错判断:
比如如下代码:
int x = tainted_input();
int z = 5;
int a[6] ={{1,1,4,1,x,1}};
//int k = sanitizer(x);
int y;
for(int i=1;i<3;i++){y = z/a[i];
}
数组中存在污点元素,虽然循环中不会到达污点元素,但是只要使用到了数组都会报除0错。
实现思路:
数组元素赋值时:
%arrayinit.element2 = getelementptr inbounds i32, i32* %arrayinit.element, i64 1
store i32 4, i32* %arrayinit.element2, align 4
追溯到数组的源头(整个数组的基地址):
while (GetElementPtrInst *PreIns = dyn_cast<GetElementPtrInst>(To)) {To = PreIns->getPointerOperand();
}
找到数组定义:
%a = alloca [1 x [6 x i32]], align 16
对数组添加规则:
addGen(InstMap, SI, To);
addDef(InstMap, To, SI);
如果在除数处使用到数组:
%arrayidx6 = getelementptr inbounds [6 x i32], [6 x i32]* %arrayidx, i64 0, i64 %idxprom
%4 = load i32, i32* %arrayidx6, align 4
%div = sdiv i32 %2, %4
会将整个污点的数据流传递至除数从而报除0错。
这种思路不能精确到数组具体元素报除0错,只能检测当数组元素中存在0元素时,存在某处用了数组元素当除数是,才会报错。
结果分析
在给定的代码框架中,其中test有部分测试,Alarm显示全部正常。同时加入自己写的数组和指针的测试。测试结果如下:
simple0/1
//simple0.c
int main() {int x = tainted_input();int y = x;int z = 4 / y; // alarmreturn 0;
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-O5Oxj2DS-1596422466103)(%E6%88%AA%E5%B1%8F2020-06-18%20%E4%B8%8B%E5%8D%887.14.07.png)]
//simple1.c
int main(int argc, char **argv) {int x = tainted_input();int y = sanitizer(x);int z = 4 / y; // safey = not_sanitizer(x);z = 4 / y; // alarmreturn 0;
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BMjbuFBS-1596422466105)(%E6%88%AA%E5%B1%8F2020-06-18%20%E4%B8%8B%E5%8D%887.15.12.png)]
loop0/1
//loop0.c
int main(int argc, char **argv) {int x;int y;x = 0;while (argc > 1) {x = tainted_input();y = x;argc--;}int z = 4 / y; // alarm
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-EOKxeQlD-1596422466106)(%E6%88%AA%E5%B1%8F2020-06-18%20%E4%B8%8B%E5%8D%887.33.07.png)]
//loop1.c
int main(int argc, char **argv) {int x;int y = tainted_input();x = 0;while (x > 0) {y = sanitizer(y);}int z = 4 / y; // alarm
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fu1P4mYV-1596422466107)(%E6%88%AA%E5%B1%8F2020-06-18%20%E4%B8%8B%E5%8D%887.34.45.png)]
branch0/1
//branch0.c
int main(int argc, char **argv) {int x;int y;if (argc > 2) {x = 0;y = x;} else {x = tainted_input();y = x;}int z = 4 / y; // alarm
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TqUgVQWa-1596422466109)(%E6%88%AA%E5%B1%8F2020-06-18%20%E4%B8%8B%E5%8D%887.35.48.png)]
//branch1.c
int main(int argc, char **argv) {int x = tainted_input();int y;if (argc > 2) {x = 0;y = sanitizer(x);} else {y = not_sanitizer(x);}int z = 4 / y; // alarm
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vRgjgmJl-1596422466110)(%E6%88%AA%E5%B1%8F2020-06-18%20%E4%B8%8B%E5%8D%887.36.32.png)]
//branch2.c
int main(int argc, char **argv) {int x = tainted_input();int y;if (1) {y = 0;} else {y = 100;}int z = 4 / y; // alarm
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XG9b21yH-1596422466111)(%E6%88%AA%E5%B1%8F2020-06-18%20%E4%B8%8B%E5%8D%887.37.55.png)]
array
//array.c
int main(int argc, char **argv) {int x = tainted_input();int z = 5;int a[1][6] ={{1,1,4,1,x,1}};//int k = sanitizer(x);int y;for(int i=1;i<3;i++){y = z/a[0][i];}
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DVVQY8IV-1596422466112)(%E6%88%AA%E5%B1%8F2020-06-18%20%E4%B8%8B%E5%8D%887.39.12.png)]
//array1.c
int main(int argc, char **argv) {int x = tainted_input();int z = 5;int a[3] ={1,x,10000};//int k = sanitizer(x);int y;for(int i=0;i<3;i++){y = z/a[i];}
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-s5822VXP-1596422466113)(%E6%88%AA%E5%B1%8F2020-06-18%20%E4%B8%8B%E5%8D%888.11.06.png)]
//array2.c
int main(int argc, char **argv) {int x = tainted_input();int z = 5;int a[3];a[0] =1;a[1]=2;a[2]=0;//int k = sanitizer(x);int y;for(int i=0;i<3;i++){y = z/a[i];}
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qUn7GHOz-1596422466114)(%E6%88%AA%E5%B1%8F2020-06-18%20%E4%B8%8B%E5%8D%888.32.32.png)]
问题
在进行数组测试时候,如果数组已经复制好初值类似于以下代码
int a[3]={1,1,0};
此时在llvm-ir中,其代码如下:
%a = alloca [3 x i32], align 4
……
%0 = bitcast [3 x i32]* %a to i8*
call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 4 %0, i8* align 4 bitcast ([3 x i32]* @__const.main.a to i8*), i64 12, i1 false)
因此无法检测a中的初值0。
而如果代码类似于以下:
int a[3];
a[0] = 1;
a[2] = 1;
a[3] = 0;
在llvm-IR中代码如下:
%a = alloca [3 x i32], align 4
……
%arrayidx = getelementptr inbounds [3 x i32], [3 x i32]* %a, i64 0, i64 0
store i32 1, i32* %arrayidx, align 4
%arrayidx1 = getelementptr inbounds [3 x i32], [3 x i32]* %a, i64 0, i64 1
store i32 2, i32* %arrayidx1, align 4
%arrayidx2 = getelementptr inbounds [3 x i32], [3 x i32]* %a, i64 0, i64 2
store i32 0, i32* %arrayidx2, align 4
因此可以通过store指令来检测初值。
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- Pandas 基础
一、对Pandas库认识 pandas(panel data & data analysis),是基于 numpy(提供高性能的矩阵运算)专门用于数据分析的工具,是一个强大的分析结构化数据(表格数据)的工具集,能够用于数 据挖掘和数据分析,同时也提供数据清洗功能 1、DataFramename age groupstu0 张某…...
2024/5/2 7:15:34 - vue路由跳转的方式
vue路由跳转有四种方式router-linkthis.$router.push() (函数里面调用)this.$router.replace() (用法同push)this.$router.go(n)一、不带参 1.1 router-link//name,path都行, 建议用name // 注意:router-link中链接如果是/开始就是从根路由开始,如果开始不带/,则从当前路由…...
2024/4/24 21:07:28 - 美好开发,从DTO开始,java的DTO与实体类的区别
表现层与应用层之间是通过数据传输对象(DTO)进行交互的,数据传输对象是没有行为的POCO对象,它 的目的只是为了对领域对象进行数据封装,实现层与层之间的数据传递。为何不能直接将领域对象用于 数据传递?因为领域对象更注重领域,而DTO更注重数据。不仅如此,由于“富领域…...
2024/4/13 15:59:32 - CentOS7.6 安装 redis6.0.6 maven3.6
博客参考:https://blog.csdn.net/qq_35992900/article/details/82950157cd /opt wget http://download.redis.io/releases/redis-6.0.6.tar.gz tar -zxvf redis-6.0.6.tar.gz cd redis-6.0.6 makemake出现问题:【原因:gcc版本过低】yum -y install centos-release-sclyum -y…...
2024/5/2 7:57:09 - Scratch编程(八)扩展模块:文字朗读模块
文字朗读是最基础的人工智能插件。在我们日常生活中,例如排队叫号,车站报播,高铁报站等等,或者是比较智能的机器人,与人的语音交互,都是以文字朗读为技术底层进行实现的。文字朗读作用就是:将文字转换成语音,Scratch3.0中的文字朗读模块,除了支持中文朗读,还支持其他…...
2024/4/20 23:27:19 - 软件基本功:重构工作的考虑及执行
手头工作非常之多。按照重要性的排序,吾决定着手重构WP。WP代码量非常之多(未统计,怎么也超过10万行),工作思路吾很清楚,如何进行具体操作,却不是几句话能解决的。于是吾就考虑,如何下手?有以下要考虑的地方:准备工作这一阶段的修改,是为了后续重构,所以不能影响功…...
2024/4/23 18:14:47 - 消息队列常见的 5 个应用场景
消息队列常见的 5 个应用场景消息队列中间件是分布式系统中重要的组件,主要解决应用耦合,异步消息,流量削锋等问题。实现高性能、高可用、可伸缩和最终一致性架构。使用较多的消息队列有ActiveMQ、RabbitMQ、ZeroMQ、Kafka、MetaMQ、RocketMQ。消息队列应用场景以下介绍消息…...
2024/4/10 11:25:15 - Verilog有哪些运算符及其优先级
目录1、算术运算符2、关系运算符3、 逻辑运算符4、 条件运算符5、位运算符6、 移位运算符7、 拼接运算符8、运算符的优先级Verilog中的运算符 按照功能可以分为下述类型:1、算术运算符、2、关系运算符、3、逻辑运算符、4、条件运算符、5、位运算符、6、移位运算符、7、拼接运算…...
2024/4/11 21:16:43 - apache的mod_php5和fastcgi
SAPI提供了一个和外部通信的接口,使得PHP可以和其他应用进行交互数据。对于一个基于apache的php应用,其运行流程可以简单归结如下mod_phpmod_php是在lamp体系中最常使用的工作方式。在这种模式下,php被编译为apache的一个内置模块,在启动时加载。当有一个php请求过来时,直…...
2024/4/23 14:23:21 - springboot部署
springboot部署项目成jar到tomcatidea上 项目路径 mvn clean package -Dmaven.test.skip=true 前端webstorm npm run build --qa jar放到lib目录 打开cmd 运行 java -Dspring.profiles.active=dev -jar zsdae.jar 最后面是文件名...
2024/4/17 16:03:53 - 获取秒级股票详细数据——Ajax-hook
获取秒级股票详细数据——Ajax-hook 1、分析数据 首先看看有哪些数据可以获取 网站:雪球网,随便打开一只股票可以发现,在工作日期间,每隔几秒都会有这么多xhr请求。 看看里面有一些什么数据。仔细研究可以发现,基本上页面上的数据都可以找到,除了实时的ticks数据,还有什…...
2024/4/11 21:16:40 - MySQL基数(索引基数)
基数是数据列所包含的不同值的数量。例如,某个数据列包含值1、3、7、4、7、3,那么它的基数就是4。索引的基数相对于数据表行数较高(也就是说,列中包含很多不同的值,重复的值很少)的时候,它的工作效果最好。如果某数据列含有很多不同的年龄,索引会很快地分辨数据行。如果…...
2024/4/11 21:16:39 - 成功案例讲解企业如何数据质量管理
上篇文章我们详细讲解了数据质量管理的整个流程,今天我们主要用真实成功案例,为大家讲解企业如何进行数据质量管理。当我们企业决定数据质量管理了,有哪些建议呢?1、建立统一的数据标准有了统一的数据标准后,数据录入采集、加工处理等诸过程都将按照标准要求进行,数据混乱…...
2024/4/22 15:46:33 - torch.optim.lr_scheduler:调整学习率之CosineAnnealingWarmRestarts()参数说明
参考博主关于torch学习率调整的文章,写的非常好。https://blog.csdn.net/qyhaill/article/details/103043637,但是CosineAnnealingWarmRestarts()学习率调整博主没有写,在此借用博主的代码,补充一下此函数的学习率调整曲线。对于此函数,官方解释如下:链接地址https://pyt…...
2024/4/24 5:20:59 - MySQL MGR单主模式搭建
备注:测试数据库版本为MySQL 8.0 这个blog我们来聊聊MySQL 组复制 文章目录概述一.部署单主模式组复制1.1 安装MGR插件1.2 准备配置文件1.3重启mysql服务1.4启动组复制1.4.1 创建复制用户1.4.2 配置用于新成员与捐赠者之间异步复制的复制通道1.4.3 启动组复制1.4.4 确认组复制是…...
2024/4/17 16:03:57 - 剑指OFFER41
剑指OFFER41在C++中使用priority_queue类型变量 //升序队列:先弹出的值是最小值,保留最大值在队列中 priority_queue <int,vector,greater > q; //降序队列:先弹出的值是最大值,保留最小值在队列中,默认为less priority_queue <int,vector,less >q; small_hea…...
2024/4/24 10:54:34 - 类加载子系统
类加载子系统自己制作的jvm中类加载子系统的思维导图,免费分享,每个知识点中皆有详细的博文,内含详细的解释 思维导图链接...
2024/4/11 21:16:34 - Sogou news-数据集
2,909,551 篇来自 SogouCA 和 SogouCS 新闻语料库 5 个类别的新闻文章。每个类别分别包含 90,000 个训练样 本和 12,000 个测试样本。这些汉字都已经转换成拼音。This article offers an empirical exploration on the use of character-level convolutional networks (ConvNet…...
2024/4/24 9:50:14 - Spring Boot的简单理解
Spring Boot Spring Boot 是构建所有基于Spring的应用程序的起点。Spring Boot也是通过最少的Spring前期配置使您尽快启动运行。 Spring整合了所有的框架。它的核心设计思想是:约定大于配置,Spring Boot所有开发细节都是依据此思想进行实现的。 Spring Boot是一套全新的框架,…...
2024/4/25 10:40:53 - TX2安装torchvision0.5.0(实测有效)
https://blog.csdn.net/qq_37144530/article/details/106412551...
2024/4/11 21:16:31
最新文章
- LeetCode 98.验证二叉搜索树
题目描述 给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下: 节点的左 子树 只包含 小于 当前节点的数。节点的右子树只包含 大于 当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。 示例 1ÿ…...
2024/5/2 19:18:00 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - 【Android】【root remount】【2】如何判断设备是否remount
前言 高版本的android设备,在remount之后,如果再进行ota升级,会产生异常,从而无法升级成功。 如何判断设备是否remount 当前已android 10 平台为例 当我们执行 adb remount 时,系统调用会调用到system/core/adb/dae…...
2024/4/30 9:19:47 - STM32实现软件SPI对W25Q64内存芯片实现读写操作
先看看本次实验的成果吧: 这么简单的一个程序,我学习了一个星期左右,终于把所有的关节都打通了。所有代码都能什么都不看背着敲出来了。为了使自己的记忆更为清晰,特意总结了一个思维导图,感觉自己即便是日后忘记了看一…...
2024/5/1 12:08:49 - Redis 教程系列之Redis 性能测试(七)
Redis 性能测试 Redis 性能测试是通过同时执行多个命令实现的。 语法 redis 性能测试的基本命令如下: redis-benchmark [option] [option value] 注意:该命令是在 redis 的目录下执行的,而不是 redis 客户端的内部指令。 实例 以下实例…...
2024/4/29 3:01:07 - 416. 分割等和子集问题(动态规划)
题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义:dp[i][j]表示当背包容量为j,用前i个物品是否正好可以将背包填满ÿ…...
2024/5/2 11:19:01 - 【Java】ExcelWriter自适应宽度工具类(支持中文)
工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...
2024/5/2 16:04:58 - Spring cloud负载均衡@LoadBalanced LoadBalancerClient
LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon,直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件,我们讨论Spring负载均衡以Spring Cloud2020之后版本为主,学习Spring Cloud LoadBalance,暂不讨论Ribbon…...
2024/5/1 21:18:12 - TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案
一、背景需求分析 在工业产业园、化工园或生产制造园区中,周界防范意义重大,对园区的安全起到重要的作用。常规的安防方式是采用人员巡查,人力投入成本大而且效率低。周界一旦被破坏或入侵,会影响园区人员和资产安全,…...
2024/5/2 9:47:31 - VB.net WebBrowser网页元素抓取分析方法
在用WebBrowser编程实现网页操作自动化时,常要分析网页Html,例如网页在加载数据时,常会显示“系统处理中,请稍候..”,我们需要在数据加载完成后才能继续下一步操作,如何抓取这个信息的网页html元素变化&…...
2024/5/2 9:47:31 - 【Objective-C】Objective-C汇总
方法定义 参考:https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...
2024/5/2 6:03:07 - 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】
👨💻博客主页:花无缺 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】🌏题目描述🌏输入格…...
2024/5/2 9:47:30 - 【ES6.0】- 扩展运算符(...)
【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数࿰…...
2024/5/1 11:24:00 - 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?
文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕,各大品牌纷纷晒出优异的成绩单,摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称,在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁,多个平台数据都表现出极度异常…...
2024/5/2 5:31:39 - Go语言常用命令详解(二)
文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令,这些命令可以帮助您在Go开发中进行编译、测试、运行和…...
2024/5/1 20:22:59 - 用欧拉路径判断图同构推出reverse合法性:1116T4
http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b,我们在 a i a_i ai 和 a i 1 a_{i1} ai1 之间连边, b b b 同理,则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然࿰…...
2024/5/2 9:47:28 - 【NGINX--1】基础知识
1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息,并安装一些有助于配置官方 NGINX 软件包仓库的软件包: apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...
2024/5/2 9:47:27 - Hive默认分割符、存储格式与数据压缩
目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限(ROW FORMAT)配置标准HQL为: ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...
2024/5/2 0:07:22 - 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法
文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中,传感器和控制器产生大量周…...
2024/5/2 8:37:00 - --max-old-space-size=8192报错
vue项目运行时,如果经常运行慢,崩溃停止服务,报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中,通过JavaScript使用内存时只能使用部分内存(64位系统&…...
2024/5/2 9:47:26 - 基于深度学习的恶意软件检测
恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞,例如可以被劫持的合法软件(例如浏览器或 Web 应用程序插件)中的错误。 恶意软件渗透可能会造成灾难性的后果,包括数据被盗、勒索或网…...
2024/5/2 9:47:25 - JS原型对象prototype
让我简单的为大家介绍一下原型对象prototype吧! 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定,每一个构造函数都有一个 prototype 属性,指向另一个对象,所以我们也称为原型对象…...
2024/5/1 14:33:22 - C++中只能有一个实例的单例类
C中只能有一个实例的单例类 前面讨论的 President 类很不错,但存在一个缺陷:无法禁止通过实例化多个对象来创建多名总统: President One, Two, Three; 由于复制构造函数是私有的,其中每个对象都是不可复制的,但您的目…...
2024/5/2 18:46:52 - python django 小程序图书借阅源码
开发工具: PyCharm,mysql5.7,微信开发者工具 技术说明: python django html 小程序 功能介绍: 用户端: 登录注册(含授权登录) 首页显示搜索图书,轮播图࿰…...
2024/5/2 7:30:11 - 电子学会C/C++编程等级考试2022年03月(一级)真题解析
C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...
2024/5/1 20:56:20 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...
2022/11/19 21:17:16 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在iPhone上关闭“请勿打扰”
Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...
2022/11/19 21:16:57