注塑机自动喷雾程序 报警自动关机

news2025/1/13 13:24:26

/***参数设置,开模数计数,秒脉冲计时***************/
/***实现功能:检测报警信号,脱模剂开模数计数信号***/
/***参数:1:脱模剂开模数 2:喷雾时间 3:延时时间 ***/
/***串口接收触摸屏参数设置字符串,接收并保存******/
/***端子输入口读开模数,比较设定值后输出到电磁阀**/
/***端子输入口读报警信号,到设定值关闭电机及加热**/
              #include     <REG52.H>      //2023  2 28  L422 CODE2785
              #include     <intrins.H>
              #include     "stdio.h"
              #define      uint unsigned int  
              #define      uchar unsigned char
              #define      WT_12M   0x83         //IAP_CONTR
//#define WT_30M          0x80     频率30M
//#define WT_24M          0x81     频率24M
//#define WT_20M          0x82     频率20M
//#define WT_12M          0x83     频率12M
//#define WT_6M           0x84     频率6M
//#define WT_3M           0x85     频率3M
//#define WT_2M           0x86     频率2M
//#define WT_1M           0x87     频率1M
              #define      IAP_ADDRESS 0x0400    //EEPROM首地址
              typedef      unsigned char BYTE;
              typedef      unsigned int WORD;
              uchar        s;                        
              sbit         AUX=P3^2;             /****RoLa***/
              sbit         MD0MD1=P1^7;             /****RoLa***/
              sbit         OUT1=P3^4;            /****输出***/
              sbit         OUT2=P3^5;            /****输出***/
              sbit         WARNING=P5^5;         /****输入***/
              sbit         INTPUT1=P5^4;         /****输入***/
              sbit         BP=P1^0;              /***输出LED指示***/
              uchar        v;                    /*从机号*/
              uchar        Modulus;              //开模数
              uchar        Spray_Time;             //喷雾时间
              uchar        Delay_Time;             //延时时间
              uchar        kcounter,kstatus;     //按键计数标志 按键状态标志
              bit           Receive_Flag;         //串口数据缓冲接收标志
              bit           WARNING_Flag;         //低电平报警标志
              bit           S_Flag;                 //秒计时标志
              uint         WARNING_Time;         //报警计时计数器
              uchar        DAT2=0;
              static       uint                  val1,val2,val3,val4;
              uint         val5;                 //机器编号
              uint         SS=0;
              uint         TIME=0;               //实际开模数
              uint         a[10];                //定义数组a 存储串口数据串
/*---------------延时子程序----------------*/
              void delay1 (uint ms)
              {
              uint i,j;
              for(i=0;i<ms;i++)
              for(j=0;j<200;j++)
              ;
              }    
/*------------------延时子程序------------------------*/
              void delay10ms(uint x)
              {
               uint i, j;
               for (i=0;i<x;i++)
               for (j=0;j<500;j++);
              }
/*-----------延时100ms子程序12MHz --------*/
               void Delay_100ms(uint x)          //
               {
               uint i,j;
                for(i=0;i<x;i++)
                {
                for(j=0;j<18000;j++);
                }
               }
/****************按键计数器状态寄存器归零*************/
              void RstKey()
              {
              kcounter=0;                       //按键计数器归零
              kstatus=0;                        //状态寄存器归零
              }
/*****************按键低电平检测函数*****************/
              void   LowVoltKey(void)           //按键计数器状态标志加一
              {
              kcounter++;                       
              kstatus++;     
              _nop_();                         //延时                  
              }
/*****************按键高电平检测函数*****************/
              void    HighVoltKey(void)         //按键计数器加一 状态标志归零
              {
              kcounter++;                       //按键计数器加一
              kstatus=0;                        //按键状态标志归零
              _nop_();                          //延时
              }
/*----关闭IAP----------------------------*/
              void IapIdle()
              {
              IAP_CONTR=0;                       //关闭IAP功能     ISP/IAP 控制寄存器
              IAP_CMD=0;                         //清除命令寄存器
              IAP_TRIG=0;                        //清除触发寄存器
              IAP_ADDRH=0X80;                    //将地址设置到非IAP区域
              IAP_ADDRL=0;
              }
