pygame飞机大战

飞机大战

  • 1.main类
  • 2.配置类
  • 3.游戏主类
  • 4.游戏资源类
  • 5.资源下载
  • 6.游戏效果

1.main类

启动游戏。

from MainWindow import MainWindow
if __name__ == '__main__':app=MainWindow()app.run()

2.配置类

该类主要存放游戏的各种设置参数。

#窗口尺寸
#窗口尺寸
import random
import pygame
WINDOW=pygame.Rect(0,0,512,768)
#窗口名字
WINDOW_NAME="飞机大战v1.0"#地图索引
MAP_INDEX=random.randint(1,5)#英雄子弹类型
HERO_BULLET_INDEX=1
#敌人子弹类型
ENEMY_BULLET_INDEX=3#敌机事件
ENEMY_EVENT=pygame.USEREVENT#pygame用户事件(整型),有多个事件可以在后面+1以区分#英雄子弹事件
BULLET_EVENT=pygame.USEREVENT+1#+1区分事件
#敌机子弹事件
BULLET_ENEMY_EVENT=pygame.USEREVENT+2#+2区分事件#英雄移动速度
HERO_MOVE_SPEED=4
#英雄子弹移动速度
HERO_BULLET_MOVE_SPEED=4
#英雄生命值
HERO_HP=10

3.游戏主类

游戏主类主要由游戏窗口创建、精灵和精灵组的创建、游戏启动函数(1.碰撞检测、2.事件处理、3.精灵组更新、4.窗口刷新)等构成。

