不写代码、年薪百万,带你玩赚ChatGPT提示工程-高级提示

news2025/1/17 0:04:44

文章目录

  • 前言
  • 一、Zero-Shot提示
  • 二、Few-Shot 提示
    • Few-shot Prompting 的局限性
  • 三、Chain-of-Thought Prompting
  • 四、Zero-Shot CoT
  • 五、Self-Consistency
  • 六、Generated Knowledge 提示
  • 七、Automatic Prompt Engineer (APE)
  • 总结


前言

随着ChatGPT的大火,提示工程在大模型中的重要性不言而喻,本文参考国外Prompt Engineering Guide完成国内中文版本的《提示工程指南》,希望能够和大家一起交流,分享及发现提示工程的美妙之处。文章所有内容可以在ChatGPT_Prompt_Chinese中找到。

到这个时候,应该很明显了,改进提示可以帮助在不同任务上获得更好的结果。这就是提示工程的整个理念。

虽然那些例子很有趣,但在我们深入探讨更高级的概念之前,让我们更正式地介绍一些概念。


一、Zero-Shot提示

今天的大语言模型在大量数据的训练和调整指令后,能够进行zero-shot任务执行。我们实际上在前面部分尝试了一些zero-shot示例。这里是我们使用的一个示例:

Prompt:

将文本分类为中性、负面或积极。

文本:我认为这个假期还可以。
情感:

Output:

中性

请注意,在上面的提示中,我们没有提供模型任何示例——这就是zero-shot功能的作用。当zero-shot无法正常工作时,建议在Prompt中提供演示或示例。下面我们将讨论称为 few-shot 提示的方法。


二、Few-Shot 提示

尽管大型语言模型已经展示了显著的zero-shot能力,但当使用zero-shot设置时,它们在更复杂的任务上仍然表现不足。为了改进这一点,few-shot prompt被用作一种技术,以实现上下文学习,在Prompt中提供演示,以引导模型获得更好的性能。这些演示作为后续示例的条件,我们希望模型生成响应。

让我们通过一个在Brown et al. 2020中提出的示例来演示 few-shot 提示。在这个例子中,任务是在一个句子中正确使用一个新词。

Prompt:

"Whatpu" 是一种生长在坦桑尼亚的小型毛茸茸的动物。使用这个词的一个例子是:
我们在非洲旅行时看到了这些非常可爱的 whatpus。

"Farduddle" 的意思是快速地上下跳动。使用这个词的一个例子是:

Output:

Farduddle 这个词的一个例子是:我弟弟在床上快速地上下跳动,就像他正在做 farduddle 一样。

我们可以清楚地观察到,模型通过仅提供一个示例(即1-shot)学会了如何执行任务。对于更困难的任务,我们可以尝试增加演示次数(例如3-shot、5-shot、10-shot等)。

根据 Min et al. (2022),在进行 few-shot 时,以下是一些有关演示/范例的技巧:

  • “演示中指定的标签空间和输入文本的分布都是关键因素(无论标签是否正确)”
  • 即使只是使用随机标签,使用的格式也对性能起着关键作用,这比不使用标签要好得多。
  • 附加结果表明,从真实标签分布中选择随机标签(而不是均匀分布)也有帮助。
    让我们尝试一些示例。让我们首先尝试一个具有随机标签的示例(意味着将负面和积极标签随机分配给输入):

Prompt:

这很棒!// 负面
这很糟糕!// 积极
哇,那部电影太棒了!// 积极
多么可怕的表演!//

Output:

这很棒!// 积极
这很糟糕!// 负面
哇,那部电影太棒了!// 积极
多么可怕的表演!// 负面

尽管标签已被随机化,我们仍然得到了正确的答案。请注意,我们也保留了格式,这也有所帮助。实际上,通过进一步实验,我们正在进行的新型 GPT 模型似乎变得更加强大,即使是在随机格式下也是如此。例如:

Prompt:

积极 这太棒了!
这很糟糕!负面
哇,那部电影太棒了!
积极
多么可怕的表演!--

Output:

负面

