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

项目管理套路:看这一篇绝对够用❤️

在这里插入图片描述

写论文必不可少的,就是创建代码并进行实验。好的项目管理可以让实验进行得更加顺利。本篇博客以一次项目实践为例,介绍项目管理的方法,以及可能遇到的问题,并提供一些可行的解决方案。

目录

  • 项目管理工具
  • 开始第一步
  • 版本管理十分关键
  • 如何进行版本管理
    • 创建分支
    • 进行改动
    • 添加改动与上传
    • 分支带来的新问题
    • 常用的git使用命令
  • 一些技巧让项目管理更简单
    • 项目结构构建
    • Commit规范
    • 文档与注释
  • 总结

项目管理工具

项目管理困难的主要原因在于,项目并非一个人构建的。许多人同时写代码,就容易出现:A改了代码的同时,B也改了代码,二人改了同一块代码,导致项目版本出现分歧的情况。这个时候,采用一个好用的项目管理工具,则可以很好地解决版本冲突的情况。Github则是一款以解决版本冲突为目标的项目管理工具,该工具跨平台皆可使用,并且简单易用,因而成为广大程序员经常使用的项目管理工具。本篇博客也就以此为工具展开对项目管理方法的经验介绍。

开始第一步

在注册完github账号之后,你就可以开始项目管理了。一般而言,项目开始之初,我们并没有一个程序项目,因而我们需要先构建一个程序项目。进入个人主页后可以在左侧个人拥有的项目库(Repositories)中找到新建(New)的按钮,点击进去后会看到这样的画面。
请添加图片描述
新建一个项目之前,需要先给项目起一个名字并填在Repository name那里,在Description那里可以填写对项目的介绍(ps: 对项目的理解越深刻,就可以用越简短的话介绍清楚这个项目到底要做什么。写Description有助于后续进行比对,并检查是否按照计划完成项目),同时还可以选择该项目是否公众可见(Public or Private),在初始化的时候可以选择添加一个README文件(ps: 建议初始化的时候就带上README文件,可以在里面写一些需要项目参与者提前知道的先验知识)。
请添加图片描述
除此之外,还可以添加.gitignore文件来指定每次git add以及git push的时候是否需要忽略一些文件(ps:每次进行实验都会产生许多中间文件,如果都把它们git push到repo里,显然会浪费很多网络资源,不利于项目开发);license这个功能限制了他人对你开源代码库的程度,不同license有不同的规则,具体请见官方文档(ps: 这个不需要在最开始就决定下来,初始化一个项目的时候并不一定要确认此项,不过为了后期开源代码能得到更多的关注,可以随着项目进展再思考license如何选择)。
请添加图片描述
建好一个代码项目,应该会有一个这样的结果。可以发现,初始化README里面的内容就是我们最开始在Description栏里写的东西。个人认为这个界面十分简洁美观,github为项目开发提供的功能其实都已经集成在这一个界面上了。菜单栏里可以看到有以下功能:

  • Code: 项目代码在这个界面里,做出的改动也会都体现在这里面
  • Issue: 这里类似于一个论坛,项目参与者可以在这里提出问题,其他参与者可以在这里进行讨论与解答问题(ps: 项目进行的过程中总会遇到许多奇奇怪怪的问题,这些问题大家共同商量出一个结果会比一个人自己闷头解决更靠谱一些,这里可以帮助项目参与者达成共识,可以有效提升项目的质量)。
  • Pull Request: 把其他分支上的代码拉到master分支上,并进行版本的融合。每个项目参与者会提供一部分功能代码,这些代码规范的写法是在不同的分支上,在各自分支上测试无误后,再由管理者将其merge到master主分支上。这一过程被称为pull request,其功能实现则可以在这个界面里实现。
  • Action: 创建工作流以自动化测试以及其他关键操作(比如pull request)。
  • Projects: 将其他相关的github repo列举在这里,方便后来的项目参与者了解情况。
  • Wiki:对与项目更加详细的介绍,好多东西无法在项目的注释里、README文档里讲清楚,这部分信息可以都放在Wiki里进行详细介绍。(ps: 文档管理做的越好,项目质量越高,但是这部分在我看了众多项目后发现,得到的关注并不是很充足)。
  • Security: 安全设置。
  • Insights: 项目流量监督。
  • Settings: 项目其他关键设置。
    请添加图片描述