import pygame
from Config import *
from GameSprite import *
class MainWindow:def __init__(self):pygame.init()#游戏窗口初始化self.window=pygame.display.set_mode([WINDOW.width,WINDOW.height])pygame.display.set_caption(WINDOW_NAME)#背景音乐pygame.mixer.music.load("./source/music/bg.wav")pygame.mixer.music.set_volume(0.1)pygame.mixer.music.play(-1)#爆炸音效self.bomb=pygame.mixer.Sound("./source/music/bomb.wav")self.bomb.set_volume(0.2)#游戏分数self.score=0self.hp=HERO_HPself.pause_flag = False  # 暂停标志#FPS时钟self.clock=pygame.time.Clock()#激活敌机定时器,参数:事件、间隔时间mspygame.time.set_timer(ENEMY_EVENT,500)# 激活英雄子弹定时器,参数:事件、间隔时间mspygame.time.set_timer(BULLET_EVENT,500)pygame.time.set_timer(BULLET_ENEMY_EVENT,2000)#创建精灵组self.create_sprite_group()#精灵组创建def create_sprite_group(self):#地图精灵组map1=GameMap()map2=GameMap(True)self.map_group=pygame.sprite.Group(map1,map2)#英雄精灵self.hero=Hero()self.hero_group=pygame.sprite.Group(self.hero)#敌机精灵组self.enemy_group=pygame.sprite.Group()#英雄子弹精灵组self.bullet_group=pygame.sprite.Group()#敌机子弹精灵组self.bullet_enemy_group=pygame.sprite.Group()#爆炸动画精灵组self.bomb_group=pygame.sprite.Group()# 菜单精灵组self.resume_nor = Menu("./source/resume_nor.png")  # 正在暂停按钮图标self.pause_nor = Menu("./source/pause_nor.png")  # 正在运行图标self.restart = Menu("./source/again.png")  # 重新开始图标self.menu_group = pygame.sprite.Group()# 显示精灵组self.show_group = pygame.sprite.Group()# 碰撞检测def collie_check(self):#1.英雄子弹与敌机for bullet1 in self.bullet_group:#第一个参数是精灵、第二个参数是精灵组、第三个参数为是否删除与该精灵碰撞的所有精灵;返回值为与第一个参数碰撞的所有精灵列表eys=pygame.sprite.spritecollide(bullet1,self.enemy_group,True)#判断子弹精灵是否与敌机精灵组有碰撞,有则杀死所有敌机#表示有碰撞if len(eys)>0:self.bomb.play()#发生碰撞,播放爆炸音效self.score+=1#记录杀死的敌机数量bullet1.kill()#杀死发生碰撞的子弹精灵bomb_enemy=Bomb(eys[0])#将发生碰撞的敌传入爆炸类,方便使用爆炸的具体位置self.bomb_group.add(bomb_enemy)#加入爆炸精灵组#2.敌机子弹与英雄bullet2=pygame.sprite.spritecollide(self.hero,self.bullet_enemy_group,True)if len(bullet2)>0:self.bomb.play()#发生碰撞,播放爆炸音效self.hp-=1#英雄与敌机子弹接触,自身HP值-1#敌机与英雄enemys=pygame.sprite.spritecollide(self.hero,self.enemy_group,True)if len(enemys)>0:self.bomb.play()#发生碰撞,播放爆炸音效self.hp-=1#英雄与敌机接触,自身HP值-1bomb_enemy2 = Bomb(enemys[0])#将发生碰撞的敌传入爆炸类,方便使用爆炸的具体位置self.bomb_group.add(bomb_enemy2)#加入爆炸精灵组# 英雄生命值为0,暂停游戏,并且显示重新开始if self.hp <0:self.hero.kill()self.enemy_group.empty()self.bullet_group.empty()self.bullet_enemy_group.empty()self.pause_flag = Trueself.restart.rect.centerx = self.window.get_rect().centerxself.restart.rect.centery = self.window.get_rect().centeryself.menu_group.add(self.restart)# 更新精灵组位置并绘制def sprite_group_update_draw(self):#地图精灵组更新self.map_group.update()self.map_group.draw(self.window)#英雄精灵组更新self.hero_group.update()self.hero_group.draw(self.window)#敌机精灵组更新self.enemy_group.update()self.enemy_group.draw(self.window)#英雄子弹精灵组self.bullet_group.update()self.bullet_group.draw(self.window)#敌机子弹精灵组self.bullet_enemy_group.update()self.bullet_enemy_group.draw(self.window)#爆炸精灵组self.bomb_group.update()self.bomb_group.draw(self.window)# 菜单类精灵组self.menu_group.update()self.menu_group.draw(self.window)# 显示信息self.show_group.update()self.show_group.draw(self.window)#绘制数据 #游戏数据# 显示游戏信息self.score1 = Show("得分", self.score)self.score1.rect.x = 80self.score1.rect.y = 0self.hp1 = Show("生命值", self.hp)self.hp1.rect.x = 200self.hp1.rect.y = 0self.show_group.empty()self.show_group.add(self.score1, self.hp1)# 事件处理def handle_events(self):#pygame.event.get()获取当前时间帧的所有事件,返回一个事件列表,可以对此列表遍历for event in pygame.event.get():if event.type==pygame.QUIT:pygame.quit()exit()#用户事件1,固定时间生成敌机(时间可以在窗口初始化代码中修改)if event.type==pygame.USEREVENT:self.enemy=Enemy()self.enemy_group.add(self.enemy)#用户事件2,固定时间生成敌机子弹(时间可以在窗口初始化代码中修改)if event.type==pygame.USEREVENT+2:#固定时间生成敌机子弹,需要遍历敌机精灵组,获取所有已经存在的敌机精灵,在对应的位置上绘制敌机子弹for enemy_sprite in self.enemy_group:self.bullet_enemy = Bullet(enemy_sprite.speed + 1,True)self.bullet_enemy.rect.centerx = enemy_sprite.rect.centerxself.bullet_enemy.rect.y =enemy_sprite.rect.bottom#将敌机子弹精灵添加到敌机子弹精灵组self.bullet_enemy_group.add(self.bullet_enemy)#用户事件3,固定时间生成英雄子弹(时间可以在窗口初始化代码中修改)if event.type==pygame.USEREVENT+1:self.bullet_hero=Bullet(-HERO_BULLET_MOVE_SPEED)#英雄子弹飞行方向与敌机子弹飞行方向相反#根据英雄的当前位置来设置英雄子弹的位置self.bullet_hero.rect.centerx=self.hero.rect.centerxself.bullet_hero.rect.y=self.hero.rect.y-self.bullet_hero.rect.height# 将英雄飞机子弹精灵添加到英雄子弹精灵组self.bullet_group.add(self.bullet_hero)# 按下ESC切换暂停if event.type == pygame.KEYDOWN and event.key == pygame.K_ESCAPE:self.pause_flag = not self.pause_flag  # 切换暂停状态# 鼠标点击切换暂停if event.type == pygame.MOUSEBUTTONDOWN and event.button == pygame.BUTTON_LEFT:if self.pause_nor.rect.collidepoint(event.pos):self.pause_flag = not self.pause_flag#pygame.key.get_pressed()获取当前时间帧的所有键盘事件并返回一个列表,遍历列表控制英雄上下左右移动keys_event=pygame.key.get_pressed()if keys_event[pygame.K_a] or keys_event[pygame.K_LEFT]:self.hero.x_speed=-HERO_MOVE_SPEEDelif keys_event[pygame.K_d] or keys_event[pygame.K_RIGHT]:self.hero.x_speed=HERO_MOVE_SPEEDelse:self.hero.x_speed = 0if keys_event[pygame.K_w] or keys_event[pygame.K_UP]:self.hero.y_speed=-HERO_MOVE_SPEEDelif keys_event[pygame.K_s] or keys_event[pygame.K_DOWN]:self.hero.y_speed=HERO_MOVE_SPEEDelse:self.hero.y_speed=0# 暂停状态下if self.pause_flag:if self.pause_nor in self.menu_group:self.menu_group.remove(self.pause_nor)  # 将运行图标的精灵移除self.menu_group.add(self.resume_nor)pygame.mixer.music.pause()#暂停背景音乐# 非暂停状态else:if self.resume_nor in self.menu_group:self.menu_group.remove(self.resume_nor)  # 将暂停图标的精灵移除self.menu_group.add(self.pause_nor)pygame.mixer.music.unpause()# 显示游戏信息self.score1 = Show("得分", self.score)self.score1.rect.x = 80self.score1.rect.y = 0self.hp1 = Show("生命值", self.hp)self.hp1.rect.x = 200self.hp1.rect.y = 0self.show_group.empty()self.show_group.add(self.score1, self.hp1)#游戏主框架def run(self):pygame.init()while True:#暂停状态while self.pause_flag:self.clock.tick(60)for event in pygame.event.get():if event.type == pygame.QUIT:pygame.quit()exit()# 按下ESC暂停if event.type == pygame.KEYDOWN and event.key == pygame.K_ESCAPE:self.pause_flag = not self.pause_flag  # 切换暂停状态# 鼠标点击切换暂停if event.type == pygame.MOUSEBUTTONDOWN and event.button == pygame.BUTTON_LEFT:if self.pause_nor.rect.collidepoint(event.pos):self.pause_flag = not self.pause_flag# 当英雄死亡之后,点击重新开始if event.type == pygame.MOUSEBUTTONDOWN and event.button == pygame.BUTTON_LEFT:pos = pygame.mouse.get_pos()# 如果英雄死亡了,点击重新开始if self.hp < 0 and self.restart.rect.collidepoint(pos):self.menu_group.remove(self.restart)self.score = 0self.hero_group.add(self.hero)self.hp = HERO_HPself.pause_flag = False# 切换到非暂停状态if not self.pause_flag:break#正常运行while not self.pause_flag:self.clock.tick(60)  # FPS#碰撞检测self.collie_check()# 事件处理self.handle_events()#更新精灵组self.sprite_group_update_draw()# 窗口刷新pygame.display.update()# 切换到暂停状态if self.pause_flag:break