/*-从ISP/IAP/EEPROM区域读取一字节-*/
              char IapRead(int addr)
              {
              char dat;
              IAP_CONTR = WT_12M;                         //使能IAP    ISP/IAP 控制寄存器
              IAP_CMD = 1;                                //设置IAP读命令
              IAP_ADDRL = addr;                           //设置IAP低地址
              IAP_ADDRH = addr >> 8;                      //设置IAP高地址
              IAP_TRIG = 0x5a;                            //写触发命令(0x5a)
              IAP_TRIG = 0xa5;                            //写触发命令(0xa5)
              _nop_();
              dat = IAP_DATA;                             //读IAP数据
              IapIdle();                                  //关闭IAP功?
              return dat;
              }
/*********字节写*********************/
              void IapProgram(int addr, char dat)
              {
              IAP_CONTR = WT_12M;                         //使能IAP
              IAP_CMD = 2;                                //设置IAP写命令
              IAP_ADDRL = addr;                           //设置IAP低地址
              IAP_ADDRH = addr >> 8;                      //设置IAP高地址
              IAP_DATA = dat;                             //写IAP数据
              IAP_TRIG = 0x5a;                            //写触发命令(0x5a)
              IAP_TRIG = 0xa5;                            //写触发命令(0xa5)
              _nop_();
              IapIdle();                                  //关闭IAP功能
              }
/*---扇区擦除---------------*/
              void IapErase(int addr)
              {
              IAP_CONTR = WT_12M;                         //使能IAP
              IAP_CMD = 3;                                //设置IAP擦除命令
              IAP_ADDRL = addr;                           //设置IAP低地址
              IAP_ADDRH = addr >> 8;                      //设置IAP高地址
              IAP_TRIG = 0x5a;                            //写触发命令(0x5a)
              IAP_TRIG = 0xa5;                            //写触发命令(0xa5)
              _nop_();                                    //
              IapIdle();                                  //关闭IAP功能
              }
/*************写参数到EEPROM*******************************/
              void Write_EepromTime()
              {
              IapErase(IAP_ADDRESS); //扇区擦除
              IapProgram(IAP_ADDRESS+0,val1/256);       /*开模数高八位*/    
              IapProgram(IAP_ADDRESS+1,val1%256);       /*开模数低八位*/

              IapProgram(IAP_ADDRESS+2,val2/256);       /*喷雾时间高八位*/  
              IapProgram(IAP_ADDRESS+3,val2%256);       /*喷雾时间低八位*/

              IapProgram(IAP_ADDRESS+4,val3/256);       /*喷雾延时高八位*/  
              IapProgram(IAP_ADDRESS+5,val3%256);       /*喷雾延时低八位*/

              IapProgram(IAP_ADDRESS+6,val4/256);       /*报警延时关高八位*/    
              IapProgram(IAP_ADDRESS+7,val4%256);       /*报警延时关低八位*/

              IapProgram(IAP_ADDRESS+8,val5/256);       /*系统高八位*/  
              IapProgram(IAP_ADDRESS+9,val5);           /*系统低八位*/
              }
/***********************************/
              void red_eeprom(void)
              {
              uint m,n;        
              m=IapRead(IAP_ADDRESS+0);  //开模数高八位
              n=IapRead(IAP_ADDRESS+1);  //开模数低八位
              val1=m*256+n;                     //开模数
               m=IapRead(IAP_ADDRESS+2);  //喷雾时间高八位
              n=IapRead(IAP_ADDRESS+3);  //喷雾时间低八位
              val2=m*256+n;                     //喷雾时间
              m=IapRead(IAP_ADDRESS+4);  //喷雾延时时间高八位
              n=IapRead(IAP_ADDRESS+5);  //喷雾延时时间低八位
              val3=m*256+n;                     //喷雾延时时间
              m=IapRead(IAP_ADDRESS+6);  //报警延时关加热电机高八位
              n=IapRead(IAP_ADDRESS+7);  //报警延时关加热电机低八位
              val4=m*256+n;                     //报警延时关加热电机时间
              val5=IapRead(IAP_ADDRESS+8);  //备用高八位
              }
