the c programing language 学习过程4
4Functions and Program Structure
scratch 刮擦 starting over from scratch从头开始 reside驻留 separately 分别的 facilities工具容易 macro arguments宏参数 pattern模式 irrelevant不相干的 sophisticated复杂的 optional sign 可选的标志 handles 处理 presence存在 invocation调用 scope rules 作用域规则
reorganizing 改组 mandatory强制的 受命令的 centralize使集中 peripherally外围的 recursion 递归 implementation贯彻 安装启用 macro宏 pitfalls陷阱 concatenation一系列相关
1UNIX cc main.c getline.c strindex.c把目标文件main.o getline.o strindex.o放到可执行文件a.out中 如果 main.c 错误 可以 cc main.c getline.o strindex.o同样将main.c编译 和后两者一起载入 cc用.c和.o来区分源文件与目标文件
2return expression 要加括号 但是不是必须的
3dummy( ) { } 这个函数啥也不做啥也不返回 如果定义中缺省了返回类型 那么则为int
4返回非INT型变量可以先声明 如double atof( char s[ ]){ ****************} 可以在main中先声明 double sum, atof ( char [ ] ); 声明了一个double 变量sum 和一个函数
5声明时 类型要相同 如果不同 函数和声明在同一个文件会被检测出error 而在多个文件(更常见)内则不会被检测到 比如函数返回double 主调声明int 那函数返回值将被转化为int 就没有意义了
6/* atoi:利用atof函数把字符串s转换成整数 */
int atoi( char s[ ] )
{
double atof(char s[ ]);
return (int) atof ( s );
}
其中如果用return atof ( s );atof也会被强制转换成int 但是编译器会出现警告信息(警告是什么 能吃么)
7逆波兰表示法 运算符号在运算量后面(1 - 2) * (4 + 5)一类的中辍可用逆波兰表示法表示成:1 2 - 4 5 + * 用栈计算就行 运算分量进栈 遇到运算符就pop两个分量出来(如果是二元运算符)运算后进栈 最后把栈顶的值拿出来输出
8+ * 满足交换律 顺序无所谓 可以push(pop()*pop()) 而-和/要规定顺序 最好用临时变量调剂下 比如 op=pop(); push(pop()/op)
9c=getch()获取一个字符给c ungetch(c) 把c退回到缓冲区里(假装什么事都没有发生)
#define BUFSIZE 100
char buf[BUFSIZE]; /* 用于unget函数的缓冲区 */
int bufp = 0; /* buf中下一个自由位置 */
int getch(void) /* 取一个字符(可能是推回的字符) */
{
return ( bufp > 0 ) ? buf[--bufp] : getchar( );
}
void ungetch(int c) /* 把字符推回到输入中 */
{
if ( bufp >= BUFSIZE )
printf ( "ungetch: too many characters\n" );
else
buf[bufp++] = c;
}
标准函数里有ungetch
10外部变量的作用域从其声明处到函数的末尾
如main( ) { … }
int sp = 0;
double val[MAXVAL];
void push( double f ) { … }
double pop( void ) { … }
sp val 在push 和pop中无需声明就可以直接用 但是对main不可见
11如果一个外部变量在定义前就要用到 那就要强制用extern 声明就通报变量(主要声明一个类型) 定义是要有赋值(并不是赋值而是分配内存空间 解释错误)(存储分配)
如int sp;
double val[MAXVAL];
这两个说明定义了外部变量 s p与v a l,并为之分配存储单元,同时也用作供源文件其余部分
使用的说明。另一方面,如下两行:
extern int sp;
extern double val[MAXVAL];
为源文件剩余部分说明了 s p是一个 i n t类型的外部变量, v a l是一个 d o u b l e数组类型的外部变量
定义数组时要写上大小 extern声明时候就随意了.
12 static variables 静态变量 可以被当前所在源文件的函数调用 不能被其他函数访问 适用于说明外部变量和函数
static char buf[BUFSIZE]; /* 供ungetch函数使用的缓冲区 */
static int bufp = 0; /* 缓冲区buf的下一个自由位置 */
int getch( void ) { …}
void ungetch( int c) { … }
此处 buf和bufp只能被getch和ungetch用到
静态变量在作为内部变量时和自动变量相似 区别在于不管函数激活还是终止 静态变量的值都存在 自动变量随着函数的调用和结束 会消失
13 register variable 建议编译器 此变量为常用变量 建议放在寄存器内 当然编译器可以不鸟你 只能用在自动变量和实参上
register int x;
f(register unsignedm)
{
register int i;
}
想要在使用寄存器变量的地方加上 register没啥坏处 编译器可以将他们忽视掉 值得注意的是 加了这玩意不管是不是存在寄存器里 地址都不能访问了
14 外面的xy 和里面的xy 没有联系 但是最好也别这么编程 看得蛋疼
int x;
int y;
f ( double x )
{
double y;
…
}
15 外部变量和静态变量在初始化缺省下 为0 自动和寄存器变量为未定义(垃圾值)纯量变量会在定义时被初始化
如 int x = 1; long day = 1000L*60L*60L*24L;
外部变量和静态变量 初始化必须是一个常量式子 初始化变量最好用显示的方式 比较直观
数组的初始化可以这样int days[ ] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 }; 数组大小缺省时 按元素个数计 这里数组大小为12
15 字符数组初始化可以用字符串
char pattern [] = "ould";
它是如下虽然长些但却与之等价的定义的缩写:
char pattern [] = { 'o', 'u', 'l', 'd' , '\0' }
数组个数为5
16#include "文件名"
或
#include <文件名>
前者从源程序找 后者从定义的规则找
17#define 名字 替换文本 如果较长 可以在后面加\可以延续多行
替换只对单词进行,对括在引号中的字符串不起作用。例如,如果Y E S是一个被定义的名字,那么在 printf ( "YES" ) 或Y E S M A N中不能进行替换。
18#define max( A, B ) ( ( A ) > ( B ) ? ( A ) : ( B ) )
x = max( p+q, r+s );
将被替换成
x = ( ( p+q ) > ( r+s ) ? ( p+q ) : ( r+s ) ); 形参将直接变替换
当然也有一定的缺陷
如
max( i++, j++ ) /* 错 */
又或者#define square( x ) x * x /* 错 */ 在square(z+1)的情况下
#undef可以取消定义
#undef getchar
int getchar(void)
{·······}
可以用加#来替换字符串
#define dprint( expr ) printf( #expr " = %g\n", expr )
当用诸如
dprint( x/y );
调用该宏时,该宏就被扩展成
printf( "x/y" " = %g\n", x/y ); 等价于printf(“x/y=%g\n”,x/y);
(***较复杂) ##可以把形参就实参替换
如
#define paste( front, back ) front ## back
从而宏调用paste(name, 1)的结果是建立单词name1。
19条件包含 conditional inclusion #if
例一
#if !defined( HDR ) //如果没有定义HDR 则定义
#define HDR /* hdr.h文件的内容*/
#endif
例二
#if SYSTEM == SYSV //根据不同的SYSTEM 选择不同的头文件
#define HDR "sysv.h"
#elif SYSTEM == BSD
#define HDR "bsd.h"
#elif SYSTEM == MSDOS
#define HDR "msdos.h"
#else
#define HDR "default.h"
#endif
# include HDR
例三 ifndef 如果没有
#ifndef HDR //如果没有HDR (例一的变型)
#define HDR
/* hdr.h文件的内容*/
#endif
the c programing language 学习过程4的更多相关文章
- the c programing language 学习过程8
glean 捡拾落穗; glean insight 深入了解 modeled模型化 peripheral外围的 himogeneous匀称的 intents 意图 excerpt摘录 intende ...
- the c programing language 学习过程7
interact 互动 carriage运费运输 linefeed 换行 redirection改方向 interleaved交叉存取 adequate足够的 untouched原样的 specif ...
- the c programing language 学习过程6
payroll工资名单 hierarchy分层层次 vexing 使人烦恼的 alignment结盟 semantics 语义 aethetic审美 parameterize 参数化 1结构标记 成员 ...
- the c programing language 学习过程5
lumped 集成总结 mandating托管 consecutively连续地 contiguous临近的 mnemonic记忆力的 mimics 酷似 魔方 bind捆绑 synonym同义词 s ...
- the c programing language 学习过程3
ControlFlow 控制流 specify 指定 compound statement 复合语句 cryptic有隐含意义的 ambiguity歧义 robust稳健 disintegratio ...
- the c programing language 学习过程2
manipulated 操纵 notations符号 hexadecimal十六进制 precision精度 be concatenated at 把····联系起来 enumerations枚举 ...
- 使用一个数组存储一个英文句子"java is an object oriented programing language"
class fun { public static void main(String[] args) { String str="java is an object oriented pro ...
- The python programing language
Python is an example of high-level language. As you might infer from the name “high-level language”, ...
- Linux下C高手成长过程
建议学习路径: 首先先学学编辑器,vim, emacs什么的都行. 然后学make file文件,只要知道一点就行,这样就可以准备编程序了. 然后看看<C程序设计语言>K&R, ...
随机推荐
- HTTP就是这么简单
为什么要学HTTP? 我们绝大多数的Web应用都是基于HTTP来进行开发的.我们对Web的操作都是通过HTTP协议来进行传输数据的. 简单来说,HTTP协议就是客户端和服务器交互的一种通迅的格式. H ...
- [squid] kid1| ERROR: No forward-proxy ports configured.
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
- Spring Boot-JPA
前文我们使用SPRING INITIALIZR快速构建了一个空的Spring Boot项目,并增加web模块实现了HTTP请求. 这一篇继续在该demo的基础上,增加JPA的功能. JPA全称Java ...
- 轮询、长轮询、长连接、flash socket 的区别
轮询:客户端定时向服务器发送Ajax请求,服务器接到请求后马上返回响应信息并关闭连接. 优点:后端程序编写比较容易. 缺点:请求中有大半是无用,浪费带宽和服务器资源. 实例:适于小型应用. 长轮询:客 ...
- iOS-UINavigationBar【颜色设置】
UINavigationBar的一些颜色设置,以前老是忘,这次记住了 - (void)setNavigationBar{ ///NavigationBar backgroundcolor[背景色] [ ...
- ABP官方文档翻译 5.2 动态We API层
动态Web APID层 创建动态Web API控制器 ForAll方法 重写ForAll ForMethods Http动词 WithVerb方法 HTTP特性 命名约定 API管理器 RemoteS ...
- HTTP/1.1与HTTP/1.0的区别[转]
原文链接:http://blog.csdn.net/forgotaboutgirl/article/details/6936982 下面主要从几个不同的方面介绍HTTP/1.0与HTTP/1.1之间的 ...
- bzoj 2095: [Poi2010]Bridges [混合图欧拉回路]
2095: [Poi2010]Bridges 二分答案,混合图欧拉路判定 一开始想了一个上下界网络流模型,然后发现不用上下界网络流也可以 对于无向边,强制从\(u \rightarrow v\),计算 ...
- BZOJ 4518: [Sdoi2016]征途 [斜率优化DP]
4518: [Sdoi2016]征途 题意:\(n\le 3000\)个数分成m组,一组的和为一个数,求最小方差\(*m^2\) DP方程随便写\(f[i][j]=min\{f[k][j-1]+(s[ ...
- BZOJ 2287. [HZOI 2015]疯狂的机器人 [FFT 组合计数]
2287. [HZOI 2015]疯狂的机器人 题意:从原点出发,走n次,每次上下左右不动,只能在第一象限,最后回到原点方案数 这不煞笔提,组合数写出来发现卷积NTT,然后没考虑第一象限gg 其实就是 ...