4.游戏资源类

游戏资源类主要包括各种游戏相关元素精灵、主要有基础精灵类、敌机精灵类、子弹精灵类、英雄飞机精灵类、爆炸动画精灵类等。

import  pygame
from Config import *
import random
#精灵类————基类,定义了基本的导入图片操作,以及图片垂直移动操作
class GameSprite(pygame.sprite.Sprite):def __init__(self,image_url,speed=0):super().__init__()self.image=pygame.image.load(image_url)self.rect=self.image.get_rect()self.speed=speeddef update(self, *args, **kwargs):self.rect.y+=self.speed
#游戏地图类,地图由两张完全一样的图片拼接构成,其中两张图片的起始和末尾要无缝衔接
#第一张图片起始位置与窗口完全重合,第二张图片的起始位置在第一张图片的上方
class GameMap(GameSprite):#is_1表示是否是第二张图片def __init__(self,is_1=False):#地图给了5张,保证地图索引在1~5,否则随机给一个1~5self.map_index=MAP_INDEX if 1<=MAP_INDEX<=5 else random.randint(1,5)map_filename=f"./source/map/map-{self.map_index}.jpg"super().__init__(map_filename,2)if is_1:self.rect.y=-WINDOW.height#第二张图片的起始位置在第一张图片的上方def update(self):#更新图像的位置super().update()#如果地图图片完全运动到了窗口最下方,就将这张图片的位置移动到窗口的最上方,作为新的起始位置if self.rect.y>=WINDOW.height:self.rect.y=-WINDOW.height
#英雄飞机类,初始化定义比较简单
class Hero(GameSprite):def __init__(self):super().__init__("./source/plane/hero.png")#定义英雄飞机出生在窗口中的具体位置self.rect.centerx=WINDOW.centerxself.rect.y=WINDOW.height-120#初始移动速度为0,静止状态self.x_speed=0self.y_speed=0def update(self, *args, **kwargs):#水平方向移动self.rect.x+=self.x_speed#垂直方向移动self.rect.y+=self.y_speed#判断上、下、左、右四个边界条件,如果移动到了边界,让飞机停在原位if self.rect.x<=0:self.rect.x=0if self.rect.x>=WINDOW.width-self.rect.width:self.rect.x=WINDOW.width-self.rect.widthif self.rect.y<=0:self.rect.y=0if self.rect.y>=WINDOW.height-self.rect.height:self.rect.y=WINDOW.height-self.rect.height
#敌机类
class Enemy(GameSprite):def __init__(self):#敌机有7中飞机,随机生成self.enemy_url=f"./source/plane/enemy-{random.randint(1,7)}.png"#敌机的垂直速度也是随机生成(1,3)super().__init__(self.enemy_url,random.randint(1,3))#敌机的初始水平位置需要随机生成,范围就是(0,WINDOW.width-self.rect.width)self.rect.x=random.randint(0,WINDOW.width-self.rect.width)#敌机的垂直位置y是固定值,保证敌机出现的位置在窗口之外self.rect.y=-self.rect.height#敌机水平方向的移动速度随机生成self.x_speed=random.randint(-1,1)def update(self, *args, **kwargs):#调用父类的update()函数super().update()#父类函数不够用的情况下,直接补充self.rect.x+=self.x_speed#水平移动#如果到达左右边界则反向运动if self.rect.x<=0 or self.rect.x>=WINDOW.width-self.rect.width:self.x_speed=-self.x_speed#敌机出了窗口底部则杀死此敌机精灵if self.rect.y>WINDOW.height:self.kill()
#子弹类(英雄飞机子弹和敌机子弹)
class Bullet(GameSprite):#is_enemy表示是否是敌机,敌机和英雄飞机使用的子弹图片不同def __init__(self,speed,is_enemy=False):if is_enemy:self.bullet_index=ENEMY_BULLET_INDEXelse:self.bullet_index = HERO_BULLET_INDEXbullet_filename = f"./source/bullet/bullet_{self.bullet_index}.png"self.speed=speedsuper().__init__(bullet_filename,self.speed)#由于敌机和英雄飞机是相对运动,资源图片都是正向的,所以如果是敌机子弹,则需要对子弹图片做旋转180°操作if is_enemy:##flip(翻转的图片、是否绕x轴翻转、是否绕y轴翻转)self.image=pygame.transform.flip(self.image,False,True)def update(self, *args, **kwargs):#垂直方向移动super().update()#超出屏幕则杀死此精灵if self.rect.y<-self.rect.height or self.rect.y>WINDOW.height+self.rect.height:self.kill()
#爆炸动画类
class Bomb(pygame.sprite.Sprite):def __init__(self,sprite1):super().__init__()#导入所有动画的图片self.images=[pygame.image.load(f"./source/bomb/bomb-{bomb_index}.png") for bomb_index in range(1,8)]self.sprite1=sprite1self.interval = 5 # 播放每一张图片的间隔 5帧self.interval_index = 0 #帧数计数器 初始值为0self.image_index=0#图片索引 初始值为0self.image = self.images[self.image_index]self.rect = self.image.get_rect()self.rect.x = self.sprite1.rect.xself.rect.y = self.sprite1.rect.ydef update(self, *args, **kwargs):self.interval_index+=1#每一帧进入update()函数,帧计数器加1#当计数器到达设置值时,切换图片if self.interval_index>=self.interval:self.image=self.images[self.image_index]#帧计数器归零self.interval_index=0#切换图片self.image_index+=1#当所有图片都播放完毕之后杀死此精灵对象if self.image_index==len(self.images):self.kill()
#菜单类,显示控制游戏的暂停、恢复游戏、重新开始游戏
class Menu(GameSprite):def __init__(self,image_url):super().__init__(image_url)def update(self, *args, **kwargs):pass
#显示游戏相关信息类,可以显示游戏中得分、英雄生命值等
class Show(pygame.sprite.Sprite):def __init__(self,name,var):super().__init__()pygame.font.init()font1 = pygame.font.SysFont('华文宋体', 25)  # 加载系统自带字体text = f"{name}:{var}"  # 编辑文本text = font1.render(text, True, (255, 255, 0))  # 渲染字体,(字符串,抗锯齿,字体颜色,背景颜色)self.image=textself.rect=self.image.get_rect()