Few-shot Prompting 的局限性

标准的 Few-shot Prompting 技术对于许多任务来说表现良好,但在处理更复杂的推理任务时仍不是一种完美的技术。让我们演示一下为什么会出现这种情况。您还记得我们之前提供的以下任务的例子吗?

这组数中的奇数加起来是一个偶数:15、32、5、13、82、7、1。

A:

如果我们再试一次,模型输出如下:

是的,这组数中的奇数加起来是一个偶数。

其中奇数有15、5、13、7、1,它们的和为41,是一个奇数。

这不是正确的回答,这不仅突显了这些系统的局限性,而且需要更先进的提示工程技术。让我们尝试添加一些示例,看看是否可以改善 Few-shot Prompting 的结果。
Prompt:

这组数中的奇数加起来是一个偶数:4、8、9、15、12、2、1。
A:答案是 False。

这组数中的奇数加起来是一个偶数:17、10、19、4、8、12、24。
A:答案是 True。

这组数中的奇数加起来是一个偶数:16、11、14、4、8、13、24。
A:答案是 True。

这组数中的奇数加起来是一个偶数:17、9、10、12、13、4、2。
A:答案是 False。

这组数中的奇数加起来是一个偶数:15、32、5、13、82、7、1。
A:

Output:

这组数中的奇数加起来是一个偶数:15、32、5、13、82、7、1。
A:答案是 False。

Few-shot Prompting 对于此类推理问题的已经能够获得可靠响应。上面的例子提供了任务的基本信息。如果您仔细观察,我们所介绍的任务类型涉及几个更多的推理步骤。换句话说,如果我们将问题分解成步骤,并向模型演示,可能会有所帮助。最近,chain-of-thought (CoT) prompting已经普及,用于解决更复杂的算术、常识和符号推理任务。

总的来说,提供示例对于解决一些任务是有用的。当零次提示和少次提示不足时,这可能意味着模型所学到的不足以胜任任务。因此,建议开始考虑微调您自己的模型或尝试更高级的提示技术。接下来,我们将讨论一种流行的提示技术,称为 chain-of-thought prompting,它已经广受欢迎。


三、Chain-of-Thought Prompting

Wei等人(2022)介绍了 chain-of-thought (CoT) prompting,它通过中间推理步骤实现复杂的推理能力。您可以将其与 Few-shot Prompting 结合使用,以在需要推理后响应的更复杂任务中获得更好的结果。

Prompt:

这组数中的奇数加起来是一个偶数:4、8、9、15、12、2、1。
A:将所有奇数相加(9、15、1),得到25。答案是 False。

这组数中的奇数加起来是一个偶数:17、10、19、4、8、12、24。
A:将所有奇数相加(17、19),得到36。答案是 True。

这组数中的奇数加起来是一个偶数:16、11、14、4、8、13、24。
A:将所有奇数相加(11、13),得到24。答案是 True。

这组数中的奇数加起来是一个偶数:17、9、10、12、13、4、2。
A:将所有奇数相加(17、9、13),得到39。答案是 False。

这组数中的奇数加起来是一个偶数:15、32、5、13、82、7、1。
A:

Output:

这组数中的奇数加起来是一个偶数:15、32、5、13、82、7、1。
A:答案是 False。

哇!我们可以看到当我们提供推理步骤时,结果是完美的。实际上,我们可以通过提供更少的示例来解决此任务,即只提供一个示例似乎就足够了:
Prompt:

这组数中的奇数加起来是一个偶数:4、8、9、15、12、2、1。
A:将所有奇数相加(9、15、1),得到25。答案是 False。

这组数中的奇数加起来是一个偶数:15、32、5、13、82、7、1。
A:

Output:

这组数中的奇数加起来是一个偶数:15、32、5、13、82、7、1。
A:答案是 False。因为将所有奇数相加(15、5、13、7、1),得到41,是一个奇数,不是偶数。

请记住,作者声称这是足够大的语言模型所产生的一种新兴能力。


四、Zero-Shot CoT

