软件设计师学习笔记-程序设计语言基础知识

news2025/1/11 9:55:47

前言

备战2023年5月份的软件设计师考试,在此记录学习之路。
知识点总结,具体内容请查看对应的模块。

提示:这里有软件设计师资料,包含软件设计师考试大纲、软件设计师第五版官方教程、历年考试真题。

通过百度网盘分享的文件:软件设计师
链接: https://pan.baidu.com/s/1M6ZKuBJo9DEvdmLgbgDGvg?pwd=1024
提取码:1024
复制这段内容打开「百度网盘APP 即可获取」

系列文章目录

第一章 计算机系统基础知识
第二章 程序设计语言基础知识


文章目录

  • 前言
  • 系列文章目录
  • 第2章 程序设计语言基础知识
    • 2.1 程序设计语言概述
      • 2.1.1 程序设计语言基本概念
        • 1. 低级语言和高级语言。
        • 2. 编译程序和解释程序
      • 2.1.2 程序设计语言的基本成分
        • 1. 数据成分
        • 2. 控制成分包含
        • 3. 函数
      • 2.2.2 编译程序基本原理
        • 1. 词法分析
        • 2. 语法分析
        • 3. 语义分析
        • 4. 中间代码生成
        • 6. 目标代码生成


第2章 程序设计语言基础知识

2.1 程序设计语言概述

2.1.1 程序设计语言基本概念

1. 低级语言和高级语言。

低级语言包括机器语言和汇编语言。
高级语言包括java、c、c++、php、python等。

2. 编译程序和解释程序

计算机只能理解由0、1序列构成的机器语言,因此高级程序设计语言需要翻译,担负这一任务的程序称为“语言处理程序”。语言之间的翻译形式有多种,基本方式为汇编、解释和编译。

用某种高级语言或汇编语言编写的程序称为源程序,源程序不能直接在计算机上执行。
如果源程序是用汇编语言编写的,则需要一个汇编程序将其翻译成目标程序后才能执行。如果源程序是用某种高级语言编写的,则需要对应的解释程序或编译程序对其进行翻译,然后在机器上运行。

解释器:翻译源程序时不生成独立的目标程序。
解释程序和源程序要参与到程序的运行过程中。

编译器:翻译时将源程序翻译成独立保存的目标程序。
机器上运行的是与源程序等价的目标程序,源程序和编译程序都不再参与目标程序的运行过程。

2.1.2 程序设计语言的基本成分

包括数据、运算、控制和传输等。

1. 数据成分

数据必须具有类型,其作用是:

  1. 便于为数据合理分配存储单元。
  2. 便于对参与表达式计算的数据对象进行检查。
  3. 便于规定数据对象的取值范围及能够进行的运算。

2. 控制成分包含

  1. 顺序结构
  2. 选择结构
  3. 循环结构

3. 函数

函数的定义:
函数的定义包括两部分:函数首部和函数体。函数的定义描述了函数做什么和怎么做。函数定义的一般形式为

	返回值的类型 函数名(形式参数表)   //函数首部
	{
		 函数体;
	}

函数首部说明了函数返回值的数据类型、函数的名字和函数运行时所需的参数及类型。
函数所实现的功能在函数体部分进行描述。

函数的调用:

形式为 : 函数名(实参);

(1)值调用(Call by Value)。若实现函数调用时将实参的值传递给相应的形参,则称为是传值调用。在这种方式下形参不能向实参传递信息。
实参可以是变量、常量、表达式。

(2)引用调用(Call by Reference)。引用是C++中引入的概念,当形式参数为引用类型时,形参名实际上是实参的别名,函数中对形参的访问和修改实际上就是针对相应实参所做的访问和改变。
实参可以变量,不能是常量和表达式。

2.2.2 编译程序基本原理

编译方式:词法分析、 语法分析、语义分析、中间代码生成、代码优化、目标代码生成。
**解释方式:**词法分析、语法分析、语义分析。

编译器和解释器都不可省略词法分析、语法分析、语义分析且顺序不可交换即词法分析、语法分析、语义分析是必须的。

编译器方式中中间代码生成和代码优化不是必要,可省略。
即编译器方式可以在词法分析、语法分析、语义分析阶段后直接生成目标代码

符号表:

不断收集、记录和使用源程序中一些相关符号的类型和特征等信息,并将其存入符号表中。记录源程序中各个字符的必要信息,以辅助语义的正确性检查和代码生成。

在这里插入图片描述

1. 词法分析

词法分析的任务是对源程序从前到后(从左到右)处个字符的扫描,从中识别出一个个“单词”符号。“单词”符号是程序设计语言的基本语法单位,如:关键字(或称保留字)、标识符、常数、运算符和分隔符等。
词法分析依据语言的词法规则。
词法分析程序输出的“单词”常以二元组的方式输出,即单词的词别和自身的值。(记号流)

词法分析输入源程序,输出二元组(记号流)

正规式与正规集

在这里插入图片描述

有限自动机