5.资源下载

链接:资源
提取码:9mje

6.游戏效果

在这里插入图片描述

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

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

相关文章

thinkphp通过html生成pdf

thinkphp 生成pdf {__NOLAYOUT__} <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>合同模板</title><style>/*打印内容*/media print {page {size: A4 landscape; /* auto is the initi…

如何让用户在网页中填写PDF表格?

在网页中让用户直接填写PDF表格&#xff0c;可以大大简化填写、打印、扫描和提交表单的流程。通过使用复选框、按钮和列表等交互元素&#xff0c;PDF表格不仅让填写过程更高效&#xff0c;还能方便地在电脑或移动设备上访问和提交数据。 以下是在浏览器中显示可填写PDF表单的四…

ThinkPHP 8高效构建Web应用-获取请求对象

【图书介绍】《ThinkPHP 8高效构建Web应用》-CSDN博客 《2025新书 ThinkPHP 8高效构建Web应用 编程与应用开发丛书 夏磊 清华大学出版社教材书籍 9787302678236 ThinkPHP 8高效构建Web应用》【摘要 书评 试读】- 京东图书 使用VS Code开发ThinkPHP项目-CSDN博客 编程与应用开…

软件架构的康威定律:AI如何重构团队协作模式

1. 引言 康威定律&#xff0c;一个简洁却深刻的观察&#xff1a;任何组织设计出的系统&#xff0c;其结构都与组织自身的沟通结构保持一致。这意味着&#xff0c;一个团队的沟通方式、组织结构直接影响着最终产品的架构。这在软件开发领域尤为明显。一个沟通效率低下的团队&am…

23.行号没有了怎么办 滚动条没有了怎么办 C#例子

新建了一个C#项目&#xff0c;发现行号没有了。 想把行号调出来&#xff0c;打开项目&#xff0c;选择工具>选项> 如下图&#xff0c;在文本编辑器的C#里有一个行号&#xff0c;打开就可以了 滚动条在这里&#xff1a;

30天开发操作系统 第 12 天 -- 定时器

前言 定时器(Timer)对于操作系统非常重要。它在原理上却很简单&#xff0c;只是每隔一段时间(比如0.01秒)就发送一个中断信号给CPU。幸亏有了定时器&#xff0c;CPU才不用辛苦地去计量时间。……如果没有定时器会怎么样呢?让我们想象一下吧。 假如CPU看不到定时器而仍想计量时…

el-table 实现纵向多级表头

为了实现上图效果&#xff0c;最开始打算用el-row、el-col去实现&#xff0c;但发现把表头和数据分成两大列时&#xff0c;数据太多时会导致所在格高度变高。但由于每一格数据肯定不一样&#xff0c;为保持高度样式一致&#xff0c;就需要我们手动去获取最高格的高度之后再设置…

ES_如何设置ElasticSearch 8.0版本的匿名访问以及https_http模式的互相切换

总结&#xff1a; 设置匿名访问&#xff0c;只需要设置xpack.security.authc.anonymous.username和xpack.security.authc.anonymous.roles参数就行&#xff0c;设置好后&#xff0c;可以匿名访问也可以非匿名访问&#xff0c;但是非匿名访问的情况下必须保证用户名和密码正确 取…

uni-app深度解码:跨平台APP开发的核心引擎与创新实践

在当今数字化浪潮中&#xff0c;移动应用市场呈现出爆炸式增长。为了满足不同用户群体在不同操作系统上的需求&#xff0c;跨平台 APP 开发成为众多开发者的首选策略。uni-app 作为一款领先的跨平台开发框架&#xff0c;以其独特的优势和创新的实践在众多同类产品中脱颖而出。它…

oxml中创建CT_Document类

概述 本文基于python-docx源码&#xff0c;详细记录CT_Document类创建的过程&#xff0c;以此来加深对Python中元类、以及CT_Document元素类的认识。 元类简介 元类&#xff08;MetaClass&#xff09;是Python中的高级特性。元类是什么呢&#xff1f;Python是面向对象编程…

FastGPT 介绍

FastGPT 是一种专注于高效对话和任务处理的人工智能语言模型。以下是关于 FastGPT 的一些主要特性和应用场景&#xff1a; FastGPT 的特点&#xff1a; 速度与效率&#xff1a; FastGPT 经过优化&#xff0c;能够以更快的速度生成高质量的内容&#xff0c;适用于对实时性要求较…

jenkins入门6 --拉取代码

Jenkins代码拉取 需要的插件&#xff0c;缺少的安装下 新建一个item,选择freestyle project 源码管理配置如下&#xff1a;需要添加git库地址&#xff0c;和登录git的用户密码 配置好后执行编译&#xff0c;成功后拉取的代码在工作空间里

CE中注册的符号地址如何通过编程获取

我的方式是先执行lua申请共享内存&#xff0c;内存名称是进程id&#xff0c;这样多开也不受影响&#xff0c;然后通过共享内存的名字就可以读到地址了。之后的人造指针的地址也都可以放这里集中管理。 -- 申请内存 local size 1024 -- 申请 1024 字节&#xff08;1 KB&#…

在 ASP.NET CORE 中上传、下载文件

创建 Web API 来提供跨客户端和服务器的文件上传和下载是常有的事。本文将介绍如何通过 ASP.NET CORE 来实现。 首先在 Visual Studio 中创建空的 Web API 项目&#xff0c;然后选择目标框架 .Net Core 3.1。 创建名为 FileController 的控制器&#xff0c;提供操作文件的接口…

vue2迁移至rsbuild

背景 由于远程机器配置较低&#xff0c;每次运行vue2项目都会非常卡。后期项目文件、路由更多的时候&#xff0c;启动到一半直接会跳出open too many files类似的错误&#xff0c;尝试将路由屏蔽掉只剩下开发所需的一个路由也不行&#xff08;不是说webpack的打包是全部打包&am…

智能手机租赁系统全新模式改变消费习惯与商家盈利路径

内容概要 智能手机租赁系统的崛起&#xff0c;让我们瞄到了一个消费市场的新风向标。想象一下&#xff0c;传统上人们总是为了最新款手机奋不顾身地排队、借钱甚至是透支信用卡。现在&#xff0c;通过灵活的租赁选项&#xff0c;消费者可以更加随意地体验高科技产品&#xff0…

[项目实战2]贪吃蛇游戏

目录 贪吃蛇游戏&#xff1a;&#xff1a; 一、游戏效果及功能实现&#xff1a; 1.规则 ​​​​​​​ ​​​​​​​ ​​​​​​​ 2.基本功能实现 ​​​​​​​ ​​​​​​​ ​​​​​​​ 3.技术要点 ​​​​​​​…

浏览器报错:您的连接不是私密连接,Kubernetes Dashboard无法打开

问题描述 部署完成Kubernetes Dashboard后&#xff0c;打开HTTPS的web页面&#xff0c;Chrome和Edge浏览器都无法正常加载页面&#xff0c;会提示您的连接不是私密连接的报错。 ​​​​​​​​​​​​ 原因&#xff1a; 浏览器不信任这些自签名的ssl证书&#xff0c;为了…

关于量子神经网络的思考

其实在写这篇文章之前想了很多&#xff0c;主要是想法太超前&#xff0c;有可能颠覆未来机器智能行业甚至是影响世界。 1、计算机的历史 计算机的历史可以追溯到20世纪中叶&#xff0c;最早的电子计算机如ENIAC和EDVAC采用了冯诺依曼架构&#xff08;John von Neumann Archit…

docker pull(拉取镜像)的时候,无法下载或者卡在Waiting的解决方法

docker pull的时候&#xff0c;卡在Waiting的解决方法 一般情况&#xff08;大部分镜像都可以拉取&#xff09;更换镜像源 进一步&#xff08;如es等拉取不到&#xff09;在镜像同步站搜索详细步骤 还可以在挂载的时候&#xff0c;让其下载对应的版本 一般情况&#xff08;大部…