最近提出的一个新思路是 zero-shot CoT (Kojima等人 2022),其基本上涉及将“让我们一步步思考”添加到原始提示中。让我们尝试一个简单的问题,看看模型的表现如何:

Prompt:

我去市场买了10个苹果。我给了邻居2个苹果和给修理工2个苹果。然后我又去买了5个苹果,并吃了1个。我还剩下多少苹果?

Output:

我去市场买了10个苹果。我给了邻居2个苹果和给修理工2个苹果。然后我又去买了5个苹果,并吃了1个。我还剩下6个苹果。

答案是不正确的!现在让我们试试特殊提示的方式。
Prompt:

我去市场买了10个苹果。我给了邻居2个苹果和给修理工2个苹果。然后我又去买了5个苹果,并吃了1个。我还剩下多少苹果?

让我们一步步思考。

Output:

好的,让我们逐步解决这个问题。

我去市场买了10个苹果。

剩余苹果数:10个。

我给了邻居2个苹果和给修理工2个苹果。

剩余苹果数:6个。

然后我又去买了5个苹果。

剩余苹果数:11个。

并吃了1个。

剩余苹果数:10个。

所以,最后我还剩下10个苹果。

实际上,这个简单的提示在这个任务上非常有效,令人印象深刻。这在您没有太多示例可用于提示的情况下特别有用。


五、Self-Consistency

或许,对于提示工程来说,更高级的技术之一就是self-consistency。Wang et al. (2022)提出了自一致性的概念,旨在“取代链式思维提示中使用的简单贪婪解码”。其思路是通过少次 CoT 来采样多条不同的推理路径,并使用生成结果来选择最一致的答案。这有助于提高 CoT 提示在涉及算术和常识推理任务中的性能。

让我们尝试下面这个算术推理的例子:

Prompt:

当我6岁时,我的妹妹的年龄是我的一半。现在我70岁了,我的妹妹现在多少岁?

Output:

根据题目所给的信息,当我6岁时,我的妹妹的年龄是3岁(即6的一半)。由此可知,我和我的妹妹之间的年龄差是3岁。

现在我70岁了,所以我的妹妹比我小3岁,也就是67岁。因此,我的妹妹现在是67岁。

不得不说,chatgpt在这块儿已经比davinci-3 “聪明”了不少,已经能够正确回答这类算数推理的问题了。

Prompt:

问:林地里有15棵树。种植工人今天将在这个区域种植树木。完成后,这里将有21棵树。种植工人今天种了多少棵树?
答:开始有15棵树。后来有21棵树。差异必须是他们种植的树木数量。因此,他们必须种植21-15=6棵树。答案是6。

问:停车场里有3辆汽车,又来了2辆汽车,现在停车场里有多少辆汽车?
答:停车场里已经有3辆汽车。又来了2辆,现在有3+2=5辆汽车。答案是5。

问:莉娅有32块巧克力,她的姐姐有42块。如果他们吃掉了35块,他们现在总共剩下多少块巧克力?
答:莉娅有32块巧克力,她的姐姐有42块,这意味着原来有32+42=74块巧克力。已经吃掉了35块。所以他们现在总共剩下74-35=39块巧克力。答案是39。

问:杰森有20个棒棒糖。他给了丹尼一些棒棒糖。现在杰森只剩下12个棒棒糖。杰森给了丹尼多少个棒棒糖?
答:杰森有20个棒棒糖。由于他现在只有12个,所以他必须把剩下的都给了丹尼。他给丹尼的棒棒糖数量必须是20-12=8个棒棒糖。答案是8。

问:肖恩有5个玩具。圣诞节时,他从他的父母那里各得到了两个玩具。现在他有多少个玩具?
答:他有5个玩具。他从妈妈那里得到了2个,所以他现在有5+2=7个玩具。然后他从爸爸那里得到了另外2个,所以他总共有7+2=9个玩具。答案是9。

Q:服务器房里原本有九台电脑。从周一到周四,每天又增加了五台电脑。现在服务器房里有多少台电脑?
A:从周一到周四一共有四天,每天增加五台电脑。所以总共增加了4 * 5 = 20 台电脑。一开始有九台电脑,现在总共有 9 + 20 = 29 台电脑。答案是29。