以上就是在项目创建之初,我们要在远端(也就是网站)上进行的操作,下面我们要将远端的repo与本地进行联系。
请添加图片描述
本地打开终端,并输入指令git clone [url]就可以从远端拉取刚刚初始化的项目代码,从而使得本地与远端形成一个联系。

⚠️这里可能会遇到一些坑:

  1. 网络失败:是指loss connection这种错,一般错因在于本地机器的网络太过拉胯,重启网络服务、重启机器、更改网络设置等一些操作往往可以解决(ps:不过有时候就算真的这么处理了,网络该连不上还是连不上,我实验室机器的网络太过拉胯,一把辛酸泪)
  2. 没有权限:这要在本地设置ssh key 然后上传到远端,具体操作详见官方文档。

例如,对于How2Code这个例子,我需要输入指令git clone https://github.com/Doris404/How2Code.git 然后就可以看到本地机器就有一个名为How2Code的文件夹,里面含有一个README文档,和远端的设定一样。

接下来我们就可以进行项目开发了 ❤️

版本管理十分关键

Github解决的最核心的问题就是版本管理。我们先来了解一下这个问题究竟有多复杂。我将用一个例子来解释此问题的复杂程度。

一个三人团队要构建项目实现网上订餐功能,三人在项目初始阶段约定,一人实现一个功能,并且初步商定的功能包括:查询可点餐馆及可点菜品、下单与付款、评价与点评、纠纷处理等。

A作为项目主要负责人实现了下单与付款这个最复杂的功能,B实现查询可点餐馆及可点菜品,C实现评价与点评、纠纷处理这两个功能。

划分功能时大家一致认为,这些代码互相独立性比较强,所以三人分别在不同的机器上各自实现各自代码即可以做到版本管理。然而在项目进行过程中,出现了意想不到的情况。A下单与付款的功能实现依赖于B显示出来的界面。因此B最初实现的界面一旦发生改动,则A的代码实现也要跟着变更。在项目进行过程中则出现了以下情况:

  1. B 实现了一个初始界面
  2. A 基于初始界面进行功能实现,但于此同时B改动了一些初始界面,并形成了一个新版界面
  3. A 和 B都上传代码,此时A的代码不能在新版界面上测试通过,只能在初始界面上通过,但由于缺乏版本管理工具,此时的代码无法通过,并且我们遗失了初始界面。

Github提供了分支用于解决这个问题,同样是上述情况,如果我们使用branch,则是另一番景象:

  1. B实现了一个初始界面,并给它放在branch 1上
  2. A实现了基于初始界面的功能,传到branch 1上
  3. B改动初始界面,并形成新版界面,传到branch 2上

这样branch1的代码就是可以正常跑通的,而branch 2上则缺少A的代码,A则可以依据branch 1上自己实现的代码进行改动,并且提交到branch 2上。

相信从上述例子中,你已经明白了版本管理有多么关键。

如何进行版本管理

创建分支

Github提供了branch功能可以用于版本管理,这一部分我将介绍如何使用branch进行版本管理。在本地终端进入项目文件夹,输入git branch即查看当前分支名称。默认分支是master分支。
请添加图片描述
使用branch进行版本管理的第一步就是创建新的分支,运行git branch checkout -b [your branch name]即可以创建一个新的分支,并切换到这个新的分支上。
请添加图片描述

进行改动

此时你已经转到这个新的分支上了,就可以在这个新的分支上进行项目开发。例如,我改动了README文档,添加了一些文本。
请添加图片描述
则可以通过git status查看到我们哪些更改,然后决定是否要接受这些改动。

