基于多目标遗传算法(NSGA-II)和多目标粒子群算法(MOPSO)的分布式仿真系统双目标负载平衡模型【Matlab代码实现】

news2024/10/6 12:20:27

 💥💥💥💞💞💞欢迎来到本博客❤️❤️❤️💥💥💥

🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者
📝目前更新:🌟🌟🌟电力系统相关知识,期刊论文,算法,机器学习和人工智能学习。
🚀支持:🎁🎁🎁如果觉得博主的文章还不错或者您用得到的话,可以关注一下博主,如果三连收藏支持就更好啦!这就是给予我最大的支持!

 ​

👨‍🎓博主课外兴趣:中西方哲学,送予读者:

👨‍💻做科研,涉及到一个深在的思想系统,需要科研者逻辑缜密,踏实认真,但是不能只是努力,很多时候借力比努力更重要,然后还要有仰望星空的创新点和启发点。当哲学课上老师问你什么是科学,什么是电的时候,不要觉得这些问题搞笑,哲学就是追究终极问题,寻找那些不言自明只有小孩子会问的但是你却回答不出来的问题。建议读者按目录次序逐一浏览,免得骤然跌入幽暗的迷宫找不到来时的路,它不足为你揭示全部问题的答案,但若能让人胸中升起一朵朵疑云,也未尝不会酿成晚霞斑斓的别一番景致,万一它居然给你带来了一场精神世界的苦雨,那就借机洗刷一下原来存放在那儿的“真理”上的尘埃吧。

     或许,雨过云收,神驰的天地更清朗.......🔎🔎🔎

📋📋📋本文目录如下:⛳️⛳️⛳️

目录

1 概述

2 数学模型

3 多目标遗传算法和多目标粒子群算法

4 运行结果

5 Matlab代码+数据+文档讲解 


1 概述

分布式系统具有高利用率、高可扩展性和并行性的优点,可以并行运行以处理计算密集型问题。此外,从分布式结构中衍生出几个难题,例如节点之间的通信问题、系统资源和计算节点的映射和分配问题。

高层体系结构(HLA)广泛用于分布式仿真开发。虽然HLA支持大规模分布式仿真,但仿真过程中的负载平衡机制尚未标准化。当仿真系统在非优化分配条件下运行时,由于计算量不足,会出现负载不平衡问题。

负载平衡的结果表现在以下两个方面:一是有效缩短任务的平均响应时间,即尽量缩短仿真过程的运行时间,使系统能够稳定、平稳地运行;其次,最大限度地利用整个系统的仿真资源,减少不必要的资源浪费。

高层体系结构(HLA)是分布式仿真系统的软件体系结构规范,不涉及负载平衡。因此,在HLA的仿真过程中,无法解决仿真时间长和仿真任务分布不均匀引起的失真问题。本文将研究基于组件级的仿真系统,并解决负载不平衡问题。目标是找到一组帕累托最优解,以最小化模型中具有负载限制约束的计算负载和总通信负载的不平衡。为了解决这个问题,提出了一个新的整数规划模型。采用带精英策略的非支配排序遗传算法(NSGA-II)和多目标粒子群优化算法(MOPSO)求解该问题。分析了MOPSO的不同全局最优选择方法(拥挤距离、自适应网格和综合排序)和扰动方法(快速下降和精英学习策略)。由于算法的参数对其性能有显著影响,因此使用具有新响应值的田口方法来调整所提出算法的参数。五个性能指标用于评估这些算法的结果。基于这些结果,将使用网络控制仿真平台来测试和验证这些方案。数值结果表明,提出的带ELS算子的多粒子群优化算法在求解该问题上优于其他提出的算法。此外,所提出的策略可以解决基于HLA的系统中的负载不平衡问题。

2 数学模型

本文考虑了一个具有计算和通信负载限制的双目标负载平衡问题。如前所述,该问题受到分布式仿真系统中负载分配问题的启发,即HLA。在基于HLA的分布式仿真系统中,仿真任务可以分为联邦成员级和组件级。

                   

