Detailed explanation of being processing

1.predefined symbol(we can view it as some can deirectly be used constants)

for example,

2.#define define constants

Now we supplement some knowledges.

(1)The storage device on the computer

1.memory 2.hard disk 3.register(on the cpu,reading speed very fast)

A code --> register int num;//meaning -- advice put the value of num in the register.

(we often use it when this variable need to be used repeatedly but whether use it depend on the complier judgement)

(2)for(;;) if the judgement write nothing,representing constantly true,which is dead circle.

(3)#define .... At last better not to add ;

A #define using example.

3.#define define macro

format -- #define name(parameter) stuff // do not need";" and the name and "(" need fit closely.

function-- parameter do not calculate and direct put in stuff.

for example,

#undef can cancel a #define

or

so we should remind add () when we use #define

4.side effect

b = a++

a++ is side effect.

when a macro parameter have side effect,it also will make some surprise situations.

5.Some positive and negative between marco and function

Characteristic

The string content will not be search.

Positive

(1)marco performance more better amd running more fast than function because marco just replace the code but function need stack creating to run.

(2) marco perameter need not type but function need.

(3)marco can directly deliver type.

Negative

(1)marco just direct replace the code,so it will add coding length.

(2)marco can not debug because the switch it is running in preprocessing progress but debug just test the program code.

(3)The operator precedence also have question.

(4)marco can not recurse.Can #define itself.

6.

7.#

make parameter in the string that can not be change be the object signal and make it stringify.

8.##

Creating a function mold

A using situation example

9.marco name always all capitalize while function name always not all capitalize

10.conditional comliation directive

1.ifdef

2.#if

do not use variable because this coding all processing in preprocessing but in this time just constant having and variable is not created.

3.branch

4.#if defined(M) if M is defined dy #define ,it will be true which is at the same of #ifdef

5.#if !defined(M) if M is not defined by #define ,it will be true which is at the same of #ifndef

5.head document including

#include <...> standard head document

#include "..." customize head document

#include "..." first will find the path of the source file's directory(文件所在目录的路径)

if not find ,it will find the standard library haed document.

#include <...> just will find the standard library haed document.

6.File nesting

A head document possbility will be used many times.

So we should have some idea to reduce repeat use.

1.#ifndef TEST_H

//first time will do in it

#define TEST_H//put this twe codes in head document head

//when define it,the last time can not put in it

....

#endif // put this code in the document last

2.#program once

using it can directly make this document just using once.

At last I tell something I found.

A variable just a digital.Like a int * p.The p essence is a digital.In pointer, it will be viewed as a address.

In pointer,it save just a address but by it type,it will control the address memory by the type manner.

for example,

//指针是带有有色眼镜的,它看内存的方式只和她的类型有关。

Like it ,using 0 to be the struct start address to calculate it offset.we can not visit the value but we can using pointer to find the struct member address.

相关推荐
玖剹2 小时前
递归练习题(四)
c语言·数据结构·c++·算法·leetcode·深度优先·深度优先遍历
序属秋秋秋6 小时前
《Linux系统编程之进程环境》【环境变量】
linux·运维·服务器·c语言·c++·操作系统·系统编程
Yue丶越6 小时前
【C语言】数据在内存中的存储
c语言·开发语言·网络
Yue丶越15 小时前
【C语言】字符函数和字符串函数
c语言·开发语言·算法
蓝牙先生16 小时前
简易TCP C/S通信
c语言·tcp/ip·算法
Old_Driver_Lee17 小时前
C语言常用语句
c语言·开发语言
松涛和鸣18 小时前
从零开始理解 C 语言函数指针与回调机制
linux·c语言·开发语言·嵌入式硬件·排序算法
无限进步_21 小时前
C语言动态内存的二维抽象:用malloc实现灵活的多维数组
c语言·开发语言·数据结构·git·算法·github·visual studio
星轨初途1 天前
数据结构排序算法详解(5)——非比较函数:计数排序(鸽巢原理)及排序算法复杂度和稳定性分析
c语言·开发语言·数据结构·经验分享·笔记·算法·排序算法