Java 小游戏《超级马里奥》

文章目录

  • 一、效果展示
  • 二、代码编写
    • 1. 素材准备
    • 2. 创建窗口类
    • 3. 创建常量类
    • 4. 创建动作类
    • 5. 创建关卡类
    • 6. 创建障碍物类
    • 7. 创建马里奥类
    • 8. 编写程序入口

一、效果展示

在这里插入图片描述

二、代码编写

1. 素材准备

首先创建一个基本的 java 项目,并将本游戏需要用到的图片素材 image 导入。

图片素材如下:
https://pan.baidu.com/s/1db_IcPvPKWKbVPtodPWO5Q?pwd=03kv
提取码:03kv

在这里插入图片描述

2. 创建窗口类

在这里插入图片描述

① Java 内部已经给我们封装了窗口的各种方法,我们只需创建一个窗口类并重写父类的方法,即可使用;
② Alt + Enter 键 → implement methods 可一键补全所有的重写方法;
③ 实现多线程有两种方法,分别是继承 Thread 类和实现 Runnable 接口,这里我们用 Runnable 方法,因为 Java 不支持多继承。

重写 paint 方法,实现场景、物体的绘制,使用多线程无限绘制窗口。

完整代码如下:

package com.zxe.beans;

import javax.swing.*;
import java.awt.*;
import java.awt.event.KeyEvent;
import java.awt.event.KeyListener;
import java.util.ArrayList;
import java.util.List;

/**
 * 窗口类
 */
public class MyFrame extends JFrame implements KeyListener, Runnable {

    //定义一个集合用于所有的关卡
    private List<LevelMap> levelMaps = new ArrayList<>();
    //定义一个变量,存放当前背景
    private LevelMap levelMap = new LevelMap();
    //定义变量,记录马里奥
    private Mario mario;

    //重写paint方法,实现场景、物体的绘制
    @Override
    public void paint(Graphics g) {
        //创建一张图片
        Image image = createImage(1045, 500);
        //设置图片
        Graphics graphics = image.getGraphics();
        graphics.drawImage(levelMap.getBg(), 0, 0, 1045, 500, this);
        //绘制障碍物
        for (Obstacle obstacle : levelMap.getObstacles()){
            graphics.drawImage(obstacle.getObstacleImage(), obstacle.getX(), obstacle.getY(), this);
        }
        //绘制马里奥
        graphics.drawImage(mario.getMarioImage(), mario.getX(), mario.getY(), this);

        //将图片描绘到当前窗口中
        g.drawImage(image, 0, 0, this);
    }

    @Override
    public void keyTyped(KeyEvent e) {

    }

    @Override
    public void keyPressed(KeyEvent e) {
        if (e.getKeyCode() == 37) {
            mario.runLeft();
        } else if (e.getKeyCode() == 39) {
            mario.runRight();
        } else if (e.getKeyCode() == 38) {
            mario.jump();
        }
    }

    public Mario getMario() {
        return mario;
    }

    public void setMario(Mario mario) {
        this.mario = mario;
    }

    @Override
    public void keyReleased(KeyEvent e) {
        if (e.getKeyCode() == 37) {
            mario.runLeftStop();
        } else if (e.getKeyCode() == 39) {
            mario.runRightStop();
        } else if (e.getKeyCode() == 38) {
            mario.jumpDown();
        }
    }

    @Override
    public void run() {
        //无限次绘制马里奥
        while (true) {
            repaint();
            try {
                Thread.sleep(50);
            } catch (InterruptedException e) {
                throw new RuntimeException(e);
            }
            //判断一下马里奥是否通关
            if (mario.getX() > 1040) {
                levelMap = levelMaps.get(levelMap.getLevel());
                mario.setLevelMap(levelMap);
                mario.setX(50);
                mario.setY(420);
            }
        }
    }

    public List<LevelMap> getLevelMaps() {
        return levelMaps;
    }

    public void setLevelMaps(List<LevelMap> levelMaps) {
        this.levelMaps = levelMaps;
    }

    public LevelMap getLevelMap() {
        return levelMap;
    }

    public void setLevelMap(LevelMap levelMap) {
        this.levelMap = levelMap;
    }
}

3. 创建常量类

小游戏中的各种元素画面其实都是一张张的图片,而这些图片路径的定义都将放在常量类中完成。

package com.zxe.beans;

import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

/**
 * 常量类
 */