git add [your file name]则可以将对指定文档的改动添加到改动之中,如果在添加之后后悔了,可以使用git restore --staged [your file name]来撤销git add操作。执行结束后,你会发现刚才提交到改动中的改动被移除改动。

另一个git restore指令与刚才使用的git restore --staged [your file name]不一样,对没在改动中的改动git restore将撤销你在文件中做出的改动,执行结束后,在文档中的改动将消失。
请添加图片描述

添加改动与上传

git add .可以将所有的改动都添加到缓存之中,接着调用git commit -m "[your commit info]" 来添加改动的介绍,最后调用git push —-force-with-lease origin [your branch name]来将改动push到远端的指定分支。
请添加图片描述
远端可以看到,新分支创建成功,并且也有我们添加的改动请添加图片描述
请添加图片描述
可以发现,new_branch比master领先1个commit,我们可以对new_branch的改动进行比较,并决定是否merge到master分支。点击Compare & pull request则可以申请一个pull request对new_branch的改动进行融合。
请添加图片描述
填写new_branch具体做了什么改动,然后点击Create pull request即可以创建一个pull request。
请添加图片描述
创建成功后,其他参与者可以提交comment来发表对改动的建议。

值得注意的是该分支上还可以push 更多的改动。只要该分支上的改动没merge到master,在此之前该分支上的所有改动,都会集成到之前提交到pull request之中。
请添加图片描述
分支融合有3种可选方案,新手不建议选择Rebase and merge方案,建议从前2个方案中进行选择。前两个方案本质都是将改动以merge的形式加到master中,区别在于选Create a merge commit则将这两次改动分别merge进去,选Squash and merge则可以将2此commit 合并成一次commit。考虑到简洁性,建议选择Squash进行融合。

Rebase这个方法是三个方法中最为简洁的一种,它将以线性来融合改动,这同时也带来了风险。例如,如果new_branch改动和master改动出现冲突,则可能出现改动覆盖的情况,这意味着有一支的改动因为代码融合消失了。因而不建议初学者使用这个融合方式。

更多解释可以查看博客的介绍。
请添加图片描述
merge得到通过后,可以在master分支上看到之前的2次commit融合成1次commit提交到master分支上,并且commit info是第2次commit info。

至此,我们完成了一次基于分支的改动提交。

分支带来的新问题

分支提供了一个版本融合的方案,但是总会有一些菜鸟在初次使用的时候不太熟练,然后误把改动添加到master分支上,我们如何保护master分支呢?
请添加图片描述
Github提供一些规则来实现对主要分支的保护,点击Protect this branch,则可以添加规则来约束对master分支的改动(ps:这些改动也可以在setting-Branches里进行)。添加的规则种类繁多,包括每个分支的起名规则,分支提交的约束等等。
请添加图片描述
这里我选了在分支融合之前,必须要请求pull request至少1次(ps:其他的选项可以根据个人需求进行勾选)以及分支要符合标准的命名规则:name_file 分支所用者以及改动主文件名。

常用的git使用命令

git clone [url]
git branch # see which branch we are in
git checkout -b [branch name] # create a new branch and turn to this branch
git checkout [branch name] # turn to a exist branh
git add [your file name] # add your update into cache
git commit -m "[update info]" # add commit info
git push --force-with-lease origin [branch name] # push your update into [branch name]

⚠️ master分支代码就是最权威的,改动的时候一定要基于master分支,另开一个分支,然后再在这个新开的分支上改动代码,将改动push到这个新分支上,然后将此分支merge到master分支上。

一些技巧让项目管理更简单

除了上述基于Github功能的项目管理,我们也可以发动主观能动性来使得项目管理更加顺滑。

项目结构构建

在项目创建之初就应该对项目有一个明确的定位,这个项目到底实现什么功能,具体如何构建项目代码结构,才能有利于后续的代码书写,都是在项目之初有明确的定位的。这件事情非常重要!!!

至于如何获得明确的定位,是超出本篇博客的内容(ps:以我浅显的经验,明确的定位并不是一次讨论就能决定的,需要需求方和实现方多交流沟通确定)。

