人和人交流的语言叫自然语言。例如汉语,英语之类的。
人和计算机交流的语言就叫做计算机语言。计算机语言也有很多种类,目前已知上千种。例如C语言, C++, JAVA ……
C语言最初是作为unix系统开发工具而发明的。
C语言是一种编译型的计算机语言。C语言源代码都是文本文件,文本文件无法执行,必须通过编译器的编译和连接器的链接,生成可执行的二进制文件。
.c-源文件 .obj-目标文件(二进制) .exe-可执行文件 .h-头文件
以上都是后缀,即以这些为结尾。例如:test.c等等之类的
每个C语言程序不管有多少行代码,都是从main函数开始执行的,main函数是程序的入口,main函数也被叫做主函数。main函数有且只能有一个。
C语言关键字
C语言中有⼀批保留的名字的符号,比如: int 、 if 、 return ,这些符号被称为保留字或者关键字。
•关键字都有特殊的意义,是保留给C语言使用的
•程序员之间在创建标识符的时候是不能和关键字重复的
•关键字也是不能自己创建的。
C语⾔的32个关键字如下:
(1)auto break case char const continue default do double else enum ex
(2)float for goto if int long register return short signed sizeof
(3)struct switch typedef union unsigned void volatile while
在c99中,虽然加入了新的,但最常见的还是这32个,现在不认识,没关系,越学到后面有些东西自然而然就会了。
字符和ASCll编码
在键盘上可以敲出各种字符,如:a,q,@,#等,这些符号都被称为字符,C语⾔中字符是⽤单引号括起来的,如:'a','b','@'。 我们知道在计算机中所有的数据都是以⼆进制的形式存储的,那这些字符在内存中分别以什么样的二进制存储的呢?如果我们每个人自己给这些字符中的每个字符编⼀个⼆进制序列,这个叫做编码,为了方便⼤家相互通信,不造成混乱,后来美国国家标准学会(ANSI)出台了⼀个标准 ASCII 编码,C语言中的字符就遵循了 ASCII 编码的方式。
下面是一张ASCll码表
• 字符A~Z的ASCII码值从65~90
• 字符a~z的ASCII码值从97~122
• 对应的大小写字符(a和A)的ASCII码值的差值是32
• 数字字符0~9的ASCII码值从48~57
• 换⾏ \n 的ASCII值是:10
• 在这些字符中ASCII码值从0~31 这32个字符是不可打印字符,无法打印在屏幕上观察
大家下来,可以自己在编译器上试一试,我这里就不过多的介绍了。
字符串和\0
C语言中如何表示字符串呢?使用双引号括起来的⼀串字符就被称为字符串,如:"abcdef",就是⼀个字符串。
C语⾔字符串中⼀个特殊的知识,就是在字符串的末尾隐藏放着⼀个 \0 字符,这个 \0 字符是字符串结束的标志。
这里又有几个知识点:1.char是表示字符型。
2.那个arr1与arr2都是定义了一个数组,不知道没关系,后面慢慢会讲到。
3.%s,是字符串的格式化输出。
4.printf的读取结束标志是\0,即遇到\0,就会停止打印了。
根据上面的运行结果,我们发现字符串后面隐藏了一个\0。
转义字符
也许在前⾯的代码中你看到 \n , \0 很纳闷是啥。其实在字符中有⼀组特殊的字符是转义字符,转义字符顾名思义:转变原来的意思的字符。
比如:我们有字符 n ,在字符串中打印的时候自然能打印出这个字符,如下:
如果我们修改⼀下代码,在 n 的前⾯加上 \ ,变成如下代码:
我们可以发现只是加了个\,为什么打印出来的结果就差距这么大呢?
这就是转义字符的问题, \n 是⼀个转义字符表⽰换⾏的意思,我们可以简单的理解为 \ 让 n 的意思 发⽣了转变, n 本来是⼀个普通的字符,被 \ 转义为换⾏的意思。
C语⾔中像这样的转义字符还有⼀些,具体如下:
• \? :在书写连续多个问号时使用,防止他们被解析成三字母词,在新的编译器上没法验证了。
• \' :用于表示字符常量'
• \" :用于表示⼀个字符串内部的双引号
• \\ :用于表示⼀个反斜杠,防止它被解释为⼀个转义序列符。
• \a :警报,这会使得终端发出警报声或出现闪烁,或者两者同时发⽣。
• \b :退格键,光标回退⼀个字符,但不删除字符。
• \f :换页符,光标移到下⼀页。在现代系统上,这已经反映不出来了,行为改成类似于 \v。
• \n :换行符。
• \r :回车符,光标移到同⼀行的开头。
• \t :制表符,光标移到下⼀个水平制表位,通常是下⼀个8的倍数。
• \v :垂直分隔符,光标移到下⼀个垂直制表位,通常是下⼀行的同⼀列。
下⾯2种转义字符可以理解为:字符的8进制或者16进制表示形式
• \ddd :d d d表示1~3个八进制的数字。 如: \130 表示字符X。
• \xdd :d d表示2个十六进制数字。 如: \x30 表示字符0。
• \0 :null 字符,代表没有内容, \0 就是 \ddd 这类转义字符的⼀种,用于字符串的结束标志,其 ASCII码值是0。
有个练习大家可以做一下:
常用的一些进制:二进制、八进制、十六进制、十进制。
二进制:都是用0、1来表示的
八进制:用0~7来表示
十六进制:用数字0~9加上字母a~f
十进制:用0~9来表示
至于它们之间的转换,我们大多数时候都是将其它几种转换为是十进制。
就拿上面的那个例子来说吧。
我们用十进制来算数的时候,我告诉你一个数715,我们来拆分这个数,它是由百位7,十位1和个位5组成,那么它就可以写成这样:7x100+1x10+5=7x10^2+1x10^1+5x10^0(^这个符号是次方的意思,^2就是平方),那么下面这个数(\130)转换为十进制也就可以这样写
\130,这是八进制,1x8^2+3x8^1+0x8^0=64+24=88
\x30,这是十六进制,3x16^1+0x16^0=48
我们可以总结一下:其他进制转换为十进制,各个位数的值乘以该进制的各个位数的值减一次方,再多项相加(加粗是为了让大家更好的阅读,我的语文水平有限,可能不会很好的表达我的意思,望大家海涵)
具体的其它转义字符,我就不举例了,记住常用的就行,有的根本就用不上。
C语言的代码是由⼀条⼀条的语句构成的,C语言中的语句可为以下五类:
• 空语句
• 表达式语句
• 函数调用语句
• 复合语句
• 控制语句
接下来,一 一介绍
空语句是最简单的,⼀个分号就是⼀条语句,是空语句。例如:
空语句,⼀般出现的地方是:这里需要⼀条语句,但是这个语句不需要做任何事,就可以写⼀个空语句。
表达式语句就是在表达式的后边加上分号。如下所示:
函数调用的时候,也会加上分号,就是函数调用语句。 例如:
注:具体代码,不用管,只要知道什么是函数调用语句就行了 。
复合语句
复合语句其实就是代码块,成对括号(大括号)中的代码就构成⼀个代码块,也被称为复合语句。
控制语句用于控制程序的执行流程,以实现程序的各种结构方式(C语言支持三种结构:顺序结构、选择结构、循环结构),它们由特定的语句定义符组成,C语言有九种控制语句。
可分成以下三类:
1. 条件判断语句也叫分支语句:if语句、switch语句;
2. 循环执行语句:do while语句、while语句、for语句;
3. 转向语句:break语句、goto语句、continue语句、return语句。
前面两种我在前面那篇关于C语言分支循环语句详解中讲过,可以去看看,至于第三种,我后面再讲。
注释是对代码的说明,编译器会忽略注释,也就是说,注释对实际代码没有影响。 注释是给程序员自己或者其他程序员看的。 好的注释可以帮我们更好的理解代码,但是也不要过度注释,不要写没必要的注释。 当然不写注释可能会让后期阅读代码的人抓狂。 写注释⼀定程度上反应了程序作者的素质,建议大家写必要的注释,在未来找工作的时候,写代码时留下必要的注释也会给⾯试官留下更好的印象。(这是在网上找的)。
总之,一句话概括:注释是为了更好的理解代码。
C语言的注释有两种表示方法。
/*...*/ 的形式
第⼀种方法是将注释放在 /*...*/ 之间,内部可以分行。
这种注释可以插在行内。
上面示例中, /* file name */ 用来对函数参数进行说明,跟在它后面的代码依然会有效执行。
这种注释⼀定不能忘记写结束符号* / ,否则很容易导致错误。
/*...*/这个注释也不⽀持嵌套注释, /* 开始注释后,遇到第⼀个 */ 就认为注释结束了。
// 的形式
第⼆种写法是将注释放在双斜杠 // 后面,从双斜杠到⾏尾都属于注释。这种注释只能是单行,可以 放在行首,也可以放在⼀行语句的结尾。这是 C99 标准新增的语法。
不管是哪⼀种注释,都不能放在双引号里面。 双引号里面的注释符号,会成为字符串的⼀部分,解释为普通符号,失去注释作用。
上面示例中,双引号里面的注释符号,都会被视为普通字符,没有注释作用。
这就是C语言常见概念的全部内容(当然这是我认为,欢迎大家补充还有的)
这是我刚开始写博客,可能有些不够好,欢迎大家指出我的错误。