public class Constant {
    //给窗口定义一张图片
    public static BufferedImage bg;
    //右跳图片
    public static BufferedImage jumpR;
    //左跳图片
    public static BufferedImage jumpL;
    //右边站立
    public static BufferedImage standR;
    //左边站立
    public static BufferedImage standL;
    //定义一个集合,存放右跑动作
    public static List<BufferedImage> runR = new ArrayList<>();
    //定义一个集合,存放左跑动作
    public static List<BufferedImage> runL = new ArrayList<>();
    //为障碍物定义一个集合
    public static List<BufferedImage> onstacles = new ArrayList<>();

    //定义一个变量,记录文件路径前缀
    public static String prefix = "C:\\Users\\Lenovo\\Desktop\\demo\\file\\image\\";

    //初始化图片到系统中
    public static void initImage() {
        try {
            //加载图片
            bg = ImageIO.read(new File(prefix + "bg2.jpeg"));
            jumpR = ImageIO.read(new File(prefix + "mario_jump_r.png"));
            jumpL = ImageIO.read(new File(prefix + "mario_jump_l.png"));
            standR = ImageIO.read(new File(prefix + "mario_stand_r.png"));
            standL = ImageIO.read(new File(prefix + "mario_stand_l.png"));
            runR.add(ImageIO.read(new File(prefix + "mario_run_r1.png")));
            runR.add(ImageIO.read(new File(prefix + "mario_run_r2.png")));
            runL.add(ImageIO.read(new File(prefix + "mario_run_l1.png")));
            runL.add(ImageIO.read(new File(prefix + "mario_run_l2.png")));
            for (int i = 1; i <= 6; i++) {
                onstacles.add(ImageIO.read(new File(prefix + "ob" + i + ".png")));
            }
        } catch (IOException e) {
            e.printStackTrace();
            throw new RuntimeException(e);
        }
    }

}

常量用 static 修饰,外部可直接通过类名调用常量,而无需创建对象。

4. 创建动作类

记录玛丽的动作状态,具体的常量名与代码分离,可以降低代码的耦合度,更规范化。

在这里插入图片描述

5. 创建关卡类

每个关卡的障碍物是不一样的,这里需要外部传入关卡号,在关卡类中把不同的障碍物拼成自定义的关卡。

完整代码如下:

package com.zxe.beans;

import com.zxe.utils.Constant;

import java.awt.image.BufferedImage;
import java.util.ArrayList;
import java.util.List;

/**
 * 关卡地图类
 */
public class LevelMap {
    //记录当前场景需要的图片
    private BufferedImage bg;
    //记录当前关卡
    private int level;
    //创建一个集合,用于存放障碍物
    private List<Obstacle> obstacles = new ArrayList<>();

    public LevelMap() {
    }

    public LevelMap(int level) {
        this.level = level;
        bg = Constant.bg;
        if (level == 1) {
            //绘制方块
            obstacles.add(new Obstacle(100, 370, 0, this));
            obstacles.add(new Obstacle(130, 370, 1, this));
            obstacles.add(new Obstacle(160, 370, 0, this));
            obstacles.add(new Obstacle(190, 370, 1, this));
            obstacles.add(new Obstacle(300, 260, 0, this));
            obstacles.add(new Obstacle(330, 260, 1, this));
            obstacles.add(new Obstacle(360, 260, 1, this));
            obstacles.add(new Obstacle(800, 300, 0, this));
            obstacles.add(new Obstacle(830, 300, 0, this));
            obstacles.add(new Obstacle(860, 300, 1, this));
            obstacles.add(new Obstacle(890, 300, 1, this));
            //绘制水管
            obstacles.add(new Obstacle(420, 420, 4, this));
            obstacles.add(new Obstacle(450, 420, 5, this));
            obstacles.add(new Obstacle(415, 390, 2, this));
            obstacles.add(new Obstacle(435, 390, 2, this));
            obstacles.add(new Obstacle(455, 390, 3, this));
            obstacles.add(new Obstacle(600, 420, 4, this));
            obstacles.add(new Obstacle(630, 420, 5, this));
            obstacles.add(new Obstacle(600, 390, 4, this));
            obstacles.add(new Obstacle(630, 390, 5, this));
            obstacles.add(new Obstacle(595, 360, 2, this));
            obstacles.add(new Obstacle(615, 360, 2, this));
            obstacles.add(new Obstacle(635, 360, 3, this));

        } else if (level == 2) {
            int i = 0;
            for (int y = 420; y >= 300; y -= 30) {
                for (int x = 100; x <= 190 - 30 * i; x += 30) {
                    obstacles.add(new Obstacle(x + 30 * i, y, 0, this));
                }
                for (int x = 300; x <= 390 - 30 * i; x += 30) {
                    obstacles.add(new Obstacle(x, y, 0, this));
                }
                for (int x = 550; x <= 640 - 30 * i; x += 30) {
                    obstacles.add(new Obstacle(x + 30 * i, y, 0, this));
                }
                for (int x = 670; x <= 790 - 30 * i; x += 30) {
                    obstacles.add(new Obstacle(x, y, 0, this));
                }
                i++;
            }
        }
    }