/*------------初始化串口---------------------*/
              void InitUart()
              {
              SCON=0X50;                         //8位数据,可变波特率
              AUXR|=0x01;                        //串口1选择定时器2为波特率发生器
              AUXR|=0X04;                        //定时器2时钟为Fosc,即1T
              T2L=0XE0;                          //设置定时器处置  110592》9600
              T2H=0XFE;                          //设置定时器处置  110592》9600
              AUXR|=0X10;                        //启动定时器2
              TI=1;
              ES=1;                        //
              EA=1;
              }
/**************串口发送*****************************/
              void Send(uchar temp)
              {
              unsigned serial;
              serial=temp;
              SBUF=(uchar)temp;
              while(TI!=1);
              TI=0;
              }
/*--------UART中断服务程序---串口4接收触摸屏数据---*/
              void Uart() interrupt 4 using 1
              {
               uchar i;
               if(RI)
               {
                if(SBUF==0XFA)         //触摸屏结束码
                {
                Receive_Flag=1;                     //接收数据标志置一
                RI=0;                             //
                i=0;                             //数组计数器归零
                }
                else
                {
                a[i]=SBUF;                       //数组下标位置的数据等于SBUF
                RI=0;                             //
                i++;
                }
               }
              }
/**************定时器0中断*********************/
              void TM0_Isr() interrupt 1
              {
               SS++;
               if(SS>=12000)         //6000
               {
               SS=0;
               S_Flag=1;                                   //秒计时标志
               }
              }
