程序由什么构成?

1、对数据的描述;在程序中要指定用到哪些数据以及这些数据的类型和数据的组织形式,其实这就是数据结构(data structure)。

2、对操作的描述;即要求计算机就行操作的步骤,也就是算法(algorithm)。

数据是操作的对象,操作的目的是对数据进行加工处理,来得到期望的结果。

作为程序设计人员,必须认真考虑和设计数据结构和设计操作步骤(即算法)。

著名计算机科学家沃思(Nikiklous Wirth)提出了一个公式:

  算法 + 数据结构 = 程序

知道今天,这个公式对于过程化程序来说仍然是适用的。

——摘自《C程序设计 第四版》谭浩强

不要认为只有“计算”的问题才有算法。广义地讲,为了解决问题而采取的方法和步骤,就称为“算法”。例如,描述太极拳动作的图解,就是“太极拳的算法”。

计算机算法分为两类:数值运算算法和非数值运算算法。

算法的特性:有穷性、确定性、0个或多个输入、1个或多个输出、有效性

结构化程序设计方法的基本思路:

  1、自顶向下

  2、逐步细化

  3、模块化设计

  4、结构化编码

3、结构体的长度是多少很复杂

因为它涉及到字符填充机器字对齐

4、指针变量大小就是4字节

1 char * p1;
2
3 int * p2;
4
5 float * p3;
6
7 double * p4;
8
9 std::cout<<sizeof(p1)<<endl<<sizeof(p2)<<endl<<sizeof(p3)<<endl<<sizeof(p4)<<endl;

输出:

4

4

4

4

1 char * p1;
2
3 int * p2;
4
5 float * p3;
6
7 double * p4;
8
9 std::cout<<sizeof(p1)<<endl<<sizeof(p2)<<endl<<sizeof(p3)<<endl<<sizeof(p4)<<endl;

输出:

1

4

4

8

注意:指针变量为啥只占4字节,因为这里的地址最大只需要4字节即可表示。而且这取决于编译器,32位的编译器指针变量占4byte,64位的编译器指针变量就占8byte。

5、变量名跟指针的区别

往下看之前,你要带着问题看,通过函数改变一个变量,我们是选择方法一、还是方法二、方法三,好处是啥?为啥要这样选?

方法一:

 1 # include <iostream>
2
3 using namespace std;
4
5 void change(int);
6
7 int main(int argc, char const *argv[])
8 {
9 int m = 6;
10
11 change(m);
12
13 cout<<m<<endl;
14
15 return 0;
16 }
17
18 void change(int n)
19 {
20 n = 7;
21 }

输出:6

这样的输出结果是不是让你大吃所惊呢?明明改变了m的值,为啥最后是没有呢?

补充:开始我觉得大家通过后面的例子应该能明白,使用了函数change()后为啥没有改变m的值。发表完我觉得我还是再啰嗦一下。

    首先我们定义了一个变量 int m = 5;

    当我们调用函数change()时,定义了另一个变量 int n; 然后使用 change(m); 就是把m的值赋给n,即&n指向了m的地址,然后就没有m的事了,后来你改变的是变量n,跟变量m没一毛钱关系。

其实你所理解的应该是这样的

方法二:

 1 # include <iostream>
2
3 using namespace std;
4
5 int change(int);
6
7 int main(int argc, char const *argv[])
8 {
9 int m = 6;
10
11 m = change(m);
12
13 cout<<m<<endl;
14
15 return 0;
16 }
17
18 int change(int n)
19 {
20 n = 7;
21
22 return n;
23 }

输出:7

但是你还可以这样:用指针传参

方法三:

 1 # include <iostream>
2
3 using namespace std;
4
5 void change(int *);
6
7 int main(int argc, char const *argv[])
8 {
9 int m = 6;
10
11 change(&m);
12
13 cout<<m<<endl;
14
15 return 0;
16 }
17
18 void change(int * n)
19 {
20 * n = 7;
21 }

输出:7

现在知道指针的魅力了吧,它能改变数值啊。

看完了这三种方法,你能回答上面的问题吗?

很明显方法一不能用,因为它达不到所要的效果。

那么就剩下方法二跟方法三待选了?

选择方法三,假如m不是一个简单数据类型而是一个结构体类型。使用方法三有如下优点:

(这也是指针的优点)

  ①可以快速的更改数据

  ②耗用内存小(因为指针变量只占4byte)

  ③执行速度快