Commit规范

首先,就是commit info的书写规范,一般来说commit info是要做到提示参与者这次提交具体进行了哪些改动的功能,对于一个不了解情况的人而言,其能阅读的文本数量实在有限,因此需要提交者用最短的话描述出代码改动的核心。建议项目之初就总结一下commit info的书写规范,并强制要求所有参与者遵守。一个可选的例子是:

<type> (scope): describe
  • type:commit的类型说明,允许7种标识

feat: 添加新功能
fix: 修补bug
docs: 增加文档
style: 修改格式
refactor: 重构
test: 添加测试
chore: 构建过程或辅助工具的变动

  • scope:改动范围,比如某个包,某个文件
  • describe: 改动的描述,以动词开头,例如: update README.md

一个可能的例子就是:feat(train.py): add train.py表示这次改动添加了train.py文件实现了train的功能。

文档与注释

文档和注释对项目实现十分重要是所有程序员的共识,然而现实却是大家写文档和注释的意愿并不强烈。一方面是因为代码书写占据了大部分程序员的大部分时间,结束了一天辛劳工作的程序员实在没用动力去完成文档注释的书写;另一方面,文档与注释的确让项目实现变得更加简单易行,但是写文档的好处主要是体现在除去文档书写者的所有人身上,除非所有人都写文档和注释,否则文档和注释的坚持者将遗憾地发现自己做了最多的工作,而受益却是别人的。基于上述原因,文档与注释的书写情况总是不容乐观。

这篇博客不想对不写文档与注释的人进行道德上的谴责,毕竟偷懒是人之常情。本篇博客希望提供一个写文档的思路,来减少善良的程序员在写文档与注释时所承担的时间开销 ❤️

如何写文档才能提升写文档的效率呢?我的经验是,先确定文档的结构,通过子标题的形式来将文档结构简明地总结出来,然后填充每个子标题的具体内容。这样做有一个好处,可以极大地调动其他参与者的文档书写积极性。

例如,对于网上订餐项目,三人实现4个功能包括:查询可点餐馆及可点菜品、下单与付款、评价与点评、纠纷处理。A作为项目管理者,对于这个项目的结构有个非常明确的认识(至少要比B和C这两个参与者明确),因而它非常清楚本项目的代码包含从数据库获取信息模块,显示信息模块,交易模块,评价和售后模块。因而项目的文档结构也应符合项目代码结构,对这些模块进行各自的介绍。

对代码介绍的文档中则应包含这4个子标题,并且对这些模块的具体实现进行展开解释。代码实现上A对显示信息模块等非主写模块并不了解,因此他会将这部分文档书写交给给自负责的人。

上述介绍只是写文档的最基本介绍,更深入的技巧,建议读者阅读一些提升写作能力的工具书。

好消息是,文档的书写不止有手工书写这一种方法(ps:这好像是废话),一些项目文档生成工具可以帮助我们从注释生成文档。对于python代码而言,可以使用Sphinx包来轻松实现项目注释文档生成。具体使用参考博客。

注释对于我们理解函数功能有极大的作用,在写注释时可以参考一些优秀项目的注释书写规范,这里给出一个实例供读者参考。

class People(object):""" __init__Args:name(str): name of a personfather_name(str): father name of this personmother_name(str): mother name of this persongender(str): can only be male or femaleconfig(json): config file that may contain name, father_name, mother_name, genderReturns:a person from PeopleNotes:Some description of PeopleExamples:person = People(name = 'Doris404',father_name = 'Xiaoming',mother_name = 'Xiaohong',gender = 'female')"""def __init__(self, name, father_name, mother_name,gender,config):try:self.name = config['name']except:self.name = nametry:self.father_name = config['father_name']except:self.father_name = father_nametry:self.mother_name = config['mother_name']except:self.mother_name = mother_nametry:self.gender = config['gender']except:self.gender = gendertry:self.config = configexcept:pass

总结

