震惊!!!原来计算机是这样工作的!

2024-03-22 03:52
文章标签 工作 计算机 原来 震惊

本文主要是介绍震惊!!!原来计算机是这样工作的!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

震惊!!!原来计算机是这样工作的!

  • 一:计算机是什么?
    • 1:什么是计算机
    • 2:计算机的分类
      • 2.1:终端设备
      • 2.2:服务器
      • 2.3:嵌入式设备
    • 3:冯诺依曼体系
  • 二:CPU
    • 1:CPU的重要指标
      • 1.1:CPU的占用率
      • 1.2:CPU的频率
    • 2:CPU 是如何执行指令的?
      • 1:CPU执行指令

一:计算机是什么?

1:什么是计算机

大家都知道电脑是计算机!
但计算机不仅仅是电脑!!!
手机,平板,智能手表,电视,路由器,智能冰箱,智能洗衣机,智能空调…这些都可以称为计算机.

2:计算机的分类

2.1:终端设备

台式机,笔记本,手机,iPad等,这些平时用户使用的.

2.2:服务器

2.3:嵌入式设备

终端设备和服务器更通用,可以解决不同的领域的问题.
主体功能不是用来计算的,而是针对一些特定的专属场景,量身定做的"专用计算机"(只是针对某个特定的场景,搞特定的功能)

3:冯诺依曼体系

为什么上面的这些设备,都是计算机???
因为他们都遵守"冯诺依曼体系结构"
冯诺依曼规定:一台计算机都是由这5部分组成:运算器,控制器,输入设备,输出设备,存储器.
运算器,控制器现在又合称为CPU
输入设备主要包括:键盘,鼠标,摄像头…
输出设备主要包括:显示器,音响,打印机…
但有的硬件设备,可能既是输入设备,又是输出设备,比如蓝牙,网卡,触摸屏…

二:CPU

CPU是计算机的大脑,运行的任何一个程序,本质上都是通过CPU来进执行的,
主要进行各种算数运算和逻辑运算

1:CPU的重要指标

1.1:CPU的占用率

CPU就像一个"打工人",一个打工人,一天工作8个小时,但可能该打工人花4个小时,就把活干完了,此时,CPU的占用率就可以称为50%.
CPU的占用率:一个计算机上,同时运行着很多的程序,这些程序,也不一定一直在工作,把这些程序工作占用的时间百分比,综合计算就会得到CPU的总的占用率.
最终算出来的总的占用率,也是和程序活动直接相关的.
现在的CPU其实是好几个打工人的"集合",一个CPU,大概率是8核心的,可能更多,
引入更多的核心,本质上就相当于"干活的人"多了,但是每个人的干活速度,还是那么多,要想让程序跑的更快,就需要在设计程序的时候,能够把要完成的任务,拆分成多个部分,交给不同的核心去完成.

1.2:CPU的频率

CPU的频率,描述了CPU干活的效率,数字越大,干活越快,可以简单粗暴的认为:CPU的频率,就是1秒,CPU运算多少次/执行了多少条指令.
(写的程序,最终都会被编译成计算机能够识别的二进制的指令的)(机器语言)
CPU在被设计出来的时候,CPU的厂商就会规定,这个CPU能够支持哪些指令,程序猿就可以通过这些指令来指挥CPU干活.
指令可以认为是CPU被设计出来的时候,给程序猿提供的一些"编程接口"
CPU有很多种架构,不同架构的CPU,支持的指令是不同的,也就是同一条指令,在这个CPU的机器上能够运行,但到另外一条机器上,就不能运行了.

CPU的频率,有两个概念:
1:基础频率:最低多少
2:最大频率;

2:CPU 是如何执行指令的?

所有的指令,都要加载到内存中,然后才能被CPU读取,并执行.
比如:一个Java程序,写出来 的是一个.java源代码文件,编译得到.class文件,(仍然在硬盘上)运行程序的时候,.jvm就会把这个.class文件加载到内存中,在进一步的被翻译成CPU能够识别的二进制指令.
冯诺依曼体系规定:一个程序,指令和数据,到时要在存储器中保存的,CPU如果要执行,都是要自动的从存储器中读取到对应的指令的.

1:CPU执行指令

CPU执行指令,大概经历三个阶段:
1:读指令(把内存中的指令数据,读取到CPU的寄存器中).
CPU上也能存指令,存储数据的模块称为"寄存器",速度比内存更快,但存储空间更小.
2:解析指令:理解当前指令要做什么.
3:执行指令.

这篇关于震惊!!!原来计算机是这样工作的!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/834461

相关文章

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

LiteFlow轻量级工作流引擎使用示例详解

《LiteFlow轻量级工作流引擎使用示例详解》:本文主要介绍LiteFlow是一个灵活、简洁且轻量的工作流引擎,适合用于中小型项目和微服务架构中的流程编排,本文给大家介绍LiteFlow轻量级工... 目录1. LiteFlow 主要特点2. 工作流定义方式3. LiteFlow 流程示例4. LiteF

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3

RabbitMQ工作模式中的RPC通信模式详解

《RabbitMQ工作模式中的RPC通信模式详解》在RabbitMQ中,RPC模式通过消息队列实现远程调用功能,这篇文章给大家介绍RabbitMQ工作模式之RPC通信模式,感兴趣的朋友一起看看吧... 目录RPC通信模式概述工作流程代码案例引入依赖常量类编写客户端代码编写服务端代码RPC通信模式概述在R

无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案

《无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案》:本文主要介绍了无法启动此程序,详细内容请阅读本文,希望能对你有所帮助... 在计算机使用过程中,我们经常会遇到一些错误提示,其中之一就是"api-ms-win-core-path-l1-1-0.dll丢失

使用easy connect之后,maven无法使用,原来需要配置-Djava.net.preferIPv4Stack=true问题

《使用easyconnect之后,maven无法使用,原来需要配置-Djava.net.preferIPv4Stack=true问题》:本文主要介绍使用easyconnect之后,maven无法... 目录使用easGWowCy connect之后,maven无法使用,原来需要配置-DJava.net.pr

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带

kotlin中的模块化结构组件及工作原理

《kotlin中的模块化结构组件及工作原理》本文介绍了Kotlin中模块化结构组件,包括ViewModel、LiveData、Room和Navigation的工作原理和基础使用,本文通过实例代码给大家... 目录ViewModel 工作原理LiveData 工作原理Room 工作原理Navigation 工