/*------------------主循环程序----------------*/      
              void   main( )                     /*主程序开始*/
              {                                  /**加一**/
              AUXR=0X80;                         //STC系列的1T 设置
              TL0=0x66;                          //65536-11.0592M/12/1000
              TH0=0xfc;
              ET0=1;                             //使能定时器中
              TR0=1;                             //启动定时器
              BP=1;  
              delay1(2000);
              BP=0;
              delay1(2000);
              BP=1;  
              delay1(2000);
              BP=0;
              delay1(2000);
              BP=1;  
              delay1(2000);
              BP=0;
              InitUart();                        //初始化串口
              MD0MD1=0;                             //
              P_SW1=0x00;                        //RXD/P3.0, TXD/P3.1
              delay10ms(200);
              printf("0XFF,0XFF,0XFF");
              delay10ms(200);
              Send(0XBB);
              delay10ms(200);
              Send(0XBB);
              delay10ms(200);
              Send(0XBB);
              red_eeprom();
              P_SW1=0x40;                        //RXD_2/P3.6, TXD_2/P3.7
              delay10ms(100);
              printf("0XFF,0XFF,0XFF");          //向串口屏发启动信号
              delay1(20);
              printf("t0.txt=\"系统启动\"" );    //    
              printf("XFF,XFF,XFF");             //向串口屏发启动信号
              printf("t0.txt=\"系统启动\"" );    //    
              printf("0XFF,0XFF,0XFF");          //向串口屏发启动信号
              delay10ms(50);
              printf("n0.val=%d\xff\xff\xff",val1);
              printf("n0.val=%d\xff\xff\xff",val1);    //开模计数
              printf("n1.val=%d\xff\xff\xff",val2);    //喷雾时间
              printf("n2.val=%d\xff\xff\xff",val3);    //喷雾延时
              printf("n3.val=%d\xff\xff\xff",val4); //关机延时 开模次数
              printf("n5.val=%d\xff\xff\xff",val5);    //系统
              delay1(20);
              Receive_Flag=0;                     //接收数据标志置零
              S_Flag=0;                             //秒计时标志
              WARNING_Time=0;                     //报警计时计数器
              WARNING_Flag=0;                     //低电平报警标志
              while(1)
              {
               if(Receive_Flag==1)                 //接收标志为1
               {
                Receive_Flag=0;                     //接收标志归零 重新接收
                  if (a[0]==0XC0&&a[1]==0X00)                     //
                 {
                 val1=a[3]*256+a[2];             //开模数
                 printf("n4.val=%d\xff\xff\xff",val1);    //返回数据核对
                 }
                 else if (a[0]==0XC0&&a[1]==0X01)
                 {
                 val2=a[3]*256+a[2];             //喷雾时间
                 printf("n4.val=%d\xff\xff\xff",val2);    //返回数据核对
                 }
                 else if (a[0]==0XC0&&a[1]==0X02)             //
                 {
                 val3=a[3]*256+a[2];            //喷雾延时
                 printf("n4.val=%d\xff\xff\xff",val3);    //返回数据核对
                 }
                 else  if (a[0]==0XC0&&a[1]==0X03)
                 {
                 val4=a[3]*256+a[2];             //报警延时关电机加热
                 printf("n4.val=%d\xff\xff\xff",val4);    //返回数据核对
                 }
                 else if (a[0]==0XC0&&a[1]==0X04)
                 {
                 val5=a[2];                        //备用参数
                 printf("n4.val=%d\xff\xff\xff",val5);    //返回数据核对
                 }
                 Write_EepromTime();
                 delay10ms(500);     
                 printf("n0.val=%d\xff\xff\xff",val1);    //开模计数
                 printf("n1.val=%d\xff\xff\xff",val2);    //喷雾时间
                 printf("n2.val=%d\xff\xff\xff",val3);    //喷雾延时
                 printf("n3.val=%d\xff\xff\xff",val4);    //关机延时
                 printf("n5.val=%d\xff\xff\xff",val5);    //系统
                }
//
                  RstKey();                         //开模完低电平信号
                for(;kcounter<5;)                //按键循环5次
                {
                 if(!INTPUT1)                    //按键低电平
                 {
                 LowVoltKey();                   //按键低电平 计数器加一状态标志加一
                 }
                 else if(~!INTPUT1)              //按键高电平
                 {
                 HighVoltKey();                  //按键计数器加一    状态标志归零
                 }
                }
                if(kstatus>=3)                   /*按键状态标志大于等于3为有效值*/
                {
                P_SW1=0x40;                      //RXD_2/P3.6, TXD_2/P3.7触摸屏显示开模数
                delay10ms(100);
                TIME++;
                printf("n4.val=%d\xff\xff\xff",TIME);    //实际开模数
                if(TIME>=val1)
                 {
                 OUT1=0;                         /****输出***/
                 Delay_100ms(val2);
                 OUT1=1;                         /****输出***/
                 TIME=0;
                 }
                 RstKey();
                  for(;kcounter<5;)              //按键循环5次
                  {
                   if(~!INTPUT1)                 //按键高电平
                   {
                    kcounter++;                     //高电平加1
                    BP=0;
                    delay1(20);                     //高电平闪烁指示
                    BP=1;
                    delay1(20);                     //高电平闪烁指示
                   }
                   else if(!INTPUT1)             //按键低电平
                   {
                   kcounter=0;                   //低电平开模完未复位,继续循环检测
                   }
                 }
                }
/**********************************************/
                   RstKey();                         //按键复位
                WARNING_Time=0;                     //报警计时计数器秒计时标志赋初始化值
                 for(;kcounter<8;)                //按键循环8次
                {
                 if(!WARNING)                    //按键低电平
                  {
                   LowVoltKey();                 //按键低电平 计数器加一状态标志加一
                  }
                  else if(~!WARNING)             //按键高电平
                  {
                   HighVoltKey();                //按键计数器加一    状态标志归零
                   }
                 }
                 if(kstatus>=5)                  /*按键状态标志大于等于5为有效值*/
                  {
                   RstKey();                     //按键复位
                   WARNING_Flag=1;                  //启动低电平报警标志    while(WARNING_Flag)
                   RstKey();                     //按键自动
                   do
                   {
                    if(~!WARNING)                //按键低电平
                    {
                     kcounter++;                 //高电平加1                   
                    }
                    else if(!WARNING)            //按键高电平
                    {
                    kcounter=0;                  //低电平开模完警报复位,继续循环检测
                     if(S_Flag==1)                 //定时器计时标志置位等于1
                     {
                      WARNING_Time++;
                      S_Flag=0;                     //关闭秒计时标志,等待定时器下一秒计时赋值
                      BP=~BP;                    //测试端口
                      printf("n6.val=%d\xff\xff\xff",WARNING_Time);    //
                      }
                      if(WARNING_Time>=val4*60)
                      {
                       P_SW1=0x00;               //RXD/P3.0, TXD/P3.1
                       delay10ms(200);
                       Send(val5);
                       delay10ms(200);
                       Send(val5);
                       delay10ms(200);
                       Send(val5);
                       S_Flag=0;                 //秒计时标志赋初始化值
                       WARNING_Time=0;             //报警计时计数器秒计时标志赋初始化值
                       WARNING_Flag=0;             //低电平报警标志
                       OUT2=0;                     //
                       }
                     }                             //检测到十次高电平,报警解除
                    if(kcounter>=10)             /*按键状态标志大于等于10为有效值*/
                    {                              //连续检测到10次高电平,警报解除
                    S_Flag=0;                     //秒计时标志赋初始化值
                    WARNING_Time=0;                 //报警计时计数器秒计时标志赋初始化值
                    WARNING_Flag=0;                 //低电平报警标志
                    }
                   }
                   while(WARNING_Flag);
                   P_SW1=0x40;                  //RXD_2/P3.6, TXD_2/P3.7    P_SW1=0x40;
                  }
                 }
              }                                     //2023  2 28  L422 CODE2785

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

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