    public BufferedImage getBg() {
        return bg;
    }

    public void setBg(BufferedImage bg) {
        this.bg = bg;
    }

    public int getLevel() {
        return level;
    }

    public void setLevel(int level) {
        this.level = level;
    }

    public List<Obstacle> getObstacles() {
        return obstacles;
    }

    public void setObstacles(List<Obstacle> obstacles) {
        this.obstacles = obstacles;
    }
}

6. 创建障碍物类

障碍物的属性包括图片以及横纵坐标。

完整代码如下:

package com.zxe.beans;

import com.zxe.utils.Constant;

import java.awt.image.BufferedImage;

/**
 * 障碍物类
 */
public class Obstacle {
    //记录障碍物的坐标
    private int x;
    private int y;
    //定义一个变量,记录当前障碍物的图片信息
    private BufferedImage obstacleImage;
    //定义障碍物类型
    private int type;
    //定义变量存放当前的背景
    private LevelMap bg;

    public Obstacle(int x, int y, int type, LevelMap bg) {
        this.x = x;
        this.y = y;
        this.type = type;
        this.bg = bg;
        //根据障碍物的编号,从常量中的障碍物集合中获取对应的图片
        this.obstacleImage = Constant.onstacles.get(type);
    }

    public int getX() {
        return x;
    }

    public void setX(int x) {
        this.x = x;
    }

    public int getY() {
        return y;
    }

    public void setY(int y) {
        this.y = y;
    }

    public BufferedImage getObstacleImage() {
        return obstacleImage;
    }

    public void setObstacleImage(BufferedImage obstacleImage) {
        this.obstacleImage = obstacleImage;
    }

    public int getType() {
        return type;
    }

    public void setType(int type) {
        this.type = type;
    }

    public LevelMap getBg() {
        return bg;
    }

    public void setBg(LevelMap bg) {
        this.bg = bg;
    }
}

7. 创建马里奥类

马里奥的无限行走动作由多线程实现,定义一个状态量status,用于标记马里奥当前的运动状态,以便进行不同动作的来回切换。

完整代码如下:

package com.zxe.beans;

import com.zxe.utils.Action;
import com.zxe.utils.Constant;

import java.awt.image.BufferedImage;

/**
 * 马里奥类
 */
public class Mario implements Runnable {
    //记录马里奥坐标信息
    private  int x;
    private int y;
    //记录马里奥状态
    private String status;
    //定义一个变量,记录马里奥当前动作所对应的图片信息
    private BufferedImage marioImage;
    //定义变量,记录当前的关卡地图,也可以获取障碍物的信息
    private LevelMap levelMap = new LevelMap();

    //创建线程执行马里奥的动作
    private Thread thread;
    //定义变量,记录马里奥的移动速度
    private int xSpeed;
    //定义变量,记录马里奥的跳跃速度
    private int ySpeed;
    //定义变量,记录马里奥的上升状态
    private int up;

    public Mario() {}

    public Mario(int x, int y) {
        this.x = x;
        this.y = y;
        //默认马里奥的动作是朝右站立
        status = Action.STAND_RIGHT;
        marioImage = Constant.standR;
        thread = new Thread(this);
        thread.start();
    }

    //马里奥向左移动的方法
    public void runLeft() {
        //判断当前是否为跳跃状态,如果不是,就改变状态
        if ( !status.contains("jump") ) {
            status = Action.RUN_LEFT;
        } else {
            status = Action.JUMP_LEFT;
        }
        xSpeed = -5;
    }

    //马里奥向右移动的方法
    public void runRight() {
        //判断当前是否为跳跃状态,如果不是,就改变状态
        if ( !status.contains("jump") ) {
            status = Action.RUN_RIGHT;
        } else {
            status = Action.JUMP_RIGHT;
        }
        xSpeed = 5;
    }