Q:Michael有58个高尔夫球。周二他丢了23个高尔夫球,周三又丢了2个。到周三结束时他还有多少高尔夫球?
A:Michael最初有58个高尔夫球。周二他丢了23个,所以他还剩下58 - 23 = 35个高尔夫球。周三又丢了2个,现在他还剩下35 - 2 = 33个高尔夫球。答案是33。

Q:Olivia有23美元。她买了五个3美元的百吉饼。她还剩下多少钱?
A:她花了5 * 3 = 15美元买了五个百吉饼。所以她还剩下23 - 15 = 8美元。

Q:当我6岁时,我的姐姐的年龄是我的一半。现在我70岁了,我的姐姐多少岁?
A:

Output 1:

当我6岁时,我的姐姐比我大3岁,因为我的姐姐的年龄是我的一半加上3岁。现在我70岁了,经过64年,我的年龄是当初的10倍。所以,如果我的姐姐当初比我大3岁,现在她的年龄是10 * 3 = 30岁。因此,我的姐姐现在应该是70 + 30 = 100岁。

Output 2:

当我6岁时,我的姐姐的年龄比我大6岁,也就是12岁(6岁的两倍)。现在我70岁了,过去的时间是70-6=64年。由于这64年中,我的姐姐年龄始终比我大6岁,所以她的年龄应该是70-64+6=12岁+6岁=18岁。因此,我的姐姐现在应该是18岁。

Output 3:

当我6岁时,我的姐姐比我年龄大3岁,因为3是6的一半。现在我70岁了,那么我的姐姐的年龄就是70-3=67岁。

计算最终答案涉及几个步骤(请查看论文了解详情),但为了简单起见,我们可以清楚地看到已经出现了大多数的答案,因此那将成为最终答案。


六、Generated Knowledge 提示

大语言模型(LLMs)不断得到改进,其中一种流行的技术是能够整合知识或信息,以帮助模型进行更准确的预测。

使用类似的想法,模型是否也可以在进行预测之前生成知识?这正是 Liu et al. 2022在论文中尝试的内容——生成用作提示的知识。特别是,这对于常识推理等任务有多大帮助?

让我们试试一个简单的提示

Prompt:

高尔夫的一部分是试图获得比其他人更高的得分总数。是或不是?

Output:

是的,高尔夫的一部分是试图获得比其他人更高的得分总数。

这种错误揭示了大型语言模型在执行需要更多关于世界知识的任务时的局限性。我们如何通过知识生成来改进这一点?

首先,我们生成一些“知识”:
Prompt:

输入:希腊比墨西哥大。
知识:希腊面积约为131,957平方公里,而墨西哥约为1,964,375平方公里,使得墨西哥比希腊大了1,389%。

输入:眼镜总是会起雾。
知识:当汗水、呼吸和环境湿度中的水蒸气着陆在一个冷表面上时,会在眼镜镜片上产生冷凝,然后变成微小的液滴,形成你看到的雾气。与你的呼吸相比,镜片相对较冷,特别是在外部空气寒冷时。

输入:鱼有思维能力。
知识:鱼比它们表现出来的更聪明。在许多领域,例如记忆力,它们的认知能力与甚至超过非人灵长类动物等“高级”脊椎动物的认知能力。鱼的长期记忆帮助它们跟踪复杂的社交关系。

输入:一个人一生中吸烟量大,患肺癌的几率比正常人高。
知识:那些终身平均每天少于一支烟的人,患肺癌的风险是从未吸烟者的九倍。在每天吸烟1到10支烟之间的人中,死于肺癌的风险几乎比从未吸烟者高出12倍。

输入:一块石头和一颗卵石大小相同。
知识:卵石是岩石的一种,根据沉积学中的Udden-Wentworth比例尺,其粒径为4到64毫米。卵石通常被认为比颗粒(直径2到4毫米)大,比卵石(直径64到256毫米)小。