相关文章

Verilog仿真跨模块调用内部信号的方法

在Verilog仿真时如果需要调用某子模块中的信号在本模块中使用可以使用层次化引用的方法&#xff0c;而不需要在rtl部分用端口引出来。 引用方式&#xff1a;当前例化模块名.子例化模块名.子子例化模块名.参数 将需要的信号引出。 注意是用例化模块名而不是用子模块名&#xff…

记录一下我102连不上MySQL的问题 NotBefore

【背景描述】我在102上是能登录上MySQL的&#xff0c;但是用客户端&#xff08;DataGrip、SQLyog就连不上&#xff09; 【解决方案】 加个这个?useSSLfalse&serverTimezoneUTC 【另外的小问题】如果直接输mysql 上面这个不是报错&#xff0c;不用管 再输mysql -uroot -p…

json diff patch

文件和图片的比对靠字符串 目录 流程 安装 效果 使用 自适应 数组&#xff1a;最长公共子序列(LCS) 数组中的对象&#xff0c;给定id&#xff0c;类似dom tree的比较 流程 安装 npm install jsondiffpatch import * as jsondiffpatch from jsondiffpatch; const jsond…

ASP.NET医院手麻信息系统源码 .NET6.0+VUE

目录 麻醉记录单 复苏记录单 麻醉文书 手术麻醉信息 1、 体征监控记录 2、 麻醉用药信息 3、 手术事件登记 4、 手术状态变更 5、 麻醉医师交接 6、 其他辅助操作 手麻信息系统是以服务围术期临床业务工作的开展为核心&#xff0c;通过与床边监护设备以及医院H…

Github 2024-04-18 Go开源项目日报Top10