    public void jump() {
        if (status.contains("left")) {
            status = Action.JUMP_LEFT;
        } else {
            status = Action.JUMP_RIGHT;
        }
            ySpeed = -12;
    }

    public void jumpDown() {
        ySpeed = 12;
    }

    private void jumpStop() {
        if (status.contains("left")) {
            status = Action.STAND_LEFT;
        } else {
            status = Action.STAND_RIGHT;
        }
        ySpeed = 0;
    }

    //马里奥向左移动停止的方法
    public void runLeftStop() {
        if (!status.contains("jump")) {
            status = Action.STAND_LEFT;
        } else {
            status = Action.JUMP_LEFT;
        }
        xSpeed = 0;
    }

    //马里奥向右移动停止的方法
    public void runRightStop() {
        if (!status.contains("jump")) {
            status = Action.STAND_RIGHT;
        } else {
            status = Action.JUMP_RIGHT;
        }
        xSpeed = 0;
    }


    public int getX() {
        return x;
    }

    public void setX(int x) {
        this.x = x;
    }

    public int getY() {
        return y;
    }

    public void setY(int y) {
        this.y = y;
    }

    public String getStatus() {
        return status;
    }

    public void setStatus(String status) {
        this.status = status;
    }

    public BufferedImage getMarioImage() {
        return marioImage;
    }

    public void setMarioImage(BufferedImage marioImage) {
        this.marioImage = marioImage;
    }

    public LevelMap getLevelMap() {
        return levelMap;
    }

    public void setLevelMap(LevelMap levelMap) {
        this.levelMap = levelMap;
    }

    public Thread getThread() {
        return thread;
    }

    public void setThread(Thread thread) {
        this.thread = thread;
    }

    public int getxSpeed() {
        return xSpeed;
    }

    public void setxSpeed(int xSpeed) {
        this.xSpeed = xSpeed;
    }

    public int getySpeed() {
        return ySpeed;
    }

    public void setySpeed(int ySpeed) {
        this.ySpeed = ySpeed;
    }

    public int getUp() {
        return up;
    }

    public void setUp(int up) {
        this.up = up;
    }

    @Override
    public void run() {
        int index = 0;
        //控制马里奥无限移动
        while (true) {
            //判断当前是否移动,xSpeed<0左移动,xSpeed>0右移动
            if (xSpeed < 0 || xSpeed > 0) {
                x += xSpeed;
                if (x < 0) {
                    x = 0;
                }
            }

            if (ySpeed < 0 || ySpeed > 0) {
                y += ySpeed;
                if (y > 420) {
                    y = 420;
                    jumpStop();
                }
                if (y < 280) {
                    y = 280;
                }
            }

            //判断移动状态,跑步状态图片切换
            if (status.contains("run")) {
                index = index == 0 ? 1 : 0;
            }
            //根据马里奥的状态切换不同的图片
            if (Action.RUN_LEFT.equals(status)) {
                marioImage = Constant.runL.get(index);
            }
            if (Action.RUN_RIGHT.equals(status)) {
                marioImage = Constant.runR.get(index);
            }
            if (Action.STAND_LEFT.equals(status)) {
                marioImage = Constant.standL;
            }
            if (Action.STAND_RIGHT.equals(status)) {
                marioImage = Constant.standR;
            }
            if (Action.JUMP_LEFT.equals(status)) {
                marioImage = Constant.jumpL;
            }
            if (Action.JUMP_RIGHT.equals(status)) {
                marioImage = Constant.jumpR;
            }

            // 控制线程的速度
            try {
                Thread.sleep(30);
            } catch (InterruptedException e) {
                throw new RuntimeException(e);
            }
        }
    }

}

8. 编写程序入口

创建游戏窗口,并对窗口的基本属性进行设置,创建三个关卡,并调用 repaint 方法绘制场景。

package com.zxe;

import com.zxe.beans.LevelMap;
import com.zxe.beans.Mario;
import com.zxe.utils.Constant;
import com.zxe.beans.MyFrame;

import javax.swing.*;