输入:高尔夫球的一部分是试图比其他人获得更高的分数。
知识:

Knowledge 1:

高尔夫球的目标是在球场上使用尽可能少的杆数将球打入洞中。高尔夫球手通过在每个洞上打出最少的杆数来获得更低的总分数。因此,高尔夫球的一部分是试图比其他人获得更低的分数,而不是更高的分数。

Knowledge 2:

知识:高尔夫球是一项球类运动,目的是将球打进被称为“洞”的小孔中,尽可能少地使用球杆。每个球场都有不同的“标准杆数”,即完成球场上所有洞的理论最少杆数。高尔夫球比赛通常是个人赛或团体赛,其中一部分是竞争比赛,试图比其他人获得更低的杆数,另一部分是计分赛,试图在规定杆数内取得最高的得分。

我们正在使用Liu et al. 2022的论文中提供的提示。

下一步是将知识整合并得出预测。我将问题重新格式化为问答格式,以指导答案的格式。
Prompt:

问题:高尔夫球的一部分是试图比其他人获得更高的分数。是或否?

知识:高尔夫球的目标是以最少的杆数打完一组洞。一般一场高尔夫球赛包括18个洞。每个洞在标准高尔夫球场上打一次。每一杆都算一分,总杆数用于确定比赛的获胜者。

解释和答案:

Answer 1 :

否。高尔夫球的目标是以最少的杆数打完一组洞,每一杆都算一分,总杆数用于确定比赛的获胜者。因此,高尔夫球的一部分是试图比其他人获得更低的分数。
问题:高尔夫球的一部分是试图比其他人获得更高的分数。是或否?

知识:高尔夫球是一项需要精密球杆技术的运动,参赛选手(或高尔夫球手)使用多种类型的球杆将球打进球场上的一系列洞中,以最少的杆数完成比赛。目标是用最少的杆数完成比赛,得分是通过计算每个洞上的杆数总和得出的。得分最低的球员获胜。

解释和答案:

Answer 2 (confidence is a lot lower):

回答:否。高尔夫球的目标是用最少的杆数完成比赛,得分是通过计算每个洞上的杆数总和得出的。因此,高尔夫球的一部分是试图比其他人获得更低的分数,得分最低的球员获胜。

在这个例子中发生了一些非常有趣的事情。在第一个答案中,模型非常自信,但在第二个答案中则不然。我为了演示目的而简化了这个过程,但在得出最终答案时还有一些细节需要考虑。请查阅论文以获取更多信息。


七、Automatic Prompt Engineer (APE)

在这里插入图片描述
Zhou et al., (2022)提出了一个名为“自动提示工程师”(APE)的框架,用于自动生成和选择指令。指令生成问题被构建为自然语言合成,使用LLMs解决黑盒优化问题来生成和搜索候选解决方案。

第一步涉及一个大型语言模型(作为推理模型),该模型给出输出演示,为任务生成指令候选项。这些候选解决方案将指导搜索过程。指令使用目标模型执行,然后根据计算的评估分数选择最适合的指令。

APE发现了比人工设计的“让我们一步一步地思考”(Kojima等人,2022年)更好的零样本CoT提示。

该提示“让我们一步一步地解决它,以确保我们有正确的答案。”引发了连锁思维,并提高了在MultiArith和GSM8K基准测试中的性能。

在这里插入图片描述
本文涉及一个与提示工程相关的重要主题,即自动优化提示的想法。虽然本指南不会深入探讨这个主题,但如果您对此感兴趣,以下是几篇关键论文:

  • AutoPrompt - 提出了一种基于梯度引导搜索的方法,用于自动创建各种任务的提示。
  • Prefix Tuning - 一种轻量级的Fine-tuning替代方案,为NLG任务准备一个可训练的连续前缀。
  • Prompt Tuning - 提出了一种通过反向传播学习软提示的机制。

总结

这篇文章我们介绍Prompt提示工程的一些高级示例,也对如何进一步调教大模型有了更深入的了解,在带你玩转ChatGPT
专栏中,我们会继续介绍ChatGPT的更多应用及实践案例。

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

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