以上是我在项目管理方面的经验,更多内容可以参考我的github repo,上述教程中的例子可以在How2Code repo中得到体现。

如果本篇博客可以帮到你的话,请给我一个赞吧,感谢 ❤️

相关文章:

项目管理套路:看这一篇绝对够用❤️

写论文必不可少的&#xff0c;就是创建代码并进行实验。好的项目管理可以让实验进行得更加顺利。本篇博客以一次项目实践为例&#xff0c;介绍项目管理的方法&#xff0c;以及可能遇到的问题&#xff0c;并提供一些可行的解决方案。 目录 项目管理工具开始第一步版本管理十分关…...

华为-算法---测试开发工程师----摘要牛客网

Java面试题---摘要牛客网-CSDN博客package extendNiuKeWang;import java.util.Scanner;public class GoodHuaWei {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int money = sc.nextInt();System.out.println("n值总金额:"+money)…...

python环境搭建-yolo代码跑通-呕心沥血制作(告别报错no module named torch)

安装软件 安装过的可以查看有没有添加环境变量 好的! 我们发车! 如果你想方便快捷的跑通大型项目,那么必须安装以下两个软件: 1.pycharm2.anaconda对应作用: pycharm:专门用来跑通python项目的软件,相当于一个编辑器,可以debug调试,可以接受远程链接调试!anaconda:专…...

Cisco Packet Tracer配置命令——路由器篇

路由基础 路由器用于互联两个或多个网络&#xff0c;具有两项功能&#xff1a;为要转发的数据包选择最佳路径以及将数据包交换到正确的端口&#xff0c;概括为路由选择和分组转发。 路由选择 路由选择就是路由器根据目的IP地址的网络地址部分&#xff0c;通过路由选择算法确…...

setContentsMargins(QMargins()) 是 QWidget 类的成员函数,用于设置小部件的内容边距(Contents Margins)

setContentsMargins(QMargins()) 是 QWidget 类的成员函数&#xff0c;用于设置小部件的内容边距&#xff08;Contents Margins&#xff09;。 在 Qt 中&#xff0c;内容边距指的是小部件内部内容与小部件边界之间的空白区域。通过设置内容边距&#xff0c;可以控制和调整小部…...

Redis key 过期监听实现

1.技术背景&#xff0c;想知道 redis 设置了TTL时间的key 过期&#xff0c;且有后续的业务处理的场景可以使用。 bug点&#xff1a; 使用redis 缓存失效监听会有一定的延迟&#xff0c; 过期事件是在redis服务器删除键的时候生成的&#xff0c;而不是在理论上生存时间到达0值得…...

Gee教程2.上下文Context

先来看看Gin框架的简单例子 func main() {engine : gin.Default()engine.GET("/", func(c *gin.Context) {c.String(http.StatusOK, "hello World!")})//监听并启动服务&#xff0c;默认 http://localhost:8080/engine.Run() }//我们自己写的 func main()…...

【从浅识到熟知Linux】基本指定之cat、more和less

&#x1f388;归属专栏&#xff1a;从浅学到熟知Linux &#x1f697;个人主页&#xff1a;Jammingpro &#x1f41f;每日一句&#xff1a;写完这篇我要去吃晚饭啦&#xff01;&#xff01; 文章前言&#xff1a;本文介绍cat、more和less指令三种查看文件的用法并给出示例和截图…...

2018年7月24日 Go生态洞察:Go Cloud实现便携式云编程

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…...

storyBook常见踩坑报错 和 解决

用StoryBook官网的代码&#xff0c;但报错&#xff0c;Unexpected token’<’ 在js文件中// Button.stories.js|jsx import { Button } from ‘./Button’; export default { component: Button, }; /* *&#x1f447; Render functions are a framework specific featur…...

python 笔记 根据用户轨迹+基站位置,估计基站轨迹+RSRP

1 问题描述 已知用户实际的轨迹&#xff0c;和基站的位置&#xff0c;能不能得到用户所连接的基站&#xff0c;以及基站的信号强度RSRP&#xff1f; 1.1 几个假设 这里我们做几个假设&#xff1a; 每个用户有80%的概率连接最近的基站&#xff0c;有20%的概率选择其他的基站连…...

RocketMQ 安装部署及应用场景记录

文章目录 前言一、RocketMQ简介1.1 整体架构 二、RocketMQ安装部署2.1 RocketMQ 下载2.2 修改 JVM 参数2.3 启动 NameServer 和 Broker2.4 验证发送和接受消息2.5 停止 NameServer 和 Broker2.6 配置全局环境 三、RocketMQ应用场景3.1 异步处理3.2 应用解耦3.3 流量削峰 前言 …...

人工智能面面观

人工智能简介 人工智能&#xff08;Artificial Intelligence&#xff0c;简称AI&#xff09;是一门研究如何使计算机能够模拟和执行人类智能任务的科学和技术领域。它致力于开发能够感知、理解、学习、推理、决策和与人类进行交互的智能系统。人工智能的背景可以追溯到上世纪50…...

vue-router的使用技巧

一、安装 npm install vue-router 二、引入 main.ts引入 import { createApp } from vue import App from ./App.vue import router from ./routerconst app createApp(App)app.use(router) app.mount(#app)三、定义路由文件 路由的参数 meta添加路由的其他参数 redire…...

CV计算机视觉每日开源代码Paper with code速览-2023.11.21

点击CV计算机视觉&#xff0c;关注更多CV干货 论文已打包&#xff0c;点击进入—>下载界面 点击加入—>CV计算机视觉交流群 1.【基础网络架构&#xff1a;Transformer】Multi-entity Video Transformers for Fine-Grained Video Representation Learning 论文地址&…...

人工智能对当代生活的影响

人工智能&#xff08;AI&#xff09;是指通过模拟人类智能的方式&#xff0c;使机器能够执行某些需要智能的任务。随着技术的快速发展和应用的广泛推广&#xff0c;人工智能已经深入到我们的日常生活中&#xff0c;对我们的生活和社会产生了深远的影响。本文将探讨人工智能对当…...

笔记:如何搭建一套前端监控系统?(持续更新中)

数据敏感处理 数据加密&#xff0c;对涉及用户隐私的数据做到加密防护 独立部署&#xff0c;不和其它应用共享监控系统 不采集具体数据&#xff0c;只采集用户操作数据 错误采集 Runtime Error: JS运行错误&#xff0c;可通过error监听器捕获 load Error: 资源加载错误&#x…...

在 Ubuntu 上安装最新版的 Calibre

目录 前言 方法1&#xff1a;从 Ubuntu 的仓库安装 Calibre 卸载 Calibre 方法2&#xff1a;获取最新版本的 Calibre 卸载 Calibre 结语 前言 Calibre 是一款自由开源的电子书软件。下面介绍如何在 Ubuntu Linux 上安装它。 作为电子书管理的瑞士军刀&#xff0c;Calibre …...

docker基础学习笔记

文章目录 Docker简介Linux下安装DockerDocker常用命令Docker网络Docker存储docker-composedockerfile制作镜像私有仓库镜像导入导出参考 Docker简介 定义&#xff1a;Docker是一个开源的应用容器引擎优势&#xff1a; 一键部署&#xff0c;开箱即用&#xff1a;容器使用基于im…...

Could not resolve all files for configuration ‘:app:androidJdkImage‘.

在使用./gradlew build编译项目时候遇到了该问题&#xff0c;整体错误如下: * What went wrong: Configuration cache state could not be cached: field generatedModuleFile of com.android.build.gradle.tasks.JdkImageInput bean found in field compilerArgumentProvider…...

[2025CVPR]DeepVideo-R1:基于难度感知回归GRPO的视频强化微调框架详解

突破视频大语言模型推理瓶颈,在多个视频基准上实现SOTA性能 一、核心问题与创新亮点 1.1 GRPO在视频任务中的两大挑战 ​安全措施依赖问题​ GRPO使用min和clip函数限制策略更新幅度,导致: 梯度抑制:当新旧策略差异过大时梯度消失收敛困难:策略无法充分优化# 传统GRPO的梯…...

vscode里如何用git

打开vs终端执行如下&#xff1a; 1 初始化 Git 仓库&#xff08;如果尚未初始化&#xff09; git init 2 添加文件到 Git 仓库 git add . 3 使用 git commit 命令来提交你的更改。确保在提交时加上一个有用的消息。 git commit -m "备注信息" 4 …...

stm32G473的flash模式是单bank还是双bank?

今天突然有人stm32G473的flash模式是单bank还是双bank&#xff1f;由于时间太久&#xff0c;我真忘记了。搜搜发现&#xff0c;还真有人和我一样。见下面的链接&#xff1a;https://shequ.stmicroelectronics.cn/forum.php?modviewthread&tid644563 根据STM32G4系列参考手…...

Redis相关知识总结(缓存雪崩,缓存穿透,缓存击穿,Redis实现分布式锁,如何保持数据库和缓存一致)

文章目录 1.什么是Redis&#xff1f;2.为什么要使用redis作为mysql的缓存&#xff1f;3.什么是缓存雪崩、缓存穿透、缓存击穿&#xff1f;3.1缓存雪崩3.1.1 大量缓存同时过期3.1.2 Redis宕机 3.2 缓存击穿3.3 缓存穿透3.4 总结 4. 数据库和缓存如何保持一致性5. Redis实现分布式…...

iPhone密码忘记了办?iPhoneUnlocker,iPhone解锁工具Aiseesoft iPhone Unlocker 高级注册版​分享

平时用 iPhone 的时候&#xff0c;难免会碰到解锁的麻烦事。比如密码忘了、人脸识别 / 指纹识别突然不灵&#xff0c;或者买了二手 iPhone 却被原来的 iCloud 账号锁住&#xff0c;这时候就需要靠谱的解锁工具来帮忙了。Aiseesoft iPhone Unlocker 就是专门解决这些问题的软件&…...

linux arm系统烧录

1、打开瑞芯微程序 2、按住linux arm 的 recover按键 插入电源 3、当瑞芯微检测到有设备 4、松开recover按键 5、选择升级固件 6、点击固件选择本地刷机的linux arm 镜像 7、点击升级 &#xff08;忘了有没有这步了 估计有&#xff09; 刷机程序 和 镜像 就不提供了。要刷的时…...

学习STC51单片机31(芯片为STC89C52RCRC)OLED显示屏1

每日一言 生活的美好&#xff0c;总是藏在那些你咬牙坚持的日子里。 硬件&#xff1a;OLED 以后要用到OLED的时候找到这个文件 OLED的设备地址 SSD1306"SSD" 是品牌缩写&#xff0c;"1306" 是产品编号。 驱动 OLED 屏幕的 IIC 总线数据传输格式 示意图 …...

拉力测试cuda pytorch 把 4070显卡拉满

import torch import timedef stress_test_gpu(matrix_size16384, duration300):"""对GPU进行压力测试&#xff0c;通过持续的矩阵乘法来最大化GPU利用率参数:matrix_size: 矩阵维度大小&#xff0c;增大可提高计算复杂度duration: 测试持续时间&#xff08;秒&…...

在WSL2的Ubuntu镜像中安装Docker

Docker官网链接: https://docs.docker.com/engine/install/ubuntu/ 1、运行以下命令卸载所有冲突的软件包&#xff1a; for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done2、设置Docker…...

Maven 概述、安装、配置、仓库、私服详解

目录 1、Maven 概述 1.1 Maven 的定义 1.2 Maven 解决的问题 1.3 Maven 的核心特性与优势 2、Maven 安装 2.1 下载 Maven 2.2 安装配置 Maven 2.3 测试安装 2.4 修改 Maven 本地仓库的默认路径 3、Maven 配置 3.1 配置本地仓库 3.2 配置 JDK 3.3 IDEA 配置本地 Ma…...