public class Main {
    public static void main(String[] args) {
        //创建窗口对象
        MyFrame myFrame = new MyFrame();
        //设置窗口大小
        myFrame.setSize(1045,500);
        //设置窗口居中
        myFrame.setLocationRelativeTo(null);
        //设置窗口可见性
        myFrame.setVisible(true);
        //设置窗口关闭程序
        myFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        //设置键盘监听事件
        myFrame.addKeyListener(myFrame);
        //设置窗口的大小不可改变
        myFrame.setResizable(false);
        //设置窗口标题
        myFrame.setTitle("超级玛丽");

        //加载图片
        Constant.initImage();
        //创建三个关卡地图
        for (int i = 1; i <= 3; i++) {
            myFrame.getLevelMaps().add(new LevelMap(i));
        }
        //设置当前关卡地图
        myFrame.setLevelMap(myFrame.getLevelMaps().get(0));

        //创建马里奥
        Mario mario = new Mario(50, 420);
        myFrame.setMario(mario);
        mario.setLevelMap(myFrame.getLevelMap());

        //绘制场景
        myFrame.repaint();

        Thread thread = new Thread(myFrame);
        thread.start();
    }
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

大数据-174 Elasticsearch Query DSL - 全文检索 full-text query 匹配、短语、多字段 详细操作

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; 目前已经更新到了&#xff1a; Hadoop&#xff08;已更完&#xff09;HDFS&#xff08;已更完&#xff09;MapReduce&#xff08;已更完&am…

推荐一个可以免费上传PDF产品图册的网站

​在数字化时代&#xff0c;企业将产品图册以PDF格式上传至网络&#xff0c;不仅便于客户浏览和下载&#xff0c;还能提升企业的专业形象。今天&#xff0c;就为您推荐一个可以免费上传PDF产品图册的网站——FLBOOK&#xff0c;轻松实现产品图册的在线展示。 1.注册登录&#x…

交通目标识别数据集YOLO 模型 ui界面✓图片数量15000,xml和txt标签都有 11类 交通道路车辆行人红黄绿数据集 红绿灯数据集 交通信号数据集

YOLO交通目标识别 数据集 模型 ui界面 ✓图片数量15000&#xff0c;xml和txt标签都有&#xff1b; ✓class&#xff1a;biker&#xff0c;car&#xff0c;pedestrian&#xff0c;trafficLight&#xff0c;trafficLight-Green&#xff0c;trafficLight-GreenLeft&#xff0c; tr…

调用第三方接口

目录 一、分析给出的接口文档 二、请求体格式之间的区别 三、示例代码 一、分析给出的接口文档 一般的接口文档包括以下几大部分&#xff1a; 1、请求URL&#xff1a;http://{ip}:{port}/api/ec/dev/message/sendCustomMessageSingle 2、请求方式&#xff1a;POST、GET等 3、…

3.C++经典实例-奇数还是偶数

要判断一个数是奇数还是偶数&#xff0c;只需要判断这个数是否能被2整除即可&#xff0c;如果要判断是否能整除&#xff0c;则要判断当前数除以2的余数是否为0&#xff0c;在C中&#xff0c;余数&#xff0c;使用%号&#xff0c;因此&#xff0c;程序为&#xff1a; #include …

缓存常见问题:缓存穿透、雪崩、击穿及解决方案分析

1. 什么是缓存穿透&#xff0c;怎么解决&#xff1f; 缓存穿透是指用户请求的数据在缓存中不存在即没有命中&#xff0c;同时在数据库中也不存在&#xff0c;导致用户每次请求该数据都要去数据库中查询一遍。如果有恶意攻击者不断请求系统中不存在的数据&#xff0c;会导致短时…

C++初阶学习第七弹——string的模拟实现

C初阶学习第六弹------标准库中的string类_c语言返回string-CSDN博客 通过上篇我们已经学习到了string类的基本使用&#xff0c;这里我们就试着模拟实现一些&#xff0c;我们主要实现一些常用到的函数。 目录 一、string类的构造 二、string类的拷贝构造 三、string类的析构函…

第十四届单片机嵌入式蓝桥杯

一、CubeMx配置 &#xff08;1&#xff09;LED配置 &#xff08;1&#xff09;LED灯里面用到了SN74HC573ADWR锁存器&#xff0c;这个锁存器有一个LE引脚,这个是我们芯片的锁存引脚&#xff08;使能引脚&#xff09;&#xff0c;由PD2这个端口来控制的 &#xff08;2&#xff…

13图书归还-云图书管理系统(Vue3+Spring Boot+element plus)

目录 1 接口地址2 后台代码RecordControllerBookController 3 view/books/BookRecordsVue中前端框架搭建4 api/record.js文件写查询用户借阅记录的接口代码5 api/book.js中写归还图书、查询当前借阅图书接口代码6 BookRecordsVue中导入接口函数&#xff0c;并调用7 运行效果 1 …

C++/初识C++

目录 一、前言 二、正文 1C语言第一个程序&#xff1a; 1.1C的第一个程序&#xff1a; 2.命名空间 2.1 namespace的价值 2.2namespace的定义 2.3namespace的正常使用 3.C输出和输入 三、结言 一、前言 点来不及悼念C语言&#xff0c;接下来出场的是新的语言C。不同于C…

【数据采集工具】Sqoop从入门到面试学习总结

国科大学习生活&#xff08;期末复习资料、课程大作业解析、大厂实习经验心得等&#xff09;: 文章专栏&#xff08;点击跳转&#xff09; 大数据开发学习文档&#xff08;分布式文件系统的实现&#xff0c;大数据生态圈学习文档等&#xff09;: 文章专栏&#xff08;点击跳转&…

unity Gpu优化

不一样的视角&#xff0c;深度解读unity性能优化。unity性能优化&#xff0c;unity内存优化&#xff0c;cpu优化&#xff0c;gpu优化&#xff0c;资源优化&#xff0c;资源包、资源去重优化&#xff0c;ugui优化。 gpu优化静态批处理静态批处理原理规则静态合批的原理静态合批的…

2023年华为杯数学建模竞赛B题论文和代码

DFT类矩阵的整数分解逼近 离散傅里叶变换&#xff08;Discrete Fourier Transform&#xff0c;DFT&#xff09;傅里叶分析方法是信号分析的最基本方法&#xff0c;傅里叶变换是傅里叶分析的核心&#xff0c;通过它把信号从时间域变换到频率域&#xff0c;进而研究信号的频谱结构…

SSM四川工商学院学生宿舍管理系统---附源码54633

摘 要 从20年代开始&#xff0c;计算机疯狂的出现在人们的生活以及工作当中&#xff0c;成为人们生活、工作的好帮手&#xff0c;计算机深入到每家每户当中&#xff0c;网络办公&#xff0c;网络教学更是替换了传统手工记录管理的方式&#xff0c;使用计算机办公可以不必局限于…

MySQL-12.DQL-聚合函数

一.DQL-分组查询 二.聚合函数 -- DQL:分组查询 -- 聚合函数 -- 1.统计该企业员工数量 count select count(id) from tb_emp; select count(job) from tb_emp;select count(A) from tb_emp; select count(*) from tb_emp;-- 2.统计该企业最早入职的员工 min select min(entr…

SQL第18课挑战题

1. 创建一个名为customerswithorders的视图&#xff0c;其中包含customers表中的所有列&#xff0c;但仅仅是那些已下订单的列。提示&#xff1a;可以在orders表上使用join来仅仅过滤所需的顾客&#xff0c;然后使用select来确保用有正确的数据。 创建视图&#xff1a;

电影台词摘抄(十一)——Banana!

Scarlet&#xff1a;Do you know who this is? Kevin&#xff1a;Uh. La cucaracha? n.伊丽莎白(女子名) Scarlet&#xff1a;This is Queen Elizabeth, ruler of England.Oh, I love England, Their music, the …

Linux - 环境变量 | 命令行参数 | 进程基础

文章目录 一、了解冯诺依曼体系结构1、概念2、对数据层面3、实例二、操作系统1、概念2、设计OS的目的3、定位4、操作系统怎么管理&#xff1f; 三、进程1、概念2、怎么管理进程3、描述进程-PCB4、描述进程怎么运行&#xff08;粗略&#xff09;5、进程属性6、创建子进程7、创建…

bash之基本运算符

一.算术运算符 vim test.sh #!/bin/basha10 b20valexpr $a $b echo "a b : $val"valexpr $a - $b echo "a - b : $val"valexpr $a \* $b echo "a * b : $val"valexpr $b / $a echo "b / a : $val"valexpr $b % $a echo "b % a …

c++STL——map与set的使用及介绍

目录 前言&#xff1a; 1. 关联式容器 2. 键值对 3. 树形结构的关联式容器 3.1 set 3.1.1 set的介绍 3.1.2 set的使用 1. set的模板参数列表 2. set的构造 3. set的迭代器 4. set的容量 5. set修改操作 6. set的使用举例 3.2 map 3.2.1 map的介绍 3.2.2 map的…