C预备知识_001的更多相关文章

  1. 驱动开发学习笔记. 0.06 嵌入式linux视频开发之预备知识

    驱动开发读书笔记. 0.06  嵌入式linux视频开发之预备知识 由于毕业设计选择了嵌入式linux视频开发相关的项目,于是找了相关的资料,下面是一下预备知识 UVC : UVC,全称为:USB v ...

  2. 受限玻尔兹曼机(RBM)学习笔记(一)预备知识

    去年 6 月份写的博文<Yusuke Sugomori 的 C 语言 Deep Learning 程序解读>是囫囵吞枣地读完一个关于 DBN 算法的开源代码后的笔记,当时对其中涉及的算法原 ...

  3. 学习Identity Server 4的预备知识

    我要使用asp.net core 2.0 web api 搭建一个基础框架并立即应用于一个实际的项目中去. 这里需要使用identity server 4 做单点登陆. 下面就简单学习一下相关的预备知 ...

  4. JAVA面向对象-----面向对象(基础预备知识汇总)

    终于整理好了面向对象基础预备知识,但是有点多,所以你们懂的,贴图,较长的代码我还是会排版出来的,我不想把时间浪费在排版上在word里排版一次已经很浪费时间了,所以请谅解. public class C ...

  5. 用ASP.NET Core 2.0 建立规范的 REST API -- 预备知识 (2) + 准备项目

    上一部分预备知识在这 http://www.cnblogs.com/cgzl/p/9010978.html 如果您对ASP.NET Core很了解的话,可以不看本文, 本文基本都是官方文档的内容. A ...

  6. ASP.NET Core的实时库: SignalR -- 预备知识

    大纲 本系列会分为2-3篇文章. 第一篇介绍SignalR的预备知识和原理 然后会介绍SignalR和如何在ASP.NET Core里使用SignalR. 本文的目录如下: 实时Web简述 Long ...

  7. 学习Identity Server 4的预备知识 (误删, 重补)

    我要使用asp.net core 2.0 web api 搭建一个基础框架并立即应用于一个实际的项目中去. 这里需要使用identity server 4 做单点登陆. 下面就简单学习一下相关的预备知 ...

  8. LDA-线性判别分析(一)预备知识

    本来是要调研 Latent Dirichlet Allocation 的那个 LDA 的, 没想到查到很多关于 Linear Discriminant Analysis 这个 LDA 的资料.初步看了 ...

  9. IP地址和子网划分学习笔记之《预备知识:进制计数》

    一.序:IP地址和子网划分学习笔记开篇 只要记住你的名字,不管你在世界的哪个地方,我一定会去见你.——新海诚 电影<你的名字> 在我们的日常生活中,每个人的名字对应一个唯一的身(敏)份(感 ...

随机推荐

  1. Java初学者作业——编写Java程序, 实现根据用户购买商品总金额, 计算实际支付的金额及所获得的购物券金额。

    返回本章节 返回作业目录 需求说明: 编写Java程序, 实现根据用户购买商品总金额, 计算实际支付的金额及所获得的购物券金额. 购买总金额达到或超过 1000元,按 8折优惠,送 200元的购物券: ...

  2. Oracle中的基本数据类型

    一.Oracle 基本数据类型 1.字符数据类型 CHAR:存储固定长度的字符串,如果没有指定长度,默认为1个字节,如果数据长度没有达到指定的长度,则通过填充空格的方式来使其达到定义的长度(CHAR类 ...

  3. MATLAB 错误之生成step图表出错

    m文件: step(Gi_close) hold on 错误示例: 使用step函数生成图表后,报错如下: Plots must be of the same type and size to be ...

  4. 『无为则无心』Python函数 — 30、Python变量的作用域

    目录 1.作用于的概念 2.局部变量 3.全局变量 4.变量的查找 5.作用域中可变数据类型变量 6.多函数程序执行流程 1.作用于的概念 变量作用域指的是变量生效的范围,在Python中一共有两种作 ...

  5. Linux-saltstack-3 saltstack的grains和pillar的基本使用

    @ 目录 一.简介 二.grains 1.查看客户端所有的grains项 2.查看grains的所有的项和值 3.查看某个项和值 (1)语法1: (2)语法2: 4.根据grains来匹配目标主机 例 ...

  6. HttpRunner_参数化进阶

    一.获取返回包数据   在提取参数时,当 HTTP 的请求响应结果为 JSON 格式,则可以采用.运算符的方式,逐级往下获取到参数值:响应结果的整体内容引用方式为 content 或者 body,如上 ...

  7. Swagger的应用

    一.介绍 一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 框架. 二.依赖 <dependency> <groupId>io.springf ...

  8. 转雅虎web前端网站优化 34条军规

    雅虎给出了优化网站加载速度的34条法则(包括Yslow规则22条) 详细说明,下载转发 ponytail 的译文 1.Minimize HTTP Requests 减少HTTP请求 图片.css.sc ...

  9. [流畅的Python]第一章数据模型

    这些来自同一家出版社的动物书 像是计算机科学界一盏盏指路明灯 余幼时 初试读 学浅 以为之晦涩难懂 像是老学究咬文嚼字 现在看起来还有些有趣 其实理工男大多都很有趣 这一章介绍了 怎么样去视线一个带有 ...

  10. 记一次线上SpringCloud-Feign请求服务超时异常排查

    由于近期线上单量暴涨,第三方反馈部分工单业务存在查询处理失败现象,经排查是当前系统通过FeignClient调用下游系统出现部分超时失败(异常代码贴在下方). Caused by: feign.Ret ...