当前位置: 首页 > news >正文

C#_事件_多线程(基础)

文章目录

    • 事件
      • 通过事件使用委托
    • 多线程(基础)
        • 进程:
        • 线程:
      • 多线程
        • 线程生命周期
        • 主线程
        • Thread 类中的属性和方法
        • 创建线程
        • 管理线程
        • 销毁线程

事件

事件(Event)本质上来讲是一种特殊的多播委托,只能从声明它的类中进行调用,基本上说是一个用户操作,如按键、点击、鼠标移动等等,或者是一些提示信息,如系统生成的通知。应用程序需要在事件发生时响应事件。例如,中断。

通过事件使用委托

事件在类中声明且生成,且通过使用同一个类或其他类中的委托与事件处理程序关联。包含事件的类用于发布事件,这被称为 发布器(publisher) 类。其他接受该事件的类被称为 订阅器(subscriber) 类。事件使用 发布-订阅(publisher-subscriber) 模型。

发布器(publisher) 是一个包含事件和委托定义的对象。事件和委托之间的联系也定义在这个对象中。发布器(publisher)类的对象调用这个事件,并通知其他的对象。

订阅器(subscriber) 是一个接受事件并提供事件处理程序的对象。在发布器(publisher)类中的委托调用订阅器(subscriber)类中的方法(事件处理程序)。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace _06_事件
{internal class Program{static void Main(string[] args){PublisherDome publisherDome=new PublisherDome();SubriberDome subscriberDome=new SubriberDome();publisherDome.MyEvent += new PublisherDome.Myentrust(subscriberDome.Print);publisherDome.SetValue("wuyifan");}}//定义一个发布器类public class PublisherDome{private string value;//在类的内部声明事件,首先必须先声明该事件的委托类型public delegate void Myentrust(string str);//基于上面的委托定义事件(当事件触发的时候,就会调用委托)public event Myentrust MyEvent;public void SetValue(string s){value = s;MyEvent(value);}}//订阅器类public class SubriberDome{public void Print(string str){Console.WriteLine(str);}}
}//-----------------------------------------------------------using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace _07_事件
{internal class Program{static void Main(string[] args){Son s=new Son();s.NoMenery += () =>{Console.WriteLine("爸爸知道了");};Console.WriteLine("按下回车就表示没钱了");Console.ReadLine();s.Buy();}}class Son{public delegate void NoMeneryDelegate();public event NoMeneryDelegate NoMenery;//一个买东西的方法public void Buy(){//只要买东西没钱了,就去执行委托NoMenery?.Invoke();}}
}//-------------------------------using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace _08_事件
{internal class Program{static Action fa;static void Main(string[] args){Son s = new Son() {Name="亦凡" };Father f =new Father() {Name="亦凡的爸爸" };Mother m = new Mother() { Name = "亦凡的妈妈" };//创建爸爸给钱的事件fa = () =>{f.Buy(10);s.Money += 10;Console.WriteLine($"爸爸给了10块钱,现在还有{s.Money}");if (f.Money <= 0){s.OnNoMonery -= fa;}};s.OnNoMonery += fa;s.OnNoMonery += () =>{m.Buy(20);s.Money += 20;Console.WriteLine($"妈妈给了20块钱,现在还有{s.Money}");};s.Buy(3);s.Buy(3);s.Buy(20);s.Buy(20);s.Buy(20);}}class People{public string Name { get; set; }public int Money { get;set; }public virtual void Buy(int m){Money -= m;Console.WriteLine($"{Name}花了{m}元,现在还有{Money}元");}}class Son : People{public Son() {Money = 10;}//声明一个事件 当儿子没钱的时候触发public event Action OnNoMonery;public override void Buy(int m){base.Buy(m);if (Money<=5){OnNoMonery.Invoke();}}}class Father : People{public Father(){Money = 20;}}class Mother : People{public Mother(){Money = 200;}}}
//----------------------------------
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace _09_事件
{internal class Program{static void Main(string[] args){Son s = new Son() { Name = "亦凡" };Father f = new Father() { Name = "亦凡的爸爸" };Mother m = new Mother() { Name = "亦凡的妈妈" };s.OnNoMonery += m.SonNoMoney;s.OnNoMonery += f.SonNoMoney;s.Buy(3);s.Buy(3);s.Buy(20);s.Buy(20);s.Buy(20);}}class People{public string Name { get; set; }public int Money { get; set; }public virtual void Buy(int m){Money -= m;Console.WriteLine($"{Name}花了{m}元,现在还有{Money}元");}}class Son : People{public Son(){Money = 10;}//声明一个事件 当儿子没钱的时候触发public event Action<Son> OnNoMonery;public override void Buy(int m){if (Money <= m){Console.WriteLine("钱不够,去要钱");OnNoMonery.Invoke(this);}base.Buy(m);if (Money<=5){OnNoMonery.Invoke(this);}}}class Father : People{public Father(){Money = 20;}//儿子没钱执行的方法public void SonNoMoney(Son s){Buy(10);s.Money+= 10;Console.WriteLine($"爸爸给了10块钱,现在还有{s.Money}");if (Money <= 0){Console.WriteLine($"{Name}没钱了");s.OnNoMonery -= SonNoMoney;}}}class Mother : People{public Mother(){Money = 200;}public void SonNoMoney(Son s){Buy(20);s.Money += 20;Console.WriteLine($"爸爸给了10块钱,现在还有{s.Money}");}}
}

多线程(基础)

进程:

进程并不是物理的东西,是虚拟出来的,是一种概念。当一个程序开始运行时,它就是一个进程,进程包括运行中的程序和程序所使用到的内存和系统资源。而一个进程又是由多个线程所组成的。是一种计算机概念,是程序在运行的时候,记录当前程序对计算机的各种资源的消耗。

线程:

线程是程序中的一个执行流,每个线程都有自己的专有寄存器(栈指针、程序计数器等),但代码区是共享的,即不同的线程可以执行同样的函数。也是一种计算机概念,线程是进程在响应操作的时候一个最小的单元,也包括CPU/硬盘/内存等。

在这里插入图片描述

多线程

多线程就是多个线程同时工作的过程,我们可以将线程看作是程序的执行路径,每个线程都定义了一个独特的控制流,用来完成特定的任务。如果您的应用程序涉及到复杂且耗时的操作,那么使用多线程来执行是非常有益的。使用多线程可以节省 CPU 资源,同时提高应用程序的执行效率,例如现代操作系统对并发编程的实现就用到了多线程。到目前为止我们编写的示例程序都是单线程的应用程序,这样的应用程序一次只能执行一个任务。

线程生命周期

线程生命周期开始于我们创建 System.Threading.Thread 类对象的时候,当线程被终止或完成执行时生命周期终止。

下面列出了线程生命周期中的各种状态:

  • 未启动状态:当线程实例被创建但 Start 方法未被调用时的状况;
  • 就绪状态:当线程准备好运行并等待 CPU 周期时的状况;
  • 不可运行状态:下面的几种情况下线程是不可运行的:
    • 已经调用 Sleep 方法;
    • 已经调用 Wait 方法;
    • 通过 I/O 操作阻塞。
  • 死亡状态:当线程已完成执行或已中止时的状况。
主线程

在 C# 中,System.Threading.Thread 类用于处理线程,它允许在多线程应用程序中创建和访问各个线程。在多线程中执行的第一个线程称为主线程,当 C# 程序开始执行时,将自动创建主线程,而使用 Thread 类创建的线程则称为子线程,您可以使用 Thread 类的 CurrentThread 属性访问线程。

            Thread th =Thread.CurrentThread;th.Name = "主线程";Console.WriteLine(th.Name);
Thread 类中的属性和方法

下表列出了 Thread 类中一些常用的属性:

属性描述
CurrentContext获取线程正在执行的上下文
CurrentCulture获取或设置当前线程的区域性
CurrentPrincipal获取或设置线程的当前负责人(对基于角色的安全性而言)
CurrentThread获取当前正在运行的线程
CurrentUICulture获取或设置资源管理器使用的当前区域性以便在运行时查找区域性特定的资源
ExecutionContext获取一个 ExecutionContext 对象,该对象包含有关当前线程的各种上下文的信息
IsAlive获取当前线程的执行状态
IsBackground获取或设置一个值,该值表示某个线程是否为后台线程
IsThreadPoolThread获取线程是否属于托管线程池
ManagedThreadId获取当前托管线程的唯一标识符
Name获取或设置线程的名称
Priority获取或设置线程的调度优先级
ThreadState获取当前线程的状态

下表列出了 Thread 类的一些常用的方法:

方法名描述
public void Abort()在调用此方法的线程上引发 ThreadAbortException,以终止此线程
public static LocalDataStoreSlot AllocateDataSlot()在所有的线程上分配未命名的数据槽,为了获得更好的性能,请改用以 ThreadStaticAttribute 特性标记的字段
public static LocalDataStoreSlot AllocateNamedDataSlot(string name)在所有线程上分配已命名的数据槽,为了获得更好的性能,请改用以 ThreadStaticAttribute 特性标记的字段
public static void BeginCriticalRegion()通知主机执行将要进入一个代码区域,在该代码区域内线程中止或未经处理的异常的影响可能会危害应用程序域中的其他任务
public static void BeginThreadAffinity()通知主机托管代码将要执行依赖于当前物理操作系统线程的标识指令
public static void EndCriticalRegion()通知主机执行将要进入一个代码区域,在该代码区域内线程中止或未经处理的异常仅影响当前任务
public static void EndThreadAffinity()通知主机托管代码已执行完依赖于当前物理操作系统线程的标识指令
public static void FreeNamedDataSlot(string name)为进程中的所有线程消除名称与数据槽之间的关联。为了获得更好的性能,请改用以 ThreadStaticAttribute 特性标记的字段
public static Object GetData(LocalDataStoreSlot slot)检索当前线程中指定的值。为了获得更好的性能,请改用以 ThreadStaticAttribute 特性标记的字段
public static AppDomain GetDomain()返回当前线程运行的域
public static AppDomain GetDomainID()返回应用程序域的唯一标识符
public static LocalDataStoreSlot GetNamedDataSlot(string name)查找已命名的数据槽。为了获得更好的性能,请改用以 ThreadStaticAttribute 特性标记的字段
public void Interrupt()中断处于 WaitSleepJoin 状态的线程
public void Join()在继续执行标准的 COM 和 SendMessage 消息泵处理期间,阻塞调用线程,直到某个线程终止为止。此方法有不同的重载形式
public static void MemoryBarrier()按如下方式同步内存访问:执行当前线程的处理器在对指令重新排序时不能采用先执行 MemoryBarrier 调用之后的内存存取,再执行 MemoryBarrier 调用之前的内存存取的方式
public static void ResetAbort()取消为当前线程请求的 Abort
public static void SetData(LocalDataStoreSlot slot, Object data)在当前正在运行的线程上的指定槽中为此线程的当前域设置数据。为了获得更好的性能,请改用以 ThreadStaticAttribute 特性标记的字段
public void Start()开始一个线程
public static void Sleep(int millisecondsTimeout)让线程暂停一段时间
public static void SpinWait(int iterations)让线程等待一段时间,时间长短由 iterations 参数定义
public static byte VolatileRead(ref byte address) public static double VolatileRead(ref double address) public static int VolatileRead(ref int address) public static Object VolatileRead(ref Object address)读取字段值。无论处理器的数目或处理器缓存状态如何,该值都是由计算机处理器写入的最新值
public static void VolatileWrite(ref byte address, byte value) public static void VolatileWrite(ref double address, double value) public static void VolatileWrite(ref int address, int value) public static void VolatileWrite(ref Object address, Object value)立即向字段中写入一个值,并使该值对计算机中的所有处理器都可见
public static bool Yield()终止当前正在调用的线程并执行另一个准备运行的线程(由操作系统选择将要执行的另一个线程)
创建线程

C# 是通过扩展 Thread 类来创建线程的,然后使用扩展的 Thread 类调用 Start() 方法开始执行子线程。

  static void Main(string[] args){ThreadStart childref = new ThreadStart(CallToChildThread);Console.WriteLine("在Main函数中创建子线程");Thread childThead = new Thread(childref);childThead.Start();}public static void CallToChildThread(){Console.WriteLine("执行子线程");}
管理线程

Thread 类提供了各种管理线程的方法,比如可以使用 sleep() 方法使线程在特定时间段内暂停,

      static void Main(string[] args){ThreadStart childref = new ThreadStart(CallToChildThread);Console.WriteLine("在Main函数中创建子线程");Thread childThead = new Thread(childref);childThead.Start();}public static void CallToChildThread(){Console.WriteLine("执行子线程");Console.WriteLine("子线程暂停5秒");Thread.Sleep(5000);//毫秒Console.WriteLine("继续执行子线程");}
销毁线程

Thread 类中提供了 Abort() 方法用于销毁线程,Abort() 方法会抛出一个 threadabortexception 异常来中止线程,这个异常不能被捕获,

  static void Main(string[] args){ThreadStart childref = new ThreadStart(CallToChildThread);Console.WriteLine("在Main函数中创建子线程");Thread childThead = new Thread(childref);childThead.Start();Thread.Sleep(2000);Console.WriteLine("在Main函数终止子线程");childThead.Abort();}public static void CallToChildThread(){try{Console.WriteLine("执行子线程");for (int i = 0; i <= 10; i++) {Thread.Sleep(500);Console.WriteLine(i);}Console.WriteLine("子线程执行完成");}catch (ThreadAbortException e){Console.WriteLine("线程终止"+e);}finally{Console.WriteLine("无法捕获线程异常");}}## 上期习题答案
1. 模拟ListMyList<int> myList1 = new MyList<int>();​      myList1.Add(1);​      myList1.Add(20);  2. 自定义 ForEach  FindIndex  Find....
```C
//using System;
//using System.Collections.Generic;
//using System.Linq;
//using System.Text;
//using System.Threading.Tasks;
//delegate bool MyFunc<T>(T v);
//namespace _03_昨天
//{
//    internal class Program
//    {
//        static void Main(string[] args)
//        {
//            int[] ints = { 1,  3, 6 };
//            string[] strings = { "亦凡1", "亦凡2", "罗祥", "李迪" };
//            //根据传入的数组和方法,从前往后查询,返回第一个满足条件的数据
//            //Find的工作原理:循环该数组,并且每次循环调用传递的方法,并且将当前的数据通过参数传递到方法中,如果方法返回了true,则Find直接返回当前这个参数
//            //参数1:查询的数组
//            //参数2:一个函数,这个函数应该返回一个布尔值,表示当前数值是否满足条件
//            //如果数组中没有满足条件的数组,则返回该类型的默认值
//             int num=  MyArray.MyFind<int>(ints, FnEven);
//             Console.WriteLine(num);
//             string str = MyArray.MyFind(strings, FnWu);
//             Console.WriteLine(str);//        }
//        public static bool FnEven(int v)
//        {
//            return v % 2 == 0;
//        }
//        public static bool FnWu(string v)
//        {
//            return v.StartsWith("吴");
//        }//    }//    class MyArray
//    {
//        public static T MyFind<T>(T[] arr, MyFunc<T> fn)
//        {
//            for (int i = 0; i < arr.Length; i++)
//            {
//                if (fn(arr[i]))
//                {
//                    return arr[i];
//                }
//            }
//            return default(T);
//        }
//    }
//}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
//delegate bool MyFunc<T>(T v);
namespace _03_昨天
{internal class Program{static void Main(string[] args){int[] ints = { 1, 3, 6 };string[] strings = { "亦凡1", "亦凡2", "志祥", "云迪" };//根据传入的数组和方法,从前往后查询,返回第一个满足条件的数据//Find的工作原理:循环该数组,并且每次循环调用传递的方法,并且将当前的数据通过参数传递到方法中,如果方法返回了true,则Find直接返回当前这个参数//参数1:查询的数组//参数2:一个函数,这个函数应该返回一个布尔值,表示当前数值是否满足条件//如果数组中没有满足条件的数组,则返回该类型的默认值int num = MyArray.MyFind(ints,v=>v%2==0);Console.WriteLine(num);string str = MyArray.MyFind(strings, FnWu);Console.WriteLine(str);MyArray.MyForEach(ints, (v,i) =>{Console.WriteLine($"v=={v}");Console.WriteLine($"i=={i}");});}public static bool FnEven(int v){return v % 2 == 0;}public static bool FnWu(string v){return v.StartsWith("吴");}}class MyArray{public static T MyFind<T>(T[] arr, Func<T,bool> fn){for (int i = 0; i < arr.Length; i++){if (fn(arr[i]))return arr[i];}return default(T);}public static void MyForEach<T>(T[]arr,Action<T,int> fn){for (int i = 0; i < arr.Length; i++){fn(arr[i],i);}}}
}

觉得本篇文章写的还不错可以点赞,收藏,关注。主页有21天速通C#教程欢迎订阅!!!

在这里插入图片描述

相关文章:

C#_事件_多线程(基础)

文章目录 事件通过事件使用委托 多线程(基础)进程:线程: 多线程线程生命周期主线程Thread 类中的属性和方法创建线程管理线程销毁线程 事件 事件&#xff08;Event&#xff09;本质上来讲是一种特殊的多播委托&#xff0c;只能从声明它的类中进行调用,基本上说是一个用户操作&…...

vue 通过插槽来分配内容

通过插槽来分配内容 一些情况下我们会希望能和 HTML 元素一样向组件中传递内容&#xff1a; <AlertBox>Something bad happened. </AlertBox> 这可以通过 Vue 的自定义 <slot> 元素来实现&#xff1a; <template><div class"alert-box&quo…...

YOLO图像前处理及格式转换

import cv2 import numpy as np import os import glob# 数据增强函数 def augment_data(img):rows,cols,_ img.shape# 水平翻转图像if np.random.random() > 0.5:img cv2.flip(img, 1)img_name os.path.splitext(save_path)[0] "_flip.png"cv2.imwrite(img_n…...

ES6 学习(二)-- 字符串/数组/对象/函数扩展

文章目录 1. 模板字符串1.1 ${} 使用1.2 字符串扩展(1) ! includes() / startsWith() / endsWith()(2) repeat() 2. 数值扩展2.1 二进制 八进制写法2.2 ! Number.isFinite() / Number.isNaN()2.3 inInteger()2.4 ! 极小常量值Number.EPSILON2.5 Math.trunc()2.6 Math.sign() 3.…...

《VMamba》论文笔记

原文链接&#xff1a; [2401.10166] VMamba: Visual State Space Model (arxiv.org) 原文笔记&#xff1a; What&#xff1a; VMamba: Visual State Space Model Why&#xff1a; 多年以来CNN和VIT作为视觉特征提取的主流框架 CNN具有模型简单&#xff0c;共享权重&…...

手机真机连接USB调试adb不识别不显示和TCPIP连接问题

手机真机连接USB调试adb devices不显示设备和TCPIP连接 本文手机型号为NOVA 7 &#xff0c;其他型号手机在开发人员模式打开等方式可能略有不同&#xff0c;需根据自己的手机型号修改。 文章目录 1. 打开和关闭开发者模式2. 真机USB连接调试adb不显示设备问题的若干解决方法3…...

MySQL分表后,如何做分页查询?

参考: https://blog.csdn.net/qq_44732146/article/details/127616258 user.sql 完整的执行一遍&#xff0c;可以做到分表和分页 数据是实时的&#xff0c;往一张子表里插入之后&#xff0c;all表就能立刻查询到 在这里实现分页查询的是MyIsam引擎&#xff0c;这个引擎不支持…...

【Deep Learning 11】Graph Neural Network

&#x1f31e;欢迎来到图神经网络的世界 &#x1f308;博客主页&#xff1a;卿云阁 &#x1f48c;欢迎关注&#x1f389;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; &#x1f31f;本文由卿云阁原创&#xff01; &#x1f4c6;首发时间&#xff1a;&#x1f339;2024年3月20日…...

http和https的工作原理是什么?

HTTP&#xff08;HyperText Transfer Protocol&#xff09;和HTTPS&#xff08;HyperText Transfer Protocol Secure&#xff09;是两种用于在互联网上传输数据的主要协议&#xff0c;它们均用于在客户端&#xff08;通常是Web浏览器&#xff09;与服务器之间交换信息。尽管它们…...

STL中容器、算法、迭代器

STL标准模板库封装了常用的数据结构和算法&#xff0c;让程序员无需太关心真实的数据结构实现。 容器 容器&#xff1a;用来存放数据的。 STL容器就是将运用最广泛的的一些数据结构实现出来。 常用的数据结构有&#xff1a;数组、链表、树、栈、队列、集合、映射表。 这些…...

深入并广泛了解Redis常见的缓存使用问题

Redis 作为一门主流技术&#xff0c;缓存应用场景非常多&#xff0c;很多大中小厂的项目中都会使用redis作为缓存层使用。 但是Redis作为缓存&#xff0c;也会面临各种使用问题&#xff0c;比如数据一致性&#xff0c;缓存穿透&#xff0c;缓存击穿&#xff0c;缓存雪崩&#…...

nginx界面管理工具之nginxWebUI 搭建与使用

nginx界面管理工具之nginxWebUI 搭建与使用 一、nginxWebUI 1.nginx网页配置工具 官网地址: http://www.nginxwebui.cn 源码地址&#xff1a;https://git.chihiro.org.cn/chihiro/nginxWebUI 2.功能说明 本项目可以使用WebUI配置nginx的各项功能, 包括http协议转发, tcp协议…...

linux下 罗技鼠标睡眠唤醒问题的解决

sudo dmesg | grep Logitech | grep -o -P "usb.?\s" 得到3-2&#xff0c;用上面这条命令得到哪个usb口。 下面这条命令禁用罗技鼠标睡眠唤醒系统&#xff08;3-2改成你自己电脑上得到的usb口&#xff09; sudo sh -c "echo disabled > /sys/bus/usb/devic…...

架构师之路--Docker的技术学习路径

Docker 的技术学习路径 一、引言 Docker 是一个开源的应用容器引擎&#xff0c;它可以让开发者将应用程序及其依赖包打包成一个可移植的容器&#xff0c;然后在任何支持 Docker 的操作系统上运行。Docker 具有轻量级、快速部署、可移植性强等优点&#xff0c;因此在现代软件开…...

【动手学深度学习-pytorch】 9.4 双向循环神经网络

在序列学习中&#xff0c;我们以往假设的目标是&#xff1a; 在给定观测的情况下 &#xff08;例如&#xff0c;在时间序列的上下文中或在语言模型的上下文中&#xff09;&#xff0c; 对下一个输出进行建模。 虽然这是一个典型情景&#xff0c;但不是唯一的。 还可能发生什么其…...

网际协议 - IP

文章目录 目录 文章目录 前言 1 . 网际协议IP 1.1 网络层和数据链路层的关系 2. IP基础知识 2.1 什么是IP地址? 2.2 路由控制 3. IP地址基础知识 3.1 IP地址定义 3.2 IP地址组成 3.3 IP地址分类 3.4 子网掩码 IP地址分类导致浪费? 子网与子网掩码 3.5 CIDR与…...

DC-9靶场

一.环境搭建 1.下载地址 靶机下载地址&#xff1a;https://download.vulnhub.com/dc/DC-9.zip 2.虚拟机配置 设置虚拟机为nat&#xff0c;遇到错误点重试和是 开启虚拟机如下图所示 二.开始渗透 1. 信息收集 查找靶机的ip地址 arp-scan -l 发现靶机的ip地址为192.168.11…...

自定义类型(二)结构体位段,联合体,枚举

这周一时兴起&#xff0c;想写两篇文章来拿个卷吧&#xff0c;今天也是又来写一篇博客了&#xff0c;也是该结束自定义类型的学习与巩固了。 常常会回顾努力的自己&#xff0c;所以要给自己的努力留下足迹。 为今天努力的自己打个卡&#xff0c;留个痕迹吧 2024.03.30 小闭…...

MySQL5.7源码分析--解析

select语句会走的case COM_QUERY判断 具体流程如下&#xff1a; 1.获取网络包数据&#xff0c;拿到查询语句&#xff0c;放入thd->query alloc_query(thd, packet, packet_length) 2.先查询缓存&#xff0c;缓存命中直接返回结果&#xff0c;未命中则解析 功能集中在mys…...

windows10搭建reactnative,运行android全过程

环境描述 win10,react-native-cli是0.73&#xff0c;nodeJS是20&#xff0c;jdk17。这都是完全根据官网文档配置的。react-native环境搭建windows。当然官网文档会更新&#xff0c;得完全按照配置来安装&#xff0c;避免遇到环境不兼容情况。 安装nodeJS并配置 这里文档有详…...

通过Wrangler CLI在worker中创建数据库和表

官方使用文档&#xff1a;Getting started Cloudflare D1 docs 创建数据库 在命令行中执行完成之后&#xff0c;会在本地和远程创建数据库&#xff1a; npx wranglerlatest d1 create prod-d1-tutorial 在cf中就可以看到数据库&#xff1a; 现在&#xff0c;您的Cloudfla…...

在Ubuntu中设置开机自动运行(sudo)指令的指南

在Ubuntu系统中&#xff0c;有时需要在系统启动时自动执行某些命令&#xff0c;特别是需要 sudo权限的指令。为了实现这一功能&#xff0c;可以使用多种方法&#xff0c;包括编写Systemd服务、配置 rc.local文件或使用 cron任务计划。本文将详细介绍这些方法&#xff0c;并提供…...

Java 加密常用的各种算法及其选择

在数字化时代&#xff0c;数据安全至关重要&#xff0c;Java 作为广泛应用的编程语言&#xff0c;提供了丰富的加密算法来保障数据的保密性、完整性和真实性。了解这些常用加密算法及其适用场景&#xff0c;有助于开发者在不同的业务需求中做出正确的选择。​ 一、对称加密算法…...

GitHub 趋势日报 (2025年06月08日)

&#x1f4ca; 由 TrendForge 系统生成 | &#x1f310; https://trendforge.devlive.org/ &#x1f310; 本日报中的项目描述已自动翻译为中文 &#x1f4c8; 今日获星趋势图 今日获星趋势图 884 cognee 566 dify 414 HumanSystemOptimization 414 omni-tools 321 note-gen …...

Map相关知识

数据结构 二叉树 二叉树&#xff0c;顾名思义&#xff0c;每个节点最多有两个“叉”&#xff0c;也就是两个子节点&#xff0c;分别是左子 节点和右子节点。不过&#xff0c;二叉树并不要求每个节点都有两个子节点&#xff0c;有的节点只 有左子节点&#xff0c;有的节点只有…...

selenium学习实战【Python爬虫】

selenium学习实战【Python爬虫】 文章目录 selenium学习实战【Python爬虫】一、声明二、学习目标三、安装依赖3.1 安装selenium库3.2 安装浏览器驱动3.2.1 查看Edge版本3.2.2 驱动安装 四、代码讲解4.1 配置浏览器4.2 加载更多4.3 寻找内容4.4 完整代码 五、报告文件爬取5.1 提…...

【无标题】路径问题的革命性重构:基于二维拓扑收缩色动力学模型的零点隧穿理论

路径问题的革命性重构&#xff1a;基于二维拓扑收缩色动力学模型的零点隧穿理论 一、传统路径模型的根本缺陷 在经典正方形路径问题中&#xff08;图1&#xff09;&#xff1a; mermaid graph LR A((A)) --- B((B)) B --- C((C)) C --- D((D)) D --- A A -.- C[无直接路径] B -…...

MFC 抛体运动模拟:常见问题解决与界面美化

在 MFC 中开发抛体运动模拟程序时,我们常遇到 轨迹残留、无效刷新、视觉单调、物理逻辑瑕疵 等问题。本文将针对这些痛点,详细解析原因并提供解决方案,同时兼顾界面美化,让模拟效果更专业、更高效。 问题一:历史轨迹与小球残影残留 现象 小球运动后,历史位置的 “残影”…...

适应性Java用于现代 API:REST、GraphQL 和事件驱动

在快速发展的软件开发领域&#xff0c;REST、GraphQL 和事件驱动架构等新的 API 标准对于构建可扩展、高效的系统至关重要。Java 在现代 API 方面以其在企业应用中的稳定性而闻名&#xff0c;不断适应这些现代范式的需求。随着不断发展的生态系统&#xff0c;Java 在现代 API 方…...

在 Spring Boot 中使用 JSP

jsp&#xff1f; 好多年没用了。重新整一下 还费了点时间&#xff0c;记录一下。 项目结构&#xff1a; pom: <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://ww…...