等式(1)最小化了模拟节点计算负载的方差。等式(2)最小化了仿真节点之间的总通信负载。等式(3)规定每个模拟任务被精确地分配给一个模拟节点。等式(4)确保了计算负载限制。等式(5)保证了通信负载限制。等式(6)表示变量的非负性和完整性。更多细节参考第五部分,文件夹里面有详细讲解。

3 多目标遗传算法和多目标粒子群算法

见第五部分,详细文章讲解。

4 运行结果

​部分代码: 

function REP = MOPSOCD(params,MultiObj)

    %% 参数
    Np      = params.Np;
    Nr      = params.Nr;
    maxgen  = params.maxgen;
    W       = params.W;
    C1      = params.C1;
    C2      = params.C2;
    %ngrid   = params.ngrid;
    maxvel  = params.maxvel;
    %u_mut   = params.u_mut;
    fun     = MultiObj.fun;
    nVar    = MultiObj.nVar;
    var_min = MultiObj.var_min(:);
    var_max = MultiObj.var_max(:);


    
     
    d=nVar;   %搜索空间维数(未知数个数) 

    xmin=var_min;
    xmax=var_max;
    xrange=xmax-xmin;


    n=Np;  %初始化群体个体数目 
    MaxDT=maxgen;    %最大迭代次数 

    rp=[];  %外部存档,档案里存的是每代保存下来的非支配解,也是算法求解的结果 
    rpmax=Nr;  %档案规模 
    c1=C1;c2=C2;
    w=W;   %惯性权重 
    % pbx n*d   矩阵---个体最优解 
    % gbx n*d   矩阵---全局最优解(每个粒子的全局最优解都不同) 
    % pbf n*k   矩阵----个体最优值 
    % gbf n*k   矩阵----全局最优值 

    %产生随机 n 个粒子,初始化粒子的位置和速度 
    %x=xmin+xrange.*rand(n,d);

    x=[];
    for i=1:n
        x(i,:)=xmin'+xrange'.*rand(1,d);
    end

    v=zeros(n,d); 

    maxvel   = (var_max-var_min).*maxvel./100;

    tmp = fun(x);
    %% 计算粒子的适应度 
    k=size(tmp,2);  %目标函数个数
    x(:,2*d+1:2*d+k)=tmp; 
    x(:,d+1:2*d)=v; 
    
    %% 求个体极值和全局极值 
    pbx=x(:,1:d);   %个体最优位置为初始粒子本身 
    pbf=x(:,2*d+1:2*d+k); 
    gbx=x(:,1:d);   %全局最优位置为初始粒子本身 
    gbf=x(:,2*d+1:2*d+k); 
    xk=x(:,1:d); 
    v=x(:,(d+1):2*d); 

    rp = x;
    
    
    %% 可视化
    if(k==2)
        h_fig = figure(1);
        h_par = plot(x(:,2*d+1),x(:,2*d+2),'or'); hold on;
        h_rep = plot(rp(:,2*d+1),rp(:,2*d+2),'ok'); hold on;
        try
            set(gca,'xtick',REP.hypercube_limits(:,1)','ytick',REP.hypercube_limits(:,2)');
            axis([min(REP.hypercube_limits(:,1)) max(REP.hypercube_limits(:,1)) ...
                  min(REP.hypercube_limits(:,2)) max(REP.hypercube_limits(:,2))]);
            grid on; xlabel('f1'); ylabel('f2');
        end
        drawnow;
    end
    if(k==3)
        h_fig = figure(1);
        h_par = plot3(POS_fit(:,1),POS_fit(:,2),POS_fit(:,3),'or'); hold on;
        h_rep = plot3(REP.pos_fit(:,1),REP.pos_fit(:,2),REP.pos_fit(:,3),'ok'); hold on;
        try
                set(gca,'xtick',REP.hypercube_limits(:,1)','ytick',REP.hypercube_limits(:,2)','ztick',REP.hypercube_limits(:,3)');
                axis([min(REP.hypercube_limits(:,1)) max(REP.hypercube_limits(:,1)) ...
                      min(REP.hypercube_limits(:,2)) max(REP.hypercube_limits(:,2))]);
        end
        grid on; xlabel('f1'); ylabel('f2'); zlabel('f3');
        drawnow;
        axis square;
    end
    display(['Generation 0 - Repository size: ' num2str(size(rp,1))]);


    %开始循环 
    for t=1:MaxDT 
        %根据粒子群公式迭代,位置、速度更新 
        gen = t;
        for i=1:n           
            %v(i,:)=0.3.*randn(1,d)+c1.*rand.*(pbx(i,:)-xk(i,:))+c2.*rand.*(gbx(i,:)-xk(i,:)); 
            v(i,:)=w.*v(i,:)+c1.*rand.*(pbx(i,:)-xk(i,:))+c2.*rand.*(gbx(i,:)-xk(i,:)); 
            for j=1:d 
                if v(i,j)>maxvel(j) 
                    v(i,j)=maxvel(j); 
                elseif v(i,j)<-maxvel(j) 
                    v(i,j)=-maxvel(j); 
                end 
            end 
            xk(i,:)=xk(i,:)+v(i,:); 
            for j=1:d 
                if xk(i,j)>xmax(j) 
                    xk(i,j)=xmax(j);
                elseif xk(i,j)<xmin(j) 
                    xk(i,j)=xmin(j);
                end 
            end 
        end 


        for i=1:n   
            mu=0.1;             % Mutation Rate
            pm=(1-(t-1)/(MaxDT-1))^(1/mu);
            if rand<pm
                xk(i,:) = Mutate(xk(i,:),pm,xmin,xmax);
            end 
            for j=1:d 
                if xk(i,j)>xmax(j) 
                    xk(i,j)=xmax(j);
                elseif xk(i,j)<xmin(j) 
                    xk(i,j)=xmin(j);
                end 
            end 
        end
        
        
   
        
        
        x(:,1:d)=xk; 
        x(:,(d+1):2*d)=v; 
        %计算粒子的适应度 
        x(:,2*d+1:2*d+k)=fun(xk); 

        %求非支配解集 np(快速排序法) 
        q=x;np=[]; 
        while isempty(q)==0 
            xsb=q(1,:); 
            q(1,:)=[]; 
            flag=1;    %若 flag==1,则 xsb 是非支配解,就可以放到非支配解集中了 
            [column,row]=size(q); 
            for i=1:column 
                dom_less=0; 
                dom_equal=0; 
                dom_more=0; 
                for l=1:k 
                    if xsb(2*d+l)<q(i,2*d+l) 
                        dom_less=dom_less+1; 
                    elseif xsb(2*d+l)==q(i,2*d+l) 
                        dom_equal=dom_equal+1; 
                    else 
                        dom_more=dom_more+1; 
                    end 
                end 

                %若 xsb 支配 q(i),则将 q(i)所在的行标记为 0,用来到最后删除此行做标记 
                if dom_more==0&dom_equal~=k   
                    q(i,:)=0;  
                %若 q(i)支配 xsb,那么 xsb 不是非支配解,不能被放入非支配解集
                elseif dom_less==0&dom_equal~=k  
                    flag=0;break 
                end 
            end 
            if flag==1     %若 xsb 是非支配解,则将其放入非支配解集 np 中 
                np=[np;xsb]; 
            end 
            %将 q 中标记为 0 的行删除,剩下不被 xsb 支配的粒子,即快速排序的简便之处 
            q(~any(q,2),:)=[];  
        end 

        %更新个体极值(若当前位置支配其个体极值位置,则更新为当前位置) 
        for i=1:n 
            dom_less=0; 
            dom_equal=0; 
            dom_more=0; 
            for l=1:k 
                if x(i,2*d+l)<pbf(i,l) 
                    dom_less=dom_less+1; 
                elseif x(i,2*d+l)==pbf(i,l) 
                    dom_equal=dom_equal+1; 
                else 
                    dom_more=dom_more+1; 
                end 
            end 
            if dom_more==0&dom_equal~=k 
                pbf(i,:)=x(i,2*d+1:2*d+k); 
                pbx(i,:)=x(i,1:d); 
            end 
        end 
        %更新外部集 rp(将非支配集按支配关系插入外部集)
        [column,row]=size(rp); 
        if column==0 
            rp=np; 
        else 
            [column2,row2]=size(np); 
            for i=1:column2 
                flag=1;   %若 flag==1,则 np(i,:)是就可以放到外部集中了 
                [column1,row1]=size(rp); 
                for j=1:column1 
                    dom_less=0; 
                    dom_equal=0; 
                    dom_more=0; 
                    for l=1:k 
                        if np(i,2*d+l)<rp(j,2*d+l) 
                            dom_less=dom_less+1; 
                        elseif np(i,2*d+l)==rp(j,2*d+l) 
                            dom_equal=dom_equal+1; 
                        else 
                            dom_more=dom_more+1; 
                        end 
                    end 
                %若非支配集中的粒子 np(i,:)支配外部集中的粒子 rp(j,:), 
                %则将 rp(j,:)所在的行标记为 0,用来到最后删除此行做标记 
                    if dom_more==0&dom_equal~=k 
                        rp(j,:)=0;  
                %若 rp(j,:)支配 np(i,:),则表示 np(i,:)被 rp(j,:)支配, 
                %那么 np(i,:)就一定不是非支配解,就不能被放入非支配解集中了 
                    elseif dom_less==0&dom_equal~=k  
                        flag=0;break 
                    end 
                end 
                if flag==1     %若 flag==1,则 np(i,:)是就可以放到外部集中了 
                                        rp=[rp;np(i,:)]; 
                end 
                rp(~any(rp,2),:)=[]; 
            end 
        end 

        np = rp;
        [column,row]=size(rp); 
        for i=1:column
            for j=i:column
                if i~=j && sum(np(i,1:d)-np(j,1:d) == 0) == d
                    rp(i,:)=0; 
                    break;
                end
            end
        end
        rp(~any(rp,2),:)=[]; 
        %基于拥挤距离控制档案规模 
        %(计算外部集中粒子的拥挤距离,对拥挤距离进行降序排序,删除后面的多余个体) 
        [column,row]=size(rp); 
        indexrp=[1:column]'; 
        rp=[rp indexrp];   %索引 
        rp(:,2*d+k+2)=zeros(column,1);   %用来保存拥挤距离 
        for i=1:k 
            rp=sortrows(rp,2*d+i);   %将粒子进行对第 i 个目标函数值进行升序排列 
            if column>2 
                for j=2:column-1 
                    rp(j,2*d+k+2)= rp(j,2*d+k+2)+(rp(j+1,2*d+i)-rp(j-1,2*d+i))/(rp(column,2*d+i)-rp(1,2*d+i)); 
                end 
            end 
            rp(1,2*d+k+2)=rp(1,2*d+k+2)+inf; 
            rp(column,2*d+k+2)=rp(column,2*d+k+2)+inf; 
        end 
        rp=sortrows(rp,-(2*d+k+2));     %外部集根据拥挤距离降序排序 
        if column>rpmax 
            rp=rp(1:rpmax,:); 
        end 

        %更新全局极值(此时外部集已根据拥挤距离降序排序,从外部集的最前部分随机选择) 
        for i=1:n 
        %产生一个随机数,从外部集前 10%的粒子里面选 
            randomnumber=ceil(rand*column/10);  
            gbx(i,:)=rp(randomnumber,1:d);     %全局最优位置 
            gbf(i,:)=rp(randomnumber,2*d+1:2*d+k); 
        end 
        rp(:,2*d+k+1:2*d+k+2)=[]; 
        
        
         % Plotting and verbose
        if(k==2)
            figure(h_fig); delete(h_par); delete(h_rep);
            h_par = plot(x(:,2*d+1),x(:,2*d+2),'or'); hold on;
            h_rep = plot(rp(:,2*d+1),rp(:,2*d+2),'ok'); hold on;
            try
                set(gca,'xtick',REP.hypercube_limits(:,1)','ytick',REP.hypercube_limits(:,2)');
                axis([min(REP.hypercube_limits(:,1)) max(REP.hypercube_limits(:,1)) ...
                      min(REP.hypercube_limits(:,2)) max(REP.hypercube_limits(:,2))]);
            end
            if(isfield(MultiObj,'truePF'))
                try delete(h_pf); end
                h_pf = plot(MultiObj.truePF(:,1),MultiObj.truePF(:,2),'.','color',0.8.*ones(1,3)); hold on;
            end
            grid on; xlabel('f1'); ylabel('f2');
            drawnow;
            axis square;
        end
        if(k==3)% 以后再改
            figure(h_fig); delete(h_par); delete(h_rep); 
            h_par = plot3(POS_fit(:,1),POS_fit(:,2),POS_fit(:,3),'or'); hold on;
            h_rep = plot3(REP.pos_fit(:,1),REP.pos_fit(:,2),REP.pos_fit(:,3),'ok'); hold on;
            try
                set(gca,'xtick',REP.hypercube_limits(:,1)','ytick',REP.hypercube_limits(:,2)','ztick',REP.hypercube_limits(:,3)');
                axis([min(REP.hypercube_limits(:,1)) max(REP.hypercube_limits(:,1)) ...
                      min(REP.hypercube_limits(:,2)) max(REP.hypercube_limits(:,2)) ...
                      min(REP.hypercube_limits(:,3)) max(REP.hypercube_limits(:,3))]);
            end
            if(isfield(MultiObj,'truePF'))
                try delete(h_pf); end
                h_pf = plot3(MultiObj.truePF(:,1),MultiObj.truePF(:,2),MultiObj.truePF(:,3),'.','color',0.8.*ones(1,3)); hold on;
            end
            grid on; xlabel('f1'); ylabel('f2'); zlabel('f3');
            drawnow;
            axis square;
        end
        display(['Generation #' num2str(gen) ' - Repository size: ' num2str(size(rp,1))]);
        
        
        
        
        
        
        
    end 

    REP.pos = rp(:,1:d);
    REP.pos_fit = rp(:,2*d+1:2*d+k);
    hold off;
%     hold on;
%     rpcd=rp;
%     plot(rpcd(:,2*d+1),rpcd(:,2*d+2),'^');
end

function xnew=Mutate(x,pm,VarMin,VarMax)
    nVar=numel(x);
    j=randi([1 nVar]);
    dx=pm*(VarMax(j)-VarMin(j));
    lb=x(j)-dx;
    ub=x(j)+dx;
    lb = max(lb,VarMin(j));
    lb = min(lb,VarMax(j));
    ub = max(ub,VarMin(j));
    ub = min(ub,VarMax(j));    
    xnew=x;
    xnew(j)=unifrnd(lb,ub);
end

5 Matlab代码+数据+文档讲解 

博客主页:电气辅导帮

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/84289.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Oracle单机部署:GI安装

Oracle单机部署&#xff1a;GI安装存储配置ASM磁盘空间评估GI单机安装配置GI图形化安装流程安装后测试&#x1f42c; 使用grid用户来安装GI。 存储配置 Oracle存储支持Oracle ASM、Oracle ACFS、本地文件系统、网络文件系统&#xff08;NFS/NAS&#xff09;、Oracle Memory S…

RK3588平台开发系列讲解(RTC篇)RTC的使用

平台内核版本安卓版本RK3588Linux 5.10Android 12文章目录 一、RTC简介二、HYM8563驱动配置2.1、设备树配置2.1、驱动代码三、RTC的使用3.1、SYSFS接口3.2、PROCFS接口3.3、IOCTL接口沉淀、分享、成长,让自己和他人都能有所收获!😄 📢本篇将介绍RK3588平台RTC驱动及使用方…

玩以太坊链上项目的必备技能(基本类型转换以及推断-Solidity之旅六)

基本类型之间的转换 熟悉过其他编程语言的您&#xff0c;对基本类型之间的转换并不陌生吧&#xff01;当然&#xff0c;这基本类型进行转换可分为隐式转换和显示转换。 隐式转换 Solidity 支持隐式转换&#xff0c;通过编译器自动进行转换&#xff0c;而不要开发人员的干涉&…

信道估计算法误码率仿真,对比不同导频长度,对比不同信道估计算法包括CS-OMP,LS,MMSE

目录 1.算法描述 2.仿真效果预览 3.MATLAB核心程序 4.完整MATLAB 1.算法描述 所谓信道估计&#xff0c;就是从接收数据中将假定的某个信道模型的模型参数出来的过程。如果信道是线性的话&#xff0c;那么信道估计就是对系统冲激响应进行估计。 CS-OMP 正则正交匹配追踪(Re…

分布式操作系统 - 5.分布式命名管理

文章目录1.基本概念2.非结构化命名管理2.1 简单的实体定位方法&#xff1a;广播和多播方法&#xff08;1&#xff09;广播方法&#xff08;broadcast&#xff09;&#xff08;2&#xff09;多播方法&#xff08;multicast&#xff09;&#xff08;3&#xff09;问题&#xff1a…

图形API学习工程(30):尝试使用panorama来代替Cubemap作为全景图

工程GIT地址&#xff1a;https://gitee.com/yaksue/yaksue-graphics 前言 为了能得到全方位的光照数据&#xff0c;我之前学习了使用CubeMap作为全景图。CubeMap包含六张贴图对应了上下左右前后六个方向的数据。但是最近在下载全景图的资源时&#xff0c;看到很多并非是CubeM…

Python基于Django的毕业设计论文提交过程管理系统

项目介绍 在各学校的教学过程中&#xff0c;django过程管理系统是一项非常重要的事情。随着计算机多媒体技术的发展和网络的普及。采用当前流行的B/S模式以及3层架构的设计思想通过Python技术来开发此系统的目的是建立一个配合网络环境的django过程管理系统的平台&#xff0c;这…

c#入门-访问基类成员

调用基类构造器 在构建派生类前&#xff0c;会首先构建出完整的基类。 即便是派生类无权访问的成员&#xff0c;也会存在。 因此才能保证派生类能完全地当作基类来使用。 因此&#xff0c;在执行派生类的构造器前&#xff0c;首先需要先调用基类的构造器。 而如果基类没有&am…

017 | 精准扶贫视野下非遗传承的研究与启示——以三峡皮影为例 | 大学生创新训练项目申请书 | 极致技术工厂

&#xff08;一&#xff09;研究目的 百年党建视域下&#xff0c;全面建成小康社会的历史目标已成功达成&#xff0c;但东西部经济发展的不平衡、不平均依旧是新时代发展中亟需解决的问题。坚持党的领导&#xff0c;响应西部大开发的战略号召&#xff0c;本团队深入探访于2018…

S2SH药膳馆会员管理系统计算机专业毕业论文java毕业设计开题报告

&#x1f496;&#x1f496;更多项目资源&#xff0c;最下方联系我们✨✨✨✨✨✨ 目录 Java项目介绍 资料获取 Java项目介绍 计算机毕业设计java毕设之S2SH药膳馆会员管理系统-IT实战营_哔哩哔哩_bilibili项目资料网址: http://itzygogogo.com软件下载地址:http://itzygog…

基于jsp+mysql+ssm足球新闻发布网站-计算机毕业设计

项目介绍 同完成整个足球新闻发布系统的设计开发。系统实现的功能主要包括&#xff1a;前台浏览足球新闻的功能&#xff1b;后台用户在成功登录该系统的后台时&#xff0c;可以对用户、足球新闻类别、足球新闻、留言进行添加、修改和删除等功能&#xff1b;以及对用户名密码等…

Arthas(Java 应用诊断利器)

文章目录Arthas使用背景Arthas&#xff08;阿尔萨斯&#xff09;能做什么&#xff1f;Arthas Spring Boot StarterArthas Arthas 是由Alibaba开源的Java监控诊断工具&#xff0c;通过全局视角实时查看应用 load、内存、gc、线程的状态信息&#xff0c;并能在不修改应用代码的情…

Pytorch中的损失函数

L1损失函数&#xff1a;又称&#xff0c;L1 范数损失、最小绝对值偏差&#xff08;LAD&#xff09;、最小绝对值误差&#xff08;LAE&#xff09; MAE也是指L1损失函数。 把目标值 yi 与模型输出&#xff08;估计值&#xff09; f(xi) 做绝对值得到的误差。 通常用于回归任务、…

uniapp实战仿写网易云音乐(二)—promise接口请求的封装和主页功能的实现,组件封装

文章目录前言promise请求接口的封装主入口功能的实现&#xff1a;推荐歌单模块新碟新歌模块精选视频模块最后前言 本篇文章继续完成上篇文章的部分&#xff0c;主要实现prromise接口的封装和首页主入口的实现 promise请求接口的封装 在上篇文章中请求我们是这样写的&#xf…

(详细及解决方法)关于Vue.prototype中定义的变量不是响应式

目录 一、背景 二、原因 三、解决方法 四、扩展 当时第一眼看到下面的图&#xff0c;就想这个不会是写错了吧&#xff0c;咋还能这样写&#xff0c;在这里我承认&#xff0c;我以前说话确实很大声了 一、背景 在项目中需要将全局变量存放到Vue的实例对象上面 Vue.protot…

【历史上的今天】12 月 13 日:时代杂志将“你”评为年度人物;苹果发布 AirPods;互联网传出欧洲

整理 | 王启隆 透过「历史上的今天」&#xff0c;从过去看未来&#xff0c;从现在亦可以改变未来。 今天是 2022 年 12 月 13 日&#xff0c;国家公祭日。从 2014 年开始&#xff0c;12 月 13 日被定为缅怀先烈的国家公祭日&#xff0c;网站也会在这一天变为全灰色&#xff0c…

墙裂推荐c++的学习网站(OJ)

目录 墙裂推荐OJ 墙裂推荐学习软件 墙裂推荐线上编辑器 墙裂推荐OJ 要想学好c,更好的OJ少不了啊!!! 为了让诸多小白们有更好的学习测试环境,特此准备了一下几个OJ, 1.Openjudge 网站: OpenJudge openjudge网站中储存着大量的题目,而且还提前帮你们把板块分好了,就问你们…

[Java] HashMap是如何实现的?扩容机制是什么?树化机制知道吗?结合源码带你理解HashMap的原理。

文章目录前言HashMap是什么&#xff1f;Map接口散列表&#xff08;HashTable&#xff09;HashMap的扩容机制扩容机制&#xff1f;扩谁的容&#xff1f;HashMap的容量&#xff08;Capacity&#xff09;属性HashMap的扩容因子&#xff08;load factor&#xff09;属性HashMap的树…

【js逆向基础】crypto 之 hash和hmac

▒ 目录 ▒&#x1f6eb; 导读需求开发环境1️⃣ hash对象创建Hash常见方法例封装成 stream 实例封装成管道流&#xff08;piped stream)2️⃣ hmac对象创建Hmac常见方法例封装成 stream 实例封装成管道流&#xff08;piped stream)&#x1f6ec; 文章小结&#x1f4d6; 参考资…

mysql学习---流程控制函数(条件判断)case when ,if使用

文章目录流程控制函数流程控制函数的介绍流程函数的使用流程控制函数 流程控制函数的介绍 if(value,value1,value2) 解释&#xff1a;如果value的结果为true &#xff0c;返回value1,否则返回value2 例如&#xff1a; select if(1>0,正确,错误) ->正确ifnull(value1,val…