有限自动机是词法分析的一个工具,它能正确地识别正规集。
确定的有限自动机(DFA):对每一个状态来说识别字符后转移的状态是唯一的。
不确定的有限自动机(NFA):对每一个状态来说识别字符后转移的状态是不唯一的。

2. 语法分析

语法分析的任务是在词法分析的基础上,根据语言的语法规则将单词符号序列分解成各类语法单位,如“表达式”“语句”和“程序”等。语法规则就是各类语法单位的构成规则。通过语法分析确定整个输入串是否构成一个语法上正确的程序。如果源程序中没有语法错误,语法分析后就能正确地构造出其语法树;否则指出语法错误,并给出相应的诊断信息。

语法分析:输入记号流,输出语法树((分析树)
语法分析阶段的主要作用是:对各条语句的结构进行合法性分析,分析程序中的句子结构是否正确
语法分析可以发现全部语法错误。

1.上下文无关文法

在这里插入图片描述
2. 自顶向下语法分析
3.自底向上语法分析

3. 语义分析

语义分析阶段分析各语法结构的含义,检查源程序是否包含静态语义错误,并收集类型信息供后面的代码生成阶段使用。只有语法和语义都正确的源程序才能翻译成正确的目标代码。
语义分析的一个主要工作是进行类型分析和检查。程序设计语言中的一个数据类型一般包含两个方面的内容:类型的载体及其上的运算。例如,整除取余运算符只能对整型数据进行运算,若其运算对象中有浮点数就认为是类型不匹配的错误。

语义分析:输入语法树(分析树)
语义分析阶段的主要作用是进行类型分析和检查

语义分析阶段不能发现的程序中的全部语义错误。
语义分析阶段可以发现静态语义错误
不能发现动态语义错误,动态语义错误运行时才能发现

4. 中间代码生成

中间代码生成阶段的工作是根据语义分析的输出生成中间代码。“中间代码”是一种简单且含义明确的记号系统,可以有若干种形式,它们的共同特征是与具体的机器无关。最常用的一种中间代码是与汇编语言的指令非常相似的三地址码,其实现方式常采用四元式

常见的中间代码有:后缀式、三地址码、三元式、四元式和树(图)等形式。
中间代码与具体的机器无关(不依赖具体的机器),
可以将不同的高级程序语言翻译成同一种中间代码。
中间代码可以跨平台。
因为与具体的机器无关,使用中间代码有利于进行与机器无关的优化处理和提高编译程序的可移植性。

6. 目标代码生成

目标代码生成是编译器工作的最后一个阶段。这一阶段的任务是把中间代码变换成特定机器上的绝对指令代码、可重定位的指令代码或汇编指令代码,这个阶段的工作与具体的机器密切相关。

目标代码生成阶段的工作与具体的机器密切相关
寄存器的分配工作处于目标代码生成阶段

后缀式:(后序遍历树)左右根
中缀式:(中序遍历树)左根右
树形表示

在这里插入图片描述

本章到此结束。

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

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

相关文章

好好学习,天天向上——“C”

各位uu们我又来啦,今天小雅兰来给大家分享一个有意思的东西,是为:天天向上的力量 基本问题:持续的价值 一年365天,每天进步1%,累积进步多少呢? 1.01^365 一年365天,每天退步1%&#…

python(运算符,顺序,选择,循环语句)

专栏:python 个人主页:HaiFan. 专栏简介:本专栏主要更新一些python的基础知识,也会实现一些小游戏和通讯录,学时管理系统之类的,有兴趣的朋友可以关注一下。 python基础语法2前言一、输入输出1.通过控制台输…

CSS 伪类

CSS 伪类 CSS 伪类是添加到选择器的关键字,用于指定所选元素的特殊状态。例如,伪类 :hover 可以用于选择一个按钮,当用户的指针悬停在按钮上时,设置此按钮的样式。 举例说明: button:hover {color: blue; }伪类由冒号&#xff…

【应用】SpringBoot -- Webflux + R2DBC 操作 MySQL

SpringBoot -- Webflux R2DBC 操作 MySQLWebflux 概述Webflux 基本使用Webflux R2DBC 操作 MySQLController ServiceRoute Handler参考文章Webflux 概述 简单来说,Webflux 是响应式编程的框架,与其对等的概念是 SpringMVC。两者的不同之处在于 Webf…

贪心策略(四)合并区间合集

目录 435. 无重叠区间移除元素的最小个数 无重叠区间 区间组合结果 合并区间_牛客题霸_牛客网 435. 无重叠区间 移除元素的最小个数 给定一个区间的集合 intervals ,其中 intervals[i] [starti, endi] 。返回 需要移除区间的最小数量,使剩余区间互不重…

【Linux调试器-gdb使用】

目录 1. 背景 2. 使用 3 命令总结 1. 背景 通过c语言的学习我们知道程序的发布方式有两种,debug模式和release模式,debug模式就是我们所说的调试模式。我们已经熟悉了在Windows平台下VS系列的调试,接下来我们一起在无图形化界面的Linux下来…

2023-01-18 flink 11.6 时间水印 和 窗口周期的关系计算方法

forBoundedOutOfOrderness 和 TumblingEventTimeWindowsforBoundedOutOfOrderness(M)TumblingEventTimeWindows(N)第一条数据的时间TS1第一个窗口期公式:窗口开始时间:win_start ((TS1-M)/N) * N窗口结束时…

Docker上部署goweb项目

文章目录一、安装go语言环境①下载go语言环境②解压go语言环境到指定目录③验证是否成功④配置镜像加速二、go语言项目配置第一种:先编译后打包(分步部署,靠谱)第二种:直接打包法三、成功运行一、安装go语言环境 ①下…

Zabbix 监控 Linux操作系统的监控指标

一、Zabbix 监控 Linux操作系统的监控指标 (仅供参考) Zabbi x默认使用Zabbix agent监控操作系统,其内置的监控项可以满足系统大部分的指标监控,因此,在完成Zabbix agent的安装后,只需在前端页面配置并关联相应的系统监控模板就可以了。 如果内置监控项不能满足监控需求…

走向开放世界强化学习、IJCAI2022论文精选、机器人 RL 工具、强化学习招聘、《强化学习周刊》第73期...

No.73智源社区强化学习组强化学习周刊订阅《强化学习周刊》已经开启“订阅功能”,扫描下面二维码,进入主页,选择“关注TA”,我们会向您自动推送最新版的《强化学习周刊》。本期贡献者:(李明,刘青…

【Kotlin】类的继承 ① ( 使用 open 关键字开启类的继承 | 使用 open 关键字开启方法重写 )

文章目录一、使用 open 关键字开启类的继承二、使用 open 关键字开启方法重写一、使用 open 关键字开启类的继承 Kotlin 中的类 默认都是 封闭的 , 无法被继承 , 如果要想类被继承 , 需要在定义类时 使用 open 关键字 ; 定义一个普通的 Kotlin 类 : class Person(val name: S…

分析GC日志来进行JVM调优

不同的垃圾收集器产生的GC日志大致遵循了同一个规则,只是有些许不同,不过对于G1收集器的GC日志和其他垃圾收集器有较大差别,话不多说,正式进入正文。。。 什么时候会发生垃圾收集 首先我们来看一个问题,那就是什么时…

SpringBoot集成Elasticsearch7.4 实战(三)

本篇文章主要讲的是:在Springboot环境下,管理数据1. 数据管理1.1. 新增数据1.1.1. 单实例新增http方式提交数据,案例中我将数据格式做了规范,提交过程中需要指定索引名,以及JSON格式数据,这样尽可能在实际过程中做到通…

图论算法:普里姆算法(C++实现+图解)

文章目录最小生成树普里姆算法实现过程代码实现最小生成树 什么是最小生成树? 对于如图所示的带权无向连通图来说:从图中任意顶点出发,进行dfs或者bfs便可以访问到图中的所有顶点,因此连通图中一次遍历所经过的边的集合以及图中所有顶点的…

libvirt零知识学习2 —— libvirt源码下载

1. libvirt官网主页 libvirt的官网地址为: https://libvirt.org/ 主页如下图所示: 2. libvirt官网下载主页 libvirt的官网下载页地址为(在主页中点击“Download”按钮即可跳转到): https://libvirt.org/downloads…

KaiwuDB 首席解决方案专家 金宁:1.0 时序数据库核心功能解读

以下是实录文章精简版欢迎大家点赞、收藏、关注!大家好,今天介绍将分为 3 部分:首先从物联网蓬勃发展的时代背景出发,我们一起来看看数据库究竟将面临怎样的挑战与机遇;接着我将为大家详细 KaiwuDB 1.0 时序数据库的核…

(Java高级教程)第四章必备前端基础知识-第一节:HTML

文章目录一:HTML概述(1)概述(2)标签(3)HTML基本结构二:常用标签介绍(1)注释(2)标题(3)段落(4&…

React Fragment

首先 我们编写这样一个例子 我们在创建一个react项目 在src的目录下创建components目录 components下创建一个子组件 我这里的名字叫 subset.jsx import React from "react";export default class subset extends React.Component{constructor(props){super(prop…

阿B百大名单公布,有你喜欢的up吗?

阿B在1月13日中午19点30分公布了2022百大UP主名单,那么今年的某站年度UP主都是谁呢?你喜欢的up入选了吗? 咱就来自己查一下都有谁入选了吧~ 我们是用python自动获取名单的哦。 环境使用 python 3.9 pycharm 模块使用 selenium 谷歌驱动 …

Java基础之《netty(26)—netty其他常用编解码器》

一、解码器-ReplayingDecoder 1、函数声明 public abstract class ReplayingDecoder<S> extends ByteToMessageDecoder 2、ReplayingDecoder扩展了ByteToMessageDecoder类&#xff0c;使用这个类&#xff0c;我们不必调用readableBytes()方法。参数S指定了用户状态管理…