相关文章

按键修改阈值功能、报警功能、空气质量功能实现

按键修改阈值功能 要使用按键,首先要定义按键。通过查阅资料,可知按键的引脚如图所示:按键1(S1)通过KEY0与PA0连接,按键2(S2)通过KEY1与PE2连接,按键3(S3&…

成本降低90%,OpenAI正式开放ChαtGΡΤ

今天凌晨,OpenAI官方发布ChαtGΡΤ和Whisper的接囗,开发人员现在可以通过API使用最新的文本生成和语音转文本功能。OpenAI称:通过一系列系统级优化,自去年12月以来,ChαtGΡΤ的成本降低了90%;现在OpenAI用…

供应链依赖:您的GitHub连接可能会触发什么?

不祥之兆,在针对 GitHub 存储库的攻击激增之后,很难避免。 最近的CircleCI漏洞(客户的机密和加密密钥被盗)清楚地表明,攻击者已经了解并利用了这个向量。 现在比以往任何时候都更需要公司保护这些非人类连接&#xf…

记录2023.3.3下午的校招

文章目录一、校招的总览意义😎二、校招时,公司是怎么做的?如何提问的?我又是怎么回答的🤔2.1 公司最喜欢提问你的问题🙌三、校招期间,我应该如何去了解一家企业?😀三、建…

LeetCode 982. 按位与为零的三元组 -- 哈希统计

按位与为零的三元组 困难 101 相关企业 给你一个整数数组 nums &#xff0c;返回其中 按位与三元组 的数目。 按位与三元组 是由下标 (i, j, k) 组成的三元组&#xff0c;并满足下述全部条件&#xff1a; 0 < i < nums.length 0 < j < nums.length 0 < k <…

【C++笔记】异常处理

C语言处理错误的方式 传统的错误处理机制&#xff1a; 1.终止程序缺陷&#xff1a;用户难以接受。 2.返回错误码&#xff1a;缺陷&#xff1a;需要自己去查错误码对应的解释。 C语言一般使用错误码来处理错误&#xff0c;部分情况下才会用终止情况处理处理严重的错误。 C异常…

初识Liunx下的进程状态和环境变量以及进程优先级

文章目录前言1.进程状态1.阻塞与挂起2.Linux下的进程状态1.概念知识2.R状态2.休眠状态(S/D&#xff09;3.T状态4.Z状态(僵尸进程)和X状态5.孤儿进程3.环境变量1.概念2.获取环境变量1.环境变量表2.函数获取环境变量3.关于环境变量的理解和main函数中的两个参数1.环境变量的理解2…

学习笔记--目标检测基础知识大全

来源&#xff1a;投稿 作者&#xff1a;LSC 编辑&#xff1a;学姐 目录 1.特点 2.数据集 2.1 VOCS数据集 2.2 COCO数据集 3.评价指标 3.1 GroundTruth 3.2 IOU(交并比&#xff0c;Intersection over Union) 3.3 基本指标 3.4 AP与mAp 3.5 案例演示 4. 脑图&#xff…

代码规范----编程规约(下)

目录 四、OOP规约 五、日期时间 六、集合处理 四、OOP规约 &#xff08;1&#xff09;、避免通过一个类的对象引用访问此类的静态变量或静态方法&#xff0c;无谓增加编译器解析成本&#xff0c;直接用类名来访问即可 &#xff08;2&#xff09;、所有的覆写方法&#xff0…

【C语言学习笔记】:二级指针

指针可以指向一个普通类型的数据&#xff0c;例如 int、double、char 等&#xff0c;也可以指向一个指针类型的数据&#xff0c;例如 int *、double *、char * 等。 如果一个指针指向的是另外一个指针&#xff0c;我们就称它为二级指针&#xff0c;或者指向指针的指针。 假设…

Leetcode.2017 网格游戏

题目链接 Leetcode.2017 网格游戏 Rating &#xff1a; 1719 题目描述 给你一个下标从 0 开始的二维数组 grid&#xff0c;数组大小为 2 x n&#xff0c;其中 grid[r][c]表示矩阵中 (r, c)位置上的点数。现在有两个机器人正在矩阵上参与一场游戏。 两个机器人初始位置都是 (0…

带你看懂RuoYi动态数据源切换

文章目录数据源是什么一、spring中是如何处理各种数据源的&#xff1f;1.开搞springboot2.创建一个测试类二、有了如上的理论,那么想想动态切换数据源吧参考若依的动态数据源配置总结数据源是什么 数据源,对于java来说,就是可用的数据库,那么我平时开发的springboot springclo…

算机网络安全基础知识5:sql注入漏洞攻击,DVWA演示sql注入漏洞,如何利用sql注入查看数据库信息,sqlmap,sql注入漏洞的防御

算机网络安全基础知识5:sql注入漏洞攻击&#xff0c;DVWA演示sql注入漏洞&#xff0c;如何利用sql注入查看数据库信息&#xff0c;sqlmap&#xff0c;sql注入漏洞的防御 2022找工作是学历、能力和运气的超强结合体&#xff0c;遇到寒冬&#xff0c;大厂不招人&#xff0c;可能…

Unity/C#------委托与事件(一篇文章彻底搞懂...)

一&#xff1a;委托 所有的代码语言创造者母语都是英语&#xff0c;我们从英语翻译到中文的过程中难免会存在一些不太能还原本意的词&#xff0c;比如我之前一直不理解构造函数和析构函数&#xff0c;只知道这俩货作用相反&#xff0c;直到我看到了它的英文意思&#xff0c;Con…

spring重点整理篇--springMVC(嘿嘿,开心哟)

Spring MVC是的基于JavaWeb的MVC框架&#xff0c;是Spring框架中的一个组成部分(WEB模块) MVC设计模式&#xff1a; Controller&#xff08;控制器&#xff09; Model&#xff08;模型&#xff09; View&#xff08;视图&#xff09; 重点来了&#x1f604; SpringMVC的工作机制…

Nginx+Tomcat实现负载均衡、动静分离(脚本方法)

一、Nginx 负载均衡实现原理1、Nginx 实现负载均衡是通过反向代理实现反向代理&#xff08;Reverse Proxy&#xff09; 是指以 代理服务器&#xff08;例&#xff1a;Nginx&#xff09; 来接受 internet 上的连接请求&#xff0c;然后将请求转发给内部网络上的服务器&#xff0…

【PGMAN:无监督的生成式多对抗网络】

PGMAN: An Unsupervised Generative Multiadversarial Network for Pansharpening &#xff08;PGMAN&#xff1a;一种无监督的生成式多对抗网络&#xff09; 全色锐化的目的是融合低分辨率多光谱&#xff08;MS&#xff09;图像和由卫星获取的高分辨率全色&#xff08;PAN&a…

OnlyOffice验证(三)OnlyOffice编译结果自制Docker镜像

OnlyOffice验证&#xff08;三&#xff09;OnlyOffice编译结果自制Docker镜像 之前验证了OnlyOffice验证&#xff08;二&#xff09;在Centos7上部署OnlyOffice编译结果&#xff0c;由于现在普遍都是容器化部署&#xff0c;所以还是验证下Doker镜像打包是否可行&#xff0c;因为…

渗透five86-2

kali的ip为192.168.56.104&#xff0c;利用nmap或arp-scan -l查看发现了靶机ip192.168.56.120这里存在20、21、80端口&#xff0c;这边需要将靶机ip进行域名绑定&#xff0c;对/etc/hosts改写&#xff0c;将192.168.56.120 与five86-2绑定输入ip后&#xff0c;发现了有log in由…

Kubernetes的网络架构及其安全风险

本博客地址&#xff1a;https://security.blog.csdn.net/article/details/129137821 一、常见的Kubernetes网络架构 如图所示&#xff1a; 说明&#xff1a; 1、集群由多个节点组成。 2、每个节点上运行若干个Pod。 3、每个节点上会创建一个CNI网桥&#xff08;默认设备名称…