根据Github Trendings的统计,今日(2024-04-18统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Go项目10Vue项目1TypeScript项目1Ollama: 本地大型语言模型设置与运行 创建周期:248 天开发语言:Go协议类型:MIT LicenseStar数量:42421 个…

C语言结构体与公用体

结构体 概述 有时我们需要将不同类型的数据组合成一个有机的整体&#xff0c;如&#xff1a;一个学生有学号/姓名/性别/年龄/地址等属性这时候可通过结构体实现结构体(struct)可以理解为用户自定义的特殊的复合的“数据类型” 可以理解为其他语言的object类型 结构体变量的定…

CSS 01

CSS层叠样式表 HTML的局限性 HTML只关注内容的语义&#xff0c;可以做简单的样式&#xff0c;却带来了无限的臃肿和繁琐。 CSS CSS是层叠样式表的简称&#xff0c;也被称之为CSS样式表或级联样式表。CSS也是一种标记语言。   CSS主要用于设置HTML页面中的文本内容(字体、大…

【第1节】书生·浦语大模型全链路开源开放体系

目录 1 简介2 内容&#xff08;1&#xff09;书生浦语大模型发展历程&#xff08;2&#xff09;体系&#xff08;3&#xff09;亮点&#xff08;4&#xff09;全链路体系构建a.数据b 预训练c 微调d 评测e.模型部署f.agent 智能体 3 相关论文解读4 ref 1 简介 书生浦语 InternLM…

SAP打印输出设置

SAP打印输入有很多方式&#xff0c;适合不同的应用场景。 一.打印输出总体概览图 二.前台打印 这个是比较常见的&#xff0c;前端打印的出现减轻了管理员的工作量&#xff0c;用户可以选择自己电脑上的打印机输出&#xff0c;不需要所有打印机都在SAP平台中进行配置&#xff0…

学习STM32第十五天

SPI外设 一、简介 STM32F4XX内部集成硬件SPI收发电路&#xff0c;可以由硬件自动执行时钟生成、数据收发等功能&#xff0c;减轻CPU负担&#xff0c;可配置8位/16位数据帧&#xff0c;高位&#xff08;最常用&#xff09;/低位先行&#xff0c;三组SPI接口&#xff0c;支持DMA…

Linux 存储:NAND 写入异常案例 (1)

文章目录 1. 前言2. 案例背景3. 案例问题4. 案例分析4.1 普通文件写入流程概要4.2 dd 写 NAND 时&#xff0c;会不会使用 page cache &#xff1f;4.3 dd 写 NAND 时&#xff0c;对比 U-Boot 读 NAND&#xff0c;是否采用了相同的坏块策略 &#xff1f;4.3.1 U-Boot 读 NAND 过…

【经验总结】Jupyter 配置内核

1. 背景描述 使用 国家超算互联网中心 的服务器&#xff0c;创建 jupyterlab 容器&#xff0c;想在之前 conda 创建的环境中运行&#xff0c;可是不行&#xff0c;进入容器就直接进入 jupyterlab 2. 解决方法 配置内核 2.1 激活环境 conda activate peft2.2 安装内核 pip…

【Python基础】字典

文章目录 [toc]什么是字典键值对示例键异常 遍历列表什么是遍历遍历字典的键keys()方法 遍历字典的值values()方法 遍历字典的键值对items()方法 字典操作增加键值对修改键值对查询键值对get()方法 删除键值对delclear()方法 个人主页&#xff1a;丷从心 系列专栏&#xff1a;…

牛客Linux高并发服务器开发学习第二天

Gcc编译 利用gcc 生成应用时如果不加-o 和应用名&#xff0c;默认生成a.out 可以用./ a.out打开 Gcc工作流程 可执行程序Windows系统中为.exe Linux系统中为.out g也可以编辑c程序 gcc也可以编译cpp代码&#xff0c;只是在编译阶段gcc不能自动共和C程序使用的库进行联接&…

kettle从入门到精通 第五十三课 ETL之kettle MQTT/RabbitMQ producer 实战

1、MQTT介绍 MQTT (Message Queuing Telemetry Transport) 是一种轻量级的消息传输协议&#xff0c;设计用于连接低带宽、高延迟或不可靠网络的设备。 MQTT 是基于发布/订阅模式&#xff08;Publish/Subscribe&#xff09;的协议&#xff0c;其中设备可以发布消息到一个主题&…

【Linux系列】Ctrl + R 的使用

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

Eland上传bge-large-zh-v1.5向量化模型到ElasticSearch中

最近需要做一些向量检索&#xff0c;试试ES 一、准备 系统&#xff1a;MacOS 14.3.1 ElasticSearch&#xff1a;8.13.2 Kibana&#xff1a;8.13.2 本地单机环境&#xff0c;无集群&#xff0c;也不基于Docker BGE是一个常见的文本转向量的模型&#xff0c;在很多大模型RAG应…

SpringBootSpringCloud升级可能会出现的问题

1.背景 之前负责过我们中台的SpringBoot和Cloud的升级&#xff0c;特次记录分享一下项目中可能出现的问题&#xff0c;方便后续的人快速定位问题。以及下述选择的解决方案都是基于让升级的服务影响和改动最小以及提供通用的解决方案的提前进行选择的。 1.1版本说明 升级前&a…

js进阶 事件循环(持续更新)

导入 js是单线程&#xff0c;同一时间只能做一件事&#xff0c;事件循环(EventLoop)来打破这个局面 异步任务 ajax网络请求setTimeout定时函数 简易粗糙的事件循环 同步任务进入主线程主执行栈异步任务进入任务队列主任务栈任务执行完毕&#xff0c;从任务队列读取对应任务…

npm怎么迁移到pnpm

下载的vue3模板用到了pnpm&#xff0c;就安装了一下 但是安装之后使用pnpm install 就发现包全被移动到ignored文件夹下面了,还报错 PS G:\Projects\gitProeject\TS_front> pnpm installWARN  Moving commitlint/config-conventional that was installed by a different …