从入门到放弃C语言-瞎倒腾(2)

2023-11-11 06:58
文章标签 语言 入门 放弃 倒腾

本文主要是介绍从入门到放弃C语言-瞎倒腾(2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

请扫码加公众号,周三周六定时更新大笑


       上一次简单的介绍了一下C语言的代码结构,总结一下可以说C语言主要由库包含,main函数以及在函数中的语句组成。

       一个源代码文件仅仅由库包含和main函数组成是最简单的结构了,为了实现更加复杂的功能,我们需要往这个结构中加入新的东西。

 

       增加新的东西自然是为了增加代码的功能,把所有的功能都放入main自然也是一种方法。

       但是,不够优雅,不够装逼。

      比如

       intmain()

       {

              aLotOfStatement    //nice! have done some fantastic work

             

              aLotOfStatement     // just so so

 

 

              aLotOfStatement        //wtf, what am I writing

 

 

              aLotOfStatement     // I want to kill myself……..

}

 

       其实,生活不仅有眼前的装逼,还有你写完几百行以后的……

       如果你当真把几百行全部写在了main函数,刚开始你和别人都能看得懂你的代码。慢慢得,看得懂的只有你和上帝。到了最后,看得懂你代码的,大概只有上帝了……

 

       这时候,我们迫切需要一种能够让你优雅装逼的利器来解决这种问题,嗯,虽然不是老司机,我推荐使用函数(function)。

       函数呢,体现的是自顶向下设计思路,这个东西在面相过程编程中是极其重要的,日后详细讨论函数的时候在说。

 

       简单来说呢,我们写函数的目的就是把main函数那么多的语句通过拆分,形成多个独立的功能个体,来完成一些小任务。当程序进入内存以后,从main函数开始执行,main函数不断调用别的函数来完成一些任务,并通过返回值来存储关键数据用于接下来的计算。

 

 

       废话不多说,看一下如何编写函数。

 

       下面的小程序完成小学的加法和乘法。

      

       #include<stdio.h>

       #include<stdlib.h>

 

       int  add(int a,int b);

       intmul(int a,int b);

 

       intmain()

       {

              intc,d,e,f;

              c=1;d=2;

 

              e=add(c,d);

              f=mul(c,d);

       }

      

       intadd(int a,int b)

       {

              returna+b;

       }

 

       intmul(int a,int b)

       {

              returna*b;

       }

 

执行完程序后,e=1+2=3,f=1*2=2

 

在上面的程序中,库包含以后跟着的两句叫做函数原型。(  int add(int a,int b);  )。

普遍的语法结构是这样的(按照英文翻译理解)

returnType    functionNmae(argumentTypeargument1, ……… argumentType arumentn);

函数原型呢也可以叫函数签名(function signature)。它呢,并没有说明这个函数是干嘛的,只是说程序中有个函数是functionName,有一天她会披着金甲圣衣,驾着七彩,,,,,

 

不不不。只是说程序中有个函数,叫functionName,它会完成一定的功能。当然呢,只是说说将会有这个函数。

 

 

在main函数以后跟着的其实就是前面两个函数签名所说的函数。

在我们把它能实现的功能放在了花括号中间,然后函数签名所指的函数也就有了真正实体。

这个能够完成某一功能的实体叫做函数定义。

当有了函数定义后,一个函数的创建工作也就在代码中完成了。

 

当有了一个个自己定义的函数以后,程序的功能会大大的增强,更好的是,main函数要做的事情被各个函数给分配走了,main函数的代码长度会大大减少,这样也就能够在编写代码的时候能够优雅的装逼了,因为功能被分散的以后,程序哪里出问题了就直接修改相关函数即可,而并不需要在整个main函数里面找我错哪里了,我究竟错哪里了!!

这样,也就能够优雅的装逼啦。

 

最后提一下,前面的代码结构中,我们把的结构是

 

#include <***>  //库包含

 

//函数签名

 

int main()

{

}   //main函数

 

//各种函数定义

 

int aFuntion()

{

}

…….

 

其实,还有一种结构是这样的

 

#include<****>//库包含

 

//各种函数定义

 

int aFunction()

{}

int bFuntion()

{}

 

//main函数

int main()

{

}

这一种结构与前面的差别在于函数签名没了,我见过很多人这样编写程序,说实话,我推荐前面一种,因为如果要了解一个程序必定是从main开始来自上向下了解的,把main函数放在前面能够直接体现程序的功能,自定义函数放在main后面更体现了他们辅助main完成功能的地位。


这篇关于从入门到放弃C语言-瞎倒腾(2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

poj 2104 and hdu 2665 划分树模板入门题

题意: 给一个数组n(1e5)个数,给一个范围(fr, to, k),求这个范围中第k大的数。 解析: 划分树入门。 bing神的模板。 坑爹的地方是把-l 看成了-1........ 一直re。 代码: poj 2104: #include <iostream>#include <cstdio>#include <cstdlib>#include <al

MySQL-CRUD入门1

文章目录 认识配置文件client节点mysql节点mysqld节点 数据的添加(Create)添加一行数据添加多行数据两种添加数据的效率对比 数据的查询(Retrieve)全列查询指定列查询查询中带有表达式关于字面量关于as重命名 临时表引入distinct去重order by 排序关于NULL 认识配置文件 在我们的MySQL服务安装好了之后, 会有一个配置文件, 也就

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX