imtoken官网正版下载|lf

作者: imtoken官网正版下载
2024-03-07 19:38:11

C语言问题:%f和%lf的区别_%f 和%lf-CSDN博客

>

C语言问题:%f和%lf的区别_%f 和%lf-CSDN博客

C语言问题:%f和%lf的区别

最新推荐文章于 2022-04-05 21:29:10 发布

meme_yun

最新推荐文章于 2022-04-05 21:29:10 发布

阅读量10w+

收藏

448

点赞数

200

分类专栏:

c语言

输入

输出

文章标签:

c语言

%f

%lf

区别

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/meme_yun/article/details/88586815

版权

c语言

同时被 3 个专栏收录

1 篇文章

2 订阅

订阅专栏

输入

1 篇文章

1 订阅

订阅专栏

输出

1 篇文章

1 订阅

订阅专栏

%f和%lf分别是float类型和double类型用于格式化输入输出时对应的格式符号。 其中: float,单精度浮点型,对应%f。 double,双精度浮点型,对应%lf。 在用于输出时: float类型可以使用%lf格式,但不会有任何好处。 double类型如果使用了%f格式可能会导致输出错误。 在用于输入时: double 类型使用了%f格式,会导致输入值错误。 float类型使用double类型不仅会导致输入错误,还可能引起程序崩溃。 所以在输入输出时,一定要区分好double和float,而使用对应的格式符号。

 

为什么呢???因为C语言的%f是浮点型函数的占位符,%If是长浮点型函数的占位符

 

讲道理这种东西没学过编译原理很容易错。 因为float和double都会被转换成double然后送给printf函数 所以其实用%f还是%lf输出其实并不重要 然而输入时%lf表示地址对应的是8字节的double,%f表示地址对应的是4字节的float,存储方式都不一样,混用了肯定会出问题。

优惠劵

meme_yun

关注

关注

200

点赞

448

收藏

觉得还不错?

一键收藏

知道了

18

评论

C语言问题:%f和%lf的区别

%f和%lf分别是float类型和double类型用于格式化输入输出时对应的格式符号。其中:float,单精度浮点型,对应%f。double,双精度浮点型,对应%lf。在用于输出时:float类型可以使用%lf格式,但不会有任何好处。double类型如果使用了%f格式可能会导致输出错误。在用于输入时:double 类型使用了%f格式,会导致输入值错误。float类型使用doubl...

复制链接

扫一扫

专栏目录

《你必须知道的495个C语言问题》

03-20

内容简介

《你必须知道的495个C语言问题》以问答的形式组织内容,讨论了学习或使用C语言的过程中经常遇到的一些问题。书中列出了C用户经常问的400多个经典问题,涵盖了初始化、数组、指针、字符串、内存分配、库函数、C预处理器等各个方面的主题,并分别给出了解答,而且结合代码示例阐明要点。

《你必须知道的495个C语言问题》结构清晰,讲解透彻,是各高校相关专业C语言课程很好的教学参考书,也是各层次C程序员的优秀实践指南。

--------------------------------------------------------------------------------

C是一门简洁精妙的语言,掌握基本语法容易,真正能够自如运用,就不那么简单了。你难免会遇到各种各样的问题,有些可能让你百思不得其解,甚至翻遍图书馆,也找不到问题的答案。

《你必须知道的495个C语言问题》的出版填补了这一空白。许多知识点的阐述都是其他资料中所没有的,弥足珍贵。

涵盖C99标准

目录

~第1章 声明和初始化 1

基本类型 1

1.1 我该如何决定使用哪种整数类型? 1 

1.2 为什么不精确定义标准类型的大小? 2

1.3 因为C语言没有精确定义类型的大小,所以我一般都用typedef定义int16和int32。然后根据实际的机器环境把它们定义为int、short、long等类型。这样看来,所有的问题都解决了,是吗? 2 

1.4 新的64位机上的64位类型是什么样的? 3

指针声明 3

1.5 这样的声明有什么问题?char *p1, p2; 我在使用p2的时候报错了。 3

1.6 我想声明一个指针,并为它分配一些空间,但却不行。这样的代码有什么问题?char *p; *p=malloc(10); 4

声明风格 4

1.7 怎样声明和定义全局变量和函数最好? 4

1.8 如何在C中实现不透明(抽象)数据类型? 5

1.9 如何生成“半全局变量”,就是那种只能被部分源文件中的部分函数访问的变量? 5

存储类型 6

1.10 同一个静态(static)函数或变量的所有声明都必须包含static存储类型吗? 6

1.11 extern在函数声明中是什么意思? 6

1.12 关键字auto到底有什么用途? 7

类型定义(typedef) 7

1.13 对于用户定义类型,typedef 和#define有什么区别? 7

1.14 我似乎不能成功定义一个链表。我试过typedef struct{char *item; NODEPTR next;}* NODEPTR; 但是编译器报了错误信息。难道在C语言中结构不能包含指向自己的指针吗? 7 

1.15 如何定义一对相互引用的结构? 9

1.16 Struct{ } x1;和typedef struct{ } x2; 这两个声明有什么区别? 10

1.17 “typedef int(*funcptr)();”是什么意思? 10

const 限定词 10

1.18 我有这样一组声明:typedef char *charp; const charp p; 为什么是p而不是它指向的字符为const? 10

1.19 为什么不能像下面这样在初始式和数组维度值中使用const值?const int n=5; int a[n]; 10

1.20 const char *p、char const *p和char *const p有什么区别? 10

复杂的声明  11

1.21 怎样建立和理解非常复杂的声明?例如定义一个包含N个指向返回指向字符的指针的函数的指针的数组? 11 

1.22 如何声明返回指向同类型函数的指针的函数?我在设计一个状态机,用函数表示每种状态,每个函数都会返回一个指向下一个状态的函数的指针。可我找不到任何方法来声明这样的函数——感觉我需要一个返回指针的函数,返回的指针指向的又是返回指针的函数……,如此往复,以至无穷。 12 

数组大小 13

1.23 能否声明和传入数组大小一致的局部数组,或者由其他参数指定大小的参数数组? 13

1.24 我在一个文件中定义了一个extern数组,然后在另一个文件中使用,为什么sizeof取不到数组的大小? 13

声明问题 14

1.25 函数只定义了一次,调用了一次,但编译器提示非法重声明了。 14

*1.26 main的正确定义是什么?void main正确吗? 15

1.27 我的编译器总在报函数原型不匹配的错误,可我觉得没什么问题。这是为什么? 15

1.28 文件中的第一个声明就报出奇怪的语法错误,可我看没什么问题。这是为什么? 15

1.29 为什么我的编译器不允许我定义大数组,如double array[256][256]? 15

命名空间 15

1.30 如何判断哪些标识符可以使用,哪些被保留了? 15

初始化 18

1.31 对于没有显式初始化的变量的初始值可以作怎样的假定?如果一个全局变量初始值为“零”,它可否作为空指针或浮点零? 18 

1.32 下面的代码为什么不能编译? intf(){char a[]="Hello, world!";} 18

*1.33 下面的初始化有什么问题?编译器提示“invalid initializers ”或其他信息。char *p=malloc(10); 19

1.34 char a[]= "string literal";和char *p="string literal"; 初始化有什么区别?当我向p[i] 赋值的时候,我的程序崩溃了。 19 

1.35 char a{[3]}= "abc"; 是否合法? 20

1.36 我总算弄清楚函数指针的声明方法了,但怎样才能初始化呢? 20

1.37 能够初始化联合吗? 20

第2章 结构、联合和枚举 21

结构声明 21

2.1 struct x1{ };和typedef struct{ }x2; 有什么不同? 21

2.2 这样的代码为什么不对?struct x{ }; x thestruct; 22

2.3 结构可以包含指向自己的指针吗? 22

2.4 在C语言中用什么方法实现抽象数据类型最好? 22

*2.5 在C语言中是否有模拟继承等面向对象程序设计特性的好方法? 22

2.6 为什么声明extern f(struct x *p); 给我报了一个晦涩难懂的警告信息? 23

2.7 我遇到这样声明结构的代码:struct name {int namelen; char namestr[1];};然后又使用一些内存分配技巧使namestr数组用起来好像有多个元素,namelen记录了元素个数。它是怎样工作的?这样是合法的和可移植的吗? 23 

2.8 我听说结构可以赋给变量也可以对函数传入和传出。为什么K&R1却明确说明不能这样做? 25

2.9 为什么不能用内建的==和!=操作符比较结构?  26

2.10 结构传递和返回是如何实现的? 26

2.11 如何向接受结构参数的函数传入常量值?怎样创建无名的中间的常量结构值? 26

2.12 怎样从/向数据文件读/写结构? 27

结构填充 27

2.13 为什么我的编译器在结构中留下了空洞?这导致空间浪费而且无法与外部数据文件进行“二进制”读写。能否关掉填充,或者控制结构域的对齐方式? 27 

2.14 为什么sizeof返回的值大于结构大小的期望值,是不是尾部有填充? 28

2.15 如何确定域在结构中的字节偏移量? 28

2.16 怎样在运行时用名字访问结构中的域? 29

2.17 C语言中有和Pascal的with等价的语句吗?  29

2.18 既然数组名可以用作数组的基地址,为什么对结构不能这样? 29

2.19 程序运行正确,但退出时却“core dump ”(核心转储)了,怎么回事? 29

联合 30

2.20 结构和联合有什么区别? 30

2.21 有办法初始化联合吗? 30

2.22 有没有一种自动方法来跟踪联合的哪个域在使用? 30

枚举 31

2.23 枚举和一组预处理的#define有什么不同?  31

2.24 枚举可移植吗? 31

2.25 有什么显示枚举值符号的容易方法吗? 31

位域 31

2.26 一些结构声明中的这些冒号和数字是什么意思? 31

2.27 为什么人们那么喜欢用显式的掩码和位操作而不直接声明位域? 32

第3章 表达式  33

求值顺序 33

3.1 为什么这样的代码不行?a[i]= i++; 33

3.2 使用我的编译器,下面的代码int i= 7; printf("%d\n", i++ * i++); 打印出49。不管按什么顺序计算,难道不该是56吗? 33 

3.3 对于代码int i=3; i=i++; 不同编译器给出不同的i值,有的为3,有的为4,哪个是正确的? 34 

*3.4 有这样一个巧妙的表达式:a^= b^= a^= b; 它不需要临时变量就可以交换a和b的值。 34

3.5 可否用显式括号来强制执行我所需要的计算顺序并控制相关的副作用?就算括号不行,操作符优先级是否能够控制计算顺序呢? 35 

3.6 可是&&和||操作符呢?我看到过类似while((c = getchar()) != EOF && c != '\n')的代码…… 35

3.7 是否可以安全地认为,一旦&&和||左边的表达式已经决定了整个表达式的结果,则右边的表达式不会被求值? 36 

3.8 为什么表达式printf("%d %d", f1(), f2()); 先调用了f2?我觉得逗号表达式应该确保从左到右的求值顺序。 36 

3.9 怎样才能理解复杂表达式并避免写出未定义的表达式?“序列点”是什么? 36

3.10 在a[i] = i++;中,如果不关心a[]的哪一个分量会被写入,这段代码就没有问题,i也的确会增加1,对吗? 38 

3.11 人们总是说i=i++的行为是未定义的。可我刚刚在一个ANSI编译器上尝试过,其结果正如我所期望的。 38 

3.12 我不想学习那些复杂的规则,怎样才能避免这些未定义的求值顺序问题呢? 38

其他的表达式问题 39

*3.13 ++i和i++有什么区别? 39

3.14 如果我不使用表达式的值,那我应该用i++还是++i来做自增呢? 39

3.15 我要检查一个数是不是在另外两个数之间,为什么if(a b c)不行? 40

3.16 为什么如下的代码不对?int a=1000, b=1000; long int c=a * b; 40

3.17 为什么下面的代码总是给出0?double degC, degF; degC= 5.0 / 9 * (degF - 32); 40

3.18 需要根据条件把一个复杂的表达式赋给两个变量中的一个。可以用下面这样的代码吗?((condition) ? a : b)= complicated_expression; 41 

3.19 我有些代码包含这样的表达式。a ? b=c : d 有些编译器可以接受,有些却不能。为什么? 41

保护规则 42

3.20 “semantics of‘’change in ANSI C”的警告是什么意思? 42

3.21 “无符号保护”和“值保护”规则的区别在哪里? 42

第4章 指针 45

基本的指针应用 45

4.1 指针到底有什么好处? 45

4.2 我想声明一个指针并为它分配一些空间,但却不行。这些代码有什么问题呢?char *p; *p =malloc(10); 45 

4.3 *p++自增p还是p所指向的变量? 46

指针操作 46

4.4 我用指针操作int数组的时候遇到了麻烦。 46

4.5 我有一个char *型指针碰巧指向一些int型变量,我想跳过它们。为什么((int *)p)++; 这样的代码不行? 47

4.6 为什么不能对void *指针进行算术操作? 47

4.7 我有些解析外部结构的代码,但是它却崩溃了,显示出了“unaligned access”(未对齐的访问)的信息。这是什么意思? 47

作为函数参数的指针 47

4.8 我有个函数,它应该接受并初始化一个指针:void f(int *ip){ static int dummy = 5; ip = &dummy;}但是当我如下调用时:int *ip; f(ip); 调用者的指针没有任何变化。 47 

4.9 能否用void ** 通用指针作为参数,使函数模拟按引用传递参数?  48

4.10 我有一个函数extern intf(int *); ,它接受指向int型的指针。我怎样用引用方式传入一个常数?调用f(&5);似乎不行。 49 

4.11 C语言可以“按引用传参”吗? 50

其他指针问题 50

4.12 我看到了用指针调用函数的不同语法形式。到底怎么回事? 50

4.13 通用指针类型是什么?当我把函数指针赋向void *类型的时候,编译通不过。 51

4.14 怎样在整型和指针之间进行转换?能否暂时把整数放入指针变量中,或者相反? 51

*4.15 我怎样把一个int变量转换为char *型?我试了类型转换,但是不行。 52

第5章 空指针  53

空指针和空指针常量 53

5.1 臭名昭著的空指针到底是什么? 53

5.2 怎样在程序里获得一个空指针? 54

5.3 用缩写的指针比较“if(p)”检查空指针是否有效?如果空指针的内部表达不是0会怎样? 55

NULL 宏 56

5.4 NULL是什么,它是怎么定义的? 56

5.5 在使用非零位模式作为空指针的内部表示的机器上,NULL 是如何定义的? 56

5.6 如果NULL定义成#define NULL((char *)0) ,不就可以向函数传入不加转换的NULL 了吗? 57

5.7 我的编译器提供的头文件中定义的NULL为0L。为什么? 57

5.8 NULL可以合法地用作函数指针吗? 57

5.9 如果NULL和0作为空指针常量是等价的,那我到底该用哪一个呢? 58

5.10 但是如果NULL的值改变了,比如在使用非零内部空指针的机器上,用NULL(而不是0)

不是更好吗? 58 

5.11 我曾经使用过一个编译器,不使用NULL就不能编译。 58

5.12 我用预处理宏#define Nullptr(type)(type *)0帮助创建正确类型的空指针。 59

回顾 59

5.13 这有点奇怪:NULL可以确保是0,但空(null)指针却不一定? 59

5.14 为什么有那么多关于空指针的疑惑?为什么这些问题如此频繁地出现? 60

5.15 有没有什么简单点儿的办法理解所有这些与空指针有关的东西呢? 60

5.16 考虑到有关空指针的所有这些困惑,要求它们的内部表示都必须为0不是更简单吗? 60

5.17 说真的,真有机器用非零空指针吗,或者不同类型用不同的表示? 61

地址0 上到底有什么? 61

5.18 运行时的整数值0转换为指针以后一定是空指针吗? 61

5.19 如何访问位于机器地址0处的中断向量?如果我将指针值设为0,编译器可能会自动将它转换为非零的空指针内部表示。 62 

5.20 运行时的“null pointer assignment”错误是什么意思?应该怎样捕捉它? 62

第6章 数组和指针 63

数组和指针的基本关系 63

6.1 我在一个源文件中定义了char a[6],在另一个源文件中声明了extern char *a。为什么不行? 63

6.2 可是我听说char a[]和char *a是等价的。是这样的吗? 63

6.3 那么,在C语言中“指针和数组等价”到底是什么意思? 64

6.4 既然它们这么不同,那为什么作为函数形参的数组和指针声明可以互换呢? 65

数组不能被赋值 66

6.5 为什么不能这样向数组赋值?extern char *getpass(); char str[10]; str=getpass("Enter password:"); 66 

6.6 既然不能向数组赋值,那这段代码为什么可以呢?int f(char str[]){ if(str[0] == '\0') str="none";…} 66 

6.7 如果你不能给它赋值,那么数组如何能成为左值呢? 66

回顾 67

6.8 现实地讲,数组和指针的区别是什么? 67

6.9 有人跟我讲,数组不过是常指针。这样讲准确吗? 67

6.10 我还是很困惑。到底指针是一种数组,还是数组是一种指针? 67

6.11 我看到一些“搞笑”的代码,包含5["abcdef"]这样的“表达式”。这为什么是合法的C语言表达式呢? 68

数组的指针  68

6.12 既然数组引用会退化为指针,如果array是数组,那么array和&array又有什么区别呢? 68

6.13 如何声明一个数组的指针? 69

动态数组分配 70

6.14 如何在运行时设定数组的大小?怎样才能避免固定大小的数组? 70

6.15 我如何声明大小和传入的数组一样的局部数组? 70

6.16 如何动态分配多维数组? 71

6.17 有个很好的窍门,如果我这样写:int realarray[10]; int *array = &realarray[-1]; 我就可以把“array”当作下标从1 开始的数组。 72

函数和多维数组 73

6.18 当我向一个接受指针的指针的函数传入二维数组的时候,编译器报错了。 73

6.19 我怎样编写接受编译时宽度未知的二维数组的函数? 74

6.20 我怎样在函数参数传递时混用静态和动态多维数组? 74

数组的大小  75

6.21 当数组是函数的参数时,为什么sizeof不能正确报告数组的大小? 76

6.22 如何在一个文件中判断声明为extern的数组的大小(例如,数组定义和大小在另一个文件中)?sizeof操作符似乎不行。 76 

6.23 sizeof返回的大小是以字节计算的,怎样才能判断数组中有多少个元素呢? 76

第7 章 内存分配 77

基本的内存分配问题 77

7.1 为什么这段代码不行?char *answer; printf("Type something:\n"); gets(answer); printf("You typed \"%s\"\n", answer); 77

7.2 我的strcat() 不行。我试了下面的代码:char *s1= "Hello,"; char *s2= "world!"; char *s3= strcat(s1, s2);但是我得到了奇怪的结果。 78 

7.3 但是strcat的文档说它接受两个char *型参数。我怎么知道(空间)分配的事情呢? 78

*7.4 我刚才试了这样的代码:char *p; strcpy(p, "abc");它运行正常。怎么回事?为什么它没有出错? 79 

*7.5 一个指针变量分配多少内存? 79

7.6 我使用fgets将文件的所有行读入一个数组,为什么读入的每一行都是最后一行的内容呢? 79

7.7 我有个函数,本该返回一个字符串,但当它返回调用者的时候,返回的字符串却是垃圾信息。

为什么?  80

*7.8 那么返回字符串或其他聚集的正确方法是什么呢? 81

调用malloc 81

7.9 为什么在调用malloc()时报出了“waring: assignment of pointer from integer lacks a cast”? 81

7.10 为什么有些代码小心翼翼地把malloc返回的值转换为分配的指针类型? 81

*7.11 在调用malloc()的时候,错误“不能把void * 转换为int * ”是什么意思? 82

7.12 我看到下面这样的代码:char *p = malloc(strlen(s) + 1); strcpy(p,s); 难道不应该是malloc ((strlen(s) + 1) * sizeof(char)) 吗? 82 

7.13 我为malloc写了一个小小的封装函数。它为什么不行? 82

7.14 我想声明一个指针并向它分配一些内存,但是不行。这样的代码有什么问题?char *p; *p = malloc(10); 82 

7.15 我如何动态分配数组? 83

7.16 怎样判断还有多少内存? 83

7.17 malloc(0)是返回空指针还是指向0个字节的指针? 83

7.18 我听说有的操作系统在程序使用的时候才真正分配malloc申请的内存。这合法吗? 83

有关malloc 的问题 83

7.19 为什么malloc返回了离谱的指针值?我的确读过问题7.9,而且也在调用之前包含了extern void *malloc();声明。  83 

7.20 我用一行这样的代码分配一个巨大的数组,用于数值运算:double *array = malloc (256 *256 *sizeof(double));malloc()并没有返回空指针,但是程序运行得有些奇怪,好像改写了某些内存,或者malloc()并没有分配我申请的那么多内存。为什么? 84 

7.21 我的PC机有8兆内存。为什么我只能分配640K左右的内存? 84

7.22 我的应用程序非常依赖数据结构的节点的动态分配,而malloc/free的代价成了瓶颈。我该怎么做? 84

7.23 我的程序总是崩溃,显然发生在malloc内部的某个地方。但是我看不出哪里有问题。是malloc有bug吗? 84

释放内存 85

7.24 动态分配的内存一旦释放之后就不能再使用,是吧? 85

7.25 为什么在调用free()之后指针没有变空?使用(赋值、比较)释放之后的指针有多么不安全? 86

7.26 当我调用malloc()为一个函数的局部指针分配内存时,我还需要用free()显式地释放吗? 86

7.27 我在分配一些结构,它们包含指向其他动态分配的对象的指针。我在释放结构的时候,还需要释放每一个下级指针吗? 86 

7.28 我必须在程序退出之前释放分配的所有内存吗? 86

7.29 我有个程序分配了大量的内存,然后又释放了。但是从操作系统看,内存的占用率却并没有变回去。 87 

分配内存块的大小 87 

7.30 free()怎么知道有多少字节需要释放? 87

7.31 那么我能否查询malloc包,以查明可分配的最大块是多大? 87

7.32 为什么sizeof不能告诉我它所指的内存块的大小? 87

其他分配函数 88

7.33 (像问题6.14中那样)动态分配数组之后,还能改变它的大小吗? 88

7.34 向realloc()的第一个参数传入空指针合法吗?你为什么要这样做? 89

7.35 calloc()和malloc()有什么区别?应该用哪一个?利用calloc 的零填充功能安全吗?free()可以释放calloc()分配的内存吗,还是需要一个cfree()?  90

7.36 alloca是什么?为什么不提倡使用它? 91

第8章 字符和字符串 92

8.1 为什么strcat(string, '!'); 不行? 92

8.2 我想检查一个字符串是否跟某个值匹配。为什么这样不行?if(string == "value") 92

8.3 如果我可以写char a[] = "Hello, world!"; 那为什么不能写char a[14]; a = "Hello, world!"; 93 

8.4 为什么我的strcat 不行?我试了char *s1="Hello,"; char *s2="world!"; char *s3 =strcat(s1, s2);可得到的结果很奇怪。 93 

8.5 char a[]= "string literal"; 和char *p= "string literal"; 初始化有什么区别?当我对p[i]赋值的时候,程序崩溃了。 93 

8.6 我怎么得到与字符相对应的数字(即ASCII 或其他字符集下的)值?反过来又该怎么做? 94

8.7 C语言有类似其他语言的"substr"(提取子串)这样的函数吗? 94

8.8 我将用户键入的字符串读入数组,然后再显示出来。当用户键入\n这样的序列时,为什么不能正确处理呢? 94 

8.9 我注意到sizeof('a')是2而不是1(即不是sizeof(char)),是不是我的编译器有问题? 94

8.10 我正开始考虑多语言字符集的问题。是否有必要担心sizeof(char)会被定义为2,以便表达16位的字符集呢? 95 

第9章 布尔表达式和变量 96

9.1 C语言中布尔值该用什么类型?为什么它不是一个标准类型?我应该用#define或enum定义真值和假值吗? 96 

9.2 既然在C 语言中所有的非零值都被看作“真”,那是不是把TRUE 定义为1很危险?如果某个内建的函数或关系操作符“返回”不是1的其他值怎么办?  97 

9.3 当p是指针时,if(p)是合法的条件表达式吗? 98

9.4 我该使用像TRUE和FALSE这样的符号名称还是直接用1和0来作布尔常量? 98

9.5 我准备使用的一个第三方头文件定义了自己的TRUE和FALSE,它们跟我已经开发的部分不兼容。我该怎么办? 98 

第10章 C预处理器 99

宏定义 99

10.1 我想定义一些函数式的宏,例如:#define square(x)x * x但它们并不总是正确的。为什么? 99

10.2 这里有一些的预处理宏,使用它们,我可以写出更像Pascal的C代码。你觉得怎么样? 100

10.3 怎么写一个交换两个值的通用宏?  101

10.4 书写多语句宏的最好方法是什么?  101

10.5 用typdef和预处理宏生成用户定义类型有什么区别? 102

头文件 102

10.6 我第一次把一个程序分成多个源文件,我不知道该把什么放到.c文件,把什么放到.h文件。(“.h”到底是什么意思?) 102 

10.7 可以在一个头文件中包含另一头文件吗? 103

10.8 完整的头文件搜索规则是怎样的?  104

10.9 我在文件的第一个声明就遇到奇怪的语法错误,但是看上去没什么问题。 104

10.10 我使用了来自两个不同的第三方库的头文件,它们都定义了相同的宏,如TRUE、FALSE、Min()和Max()等,但是它们的定义相互冲突,而且跟我在自己的头文件中的定义也有冲突。我该怎么办? 104 

10.11 我在编译一个程序,看起来我好像缺少需要的一个或多个头文件。谁能发给我一份? 105

条件编译  105

10.12 怎样构造比较字符串的#if预处理表达式? 105

10.13 sizeof操作符可以用在#if预处理指令中吗? 106

10.14 我可以像这样在#define行里使用#ifdef来定义两个不同的东西吗? 106

10.15 对typedef的类型定义有没有类似#ifdef的东西? 106

10.16 我如何用#if表达式来判断机器是高字节在前还是低字节在前? 107

10.17 为什么在我用#ifdef关掉的代码行中报出了奇怪的语法错误? 107

10.18 我拿到了一些代码,里边有太多的#ifdef。我不想使用预处理器把所有的#include 和#ifdef都扩展开,有什么办法只保留一种条件的代码呢? 107 

10.19 如何列出所有的预定义宏? 107

奇异的处理 108

10.20 我有些旧代码,试图用这样的宏来构造标识符:#define Paste(a, b) a/**/b 但是现在不行了。为什么? 108 

10.21 我有一个旧宏:#define CTRL(c) ('c' & 037)现在不能用了。为什么? 108

10.22 为什么宏#define TRACE(n) printf("TRACE: \%d\n", n) 报出警告“macro replacement within a string literal ”?它似乎把TRACE(count);扩展成了printf("TRACE: \%d\count", count); 109 

10.23 如何在宏扩展的字符串字面量中使用宏参数? 109

10.24 我想用ANSI 的“字符串化”预处理操作符#将符号常量的值放入消息中,但它总是对宏名称而不是它的值进行字符串化。这是什么原因? 109 

10.25 我想用预处理器做某件事情,但却不知道如何下手。 110

可变参数列表的宏 110

10.26 怎样写可变参数宏?如何用预处理器“关掉”具有可变参数的函数调用? 110

10.27 如何在通用的调试宏中包含__FILE__和__LINE__宏? 111

第11章 ANSI/ISO标准C 113

标准 113

11.1 什么是“ANSI C标准”? 113

11.2 如何得到一份标准的副本? 114

*11.3 我在哪里可以找到标准的更新? 115

函数原型  115

11.4 为什么我的ANSI编译器对用float声明的参数会警告类型不匹配? 115

11.5 能否混用旧式的和新型的函数语法? 116

*11.6 为什么下述声明报出了一个奇怪的警告信息“Struct X declared inside parameter list”? extern int f(struct x *p); 116 

11.7 有个问题一直困扰着我,它是由这一行printf ("%d", n); 导致的,因为n是个long int型。难道 ANSI 的函数原型不能检查这种函数的参数不匹配问题吗? 116 

11.8 我听说必须在调用printf之前包含stdio.h。为什么? 117

const 限定词 117

11.9 为什么不能在初始化和数组维度中使用const值?例如const int n = 5; int a[n]; 117

11.10 “const char *p”、“char const *p ”和“char * const p ”有何区别? 117

11.11 为什么不能向接受const char ** 的函数传入char **? 118

11.12 我这样声明:typedef char * charp; const charp p; 为什么是p而不是它所指向的字符为const?  118 

main()函数的使用 119 

11.13 能否通过将main声明为void来关掉“main没有返回值”的警告? 119

11.14 main()的第3个参数envp是怎么回事?  120

11.15 我觉得把main()声明为void也不会失败,因为我调用了exit()而不是return,况且我的操作系统也忽略了程序的退出/返回状态。 120

*11.16 那么到底会出什么问题?真的有什么系统不支持void main()吗? 120

11.17 为什么以前流行的那些C 语言书总是使用void main()?  120

11.18 在main()中调用exit(status)和返回同样的status真的等价吗? 121

预处理功能 121

11.19 我试图用ANSI“字符串化”预处理操作符'#'向信息中插入符号常量的值,但它字符串化的总是宏的名字而不是它的值。为什么? 121 

11.20 警告信息“warning: macro replacement within a string literal”是什么意思? 121

11.21 为什么在我用#ifdef去掉的代码里出现了奇怪的语法错误? 122

11.22 #pragma是什么,有什么用? 122

11.23 “#pragma once”什么意思?我在一些头文件中看到了它。 122

其他的ANSI C 问题 123

11.24 char a[3] = "abc";合法吗?它是什么意思? 123

11.25 既然对数组的引用会退化为指针,那么,如果array是数组,array和&array之间有什么区别呢? 123

11.26 为什么我不能对void *指针进行算术运算? 123

11.27 memcpy()和memmove() 有什么区别? 124

11.28 malloc(0)有什么用?返回一个空指针还是指向0字节的指针? 124

11.29 为什么ANSI 标准规定了外部标识符的长度和大小写限制? 125

11.30 noalias是怎么回事?在它身上发生了什么? 125

老的或非标准的编译器 125

11.31 为什么我的编译器对最简单的测试程序都报出了一大堆的语法错误?对这段代码的第一行就报错了:main(int argc. char **argv) { return0; } 125 

11.32 为什么有些 ASNI/ISO 标准库函数未定义?我明明使用的就是ANSI 编译器。 126

11.33 谁有可以在旧的C 程序和ANSI C 之间相互转换的工具,或者自动生成原型的工具? 127

11.34 为什么声称兼容ANSI 的编译器不能编译这些代码?我知道这些代码是 ANSI 的,因为gcc 可以编译。 127 

兼容性 127 

11.35 人们好像有些在意实现定义的(implementation-defined)、不确定的(unspecified)和未定义的(undefined) 行为的区别。它们的区别到底在哪里? 128 

*11.36 一个程序“合法(legal)”、“有效(valid)”或“符合标准的”(conforming )到底是什么意思? 128 

11.37 我很吃惊,ANSI 标准竟然有那么多未定义的东西。标准的唯一任务不就是让这些东西标准化吗? 129

11.38 有人说i=i++的行为是未定义的,但是我刚在一个兼容ANSI 的编译器上测试,得到了我希望的结果。它真的是未定义的吗? 129 

第12章 标准输入输出库 130

基本输入输出 130

12.1 这样的代码有什么问题?char c; while((c = getchar()) != EOF) 130

12.2 我有个读取直到EOF的简单程序,但是我如何才能在键盘上输入那个“\EOF”呢?我看stdio.h 中定义的EOF 是-1,是不是说我该输入-1?  131 

12.3 为什么这些代码把最后一行复制了两遍?while(!feof(infp)){fgets(buf, MAXLINE, infp); fputs(buf, outfp);} 131 

12.4 我用fgets将文件的每行内容读入指针数组。为什么结果所有的行都是最后一行的内容呢? 132

12.5 我的程序的屏幕提示和中间输出有时没有在屏幕上显示,尤其是当我用管道通过另一个程序输出的时候。为什么? 132 

12.6 我怎样才能不等待回车键而一次输入一个字符? 132

printf格式 132

12.7 如何在printf 的格式串中输出一个'%'字符?我试过\%,但是不行。 132

12.8 为什么这么写不对?long int n = 123456; printf("%d\n", n); 133

12.9 有人告诉我不能在printf 中使用%lf。为什么printf() 用%f输出double 型,而scanf 却用%lf 呢? 133 

*12.10 对于size_t 那样的类型定义,当我不知道它到底是long 还是其他类型的时候,我应该使用什么样的printf格式呢? 134 

12.11 如何用printf 实现可变的域宽度?就是说,我想在运行时确定宽度而不是使用%8d? 134

12.12 如何输出在千位上用逗号隔开的数字?货币格式的数字呢? 135

12.13 为什么scanf("%d", i) 调用不行? 136

*12.14 为什么char s[30]; scamf("%s", s); 不用&也可以?我原以为传给scanf的每个变量都要带&。 136

12.15 为什么这些代码不行?double d; scanf("%f", &d); 136

12.16 为什么这段代码不行?short int s; scanf("%d", &s); 136

12.17 怎样在scanf 格式串中指定可变的宽度?  136

12.18 怎样从特定格式的数据文件中读取数据?怎样读入10个float 而不用使用包含10次%f的奇怪格式?如何将一行的任意多个域读入一个数组中? 137

scanf问题 138

12.19 我像这样用"%d\n"调用scanf 从键盘读取数字:int n; scanf("%d\n",&n); printf("you typed %d\ n", n);好像要多输入一行才返回。为什么? 138 

12.20 我用scanf 和%d读取一个数字,然后再用gets() 读取字符串,但是编译器好像跳过了gets() 调用!  139

12.21 我发现如果坚持检查返回值以确保用户输入的是我期待的数值,则scanf 的使用会安全很多。但有的时候好像会陷入无限循环。为什么? 139 

12.22 为什么大家都说不要使用scanf?那我该用什么来代替呢? 140

其他stdio 函数 141

12.23 我怎样才知道对于任意的sprintf 调用需要多大的目标缓冲区?怎样才能避免sprintf 目标缓冲区溢出? 141 

12.24 sprintf的返回值是什么?是int 还是char *? 142

12.25 为什么大家都说不要使用gets?  142

12.26 我觉得我应该在一长串的printf 调用之后检查errno ,以确定是否有失败的调用。为什么当我将输出重定向到文件的时候会输出奇怪的“printf failed: Not a typewriter ”信息? 142 

12.27 fgetops/fsetops和ftell/fseek之间有什么区别?fgetops和fsetops 到底有什么用处? 143

12.28 如何清除用户的多余输入,以防止在下一个提示符下读入?用fflush(stdin) 可以吗? 143 

打开和操作文件 144

12.29 我写了一个函数用来打开文件:myfopen(char *filename, FILE *fp){fp = fopen(filename, "r");}可我这样调用的时候:FILE *infp; myfopen("filename.dat", infp);,infp 指针并

没有正确设置。为什么? 144 

12.30 连一个最简单的fopen调用都不成功!这个调用有什么问题?FILE *fp = fopen(filename, 'r'); 145 

12.31 为什么我不能用完整路径名打开一个文件?这个调用总是失败:fopen("c:\newdir\ file. dat", "r"); 145 

12.32 我想用fopen模式"r+"打开一个文件,读出一个字符串,修改之后再写入,从而就地更新一个文件。可是这样不行。为什么? 145 

12.33 如何在文件中间插入或删除一行(一条记录)? 145

12.34 怎样从打开的流中恢复文件名? 145

重定向stdin 和stdout  146

12.35 怎样在程序里把stdin或stdout重定向到文件? 146

12.36 一旦使用freopen之后,怎样才能恢复原来的stdout (或stdin)? 146

12.37 如何判断标准输入或输出是否经过了重定向,即是否在命令行上使用了“”或“”? 147

12.38 我想写个像"more"那样的程序。怎样才能在stdin 被重定向之后再回到交互键盘? 147

*12.39 怎样同时向两个地方输出,如同时输出到屏幕和文件? 147

“二进制”输入输出 148

12.40 我希望按字节在内存和文件之间直接读写数字,而不像fprintf和fscanf进行格式化。我该怎么办? 148

12.41 怎样正确地读取二进制文件?有时看到0x0a和0x0d容易混淆,而且如果数据中包含0x1a的话,我好像会提前遇到EOF。 148 

12.42 我在写一个二进制文件的“过滤器”,但是stdin和stdout却被作为文本流打开了。怎样才能把它们的模式改为二进制? 148 

12.43 文本和二进制输入输出有什么区别? 149

12.44 如何在数据文件中读写结构? 149

12.45 怎样编写符合旧的二进制数据格式的代码? 149

第13章 库函数 151

字符串函数 151

13.1 怎样把数字转为字符串(与atoi相反)?有itoa函数吗? 151

13.2 为什么strncpy不能总在目标串放上终止符'\0'? 152

13.3 C 语言有类似于其他语言中的“substr ”(取出子串)的例程吗? 152

13.4 怎样把一个字符串中所有字符转换成大写或小写? 153

13.5 为什么有些版本的toupper对大写字符会有奇怪的反应?为什么有的代码在调用toupper 前先调用islower? 153

13.6 怎样将字符串分割成用空白分隔的字段?怎样实现类似main 处理argc和argv的过程? 153

13.7 哪里可以找到处理正则表达式或通配符匹配的代码? 155

排序 156

13.8 我想用strcmp作为比较函数,调用qsort对一个字符串数组排序,但是不行。为什么? 156

13.9 我想用qsort()对一个结构数组排序。我的比较函数接受结构指针,但是编译器认为这个函数不是qsort需要的类型。我要怎样转换这个函数指针才能避免这样的警告? 156 

13.10 怎样对一个链表排序? 158

13.11 怎样对大于内存容量的数据排序? 158

日期和时间 159

13.12 怎样在C 程序中取得当前日期或时间? 159

13.13 我知道库函数localtime可以把time_t转换成结构struct tm,而ctime可以把time_t转换成为可打印的字符串。怎样才能进行反向操作,把struct tm或一个字符串转换成time_t?  159 

13.14 怎样在日期上加n天?怎样取得两个日期的时间间隔? 160

随机数 162

13.15 怎么生成一个随机数? 162

13.16 怎样获得某一范围内的随机整数? 163

13.17 每次执行程序,rand都返回相同的数字序列。为什么? 164

13.18 我需要随机的真/假值,所以我就直接用rand()%2,可是我得到交替的0, 1, 0, 1, 0 …。为什么? 164

13.19 如何获取根本不重复的随机数? 165

13.20 怎样产生正态分布或高斯分布的随机数?  165

13.21 我在移植一个程序,里边调用了一个函数drand48 ,而我的库又没有这个。这是个什么函数? 167

其他库函数 168

13.22 exit(status)是否真的跟从main 函数返回status 等价? 168

13.23 memcpy和memmove 有什么区别? 168

13.24 我想移植这个旧程序。为什么报出这些“undefined external”错误:index? 、rindex?、bcopy?、bcmp?、bzero??  168 

13.25 我不断得到库函数未定义错误,但是我已经包含了所有用到的头文件了。 168

13.26 虽然我在连接时明确地指定了正确的函数库,我还是得到库函数未定义错误。 168

13.27 一个最简单的程序,不过在一个窗口里打印出“Hello,World”,为什么会编译出巨大的可执行代码(数百K)?我该少包含一些头文件吗? 169 

13.28 连接器报告_end未定义代表什么意思? 169

*13.29 我的编译器提示printf未定义!这怎么可能? 169

第14章 浮点运算 170

14.1 一个float变量赋值为3.1时,为什么printf输出的值为3.0999999? 170

14.2 我想计算一些平方根,我把程序简化成这样:main(){printf ("%f\h", sqrt(144.)); 可得到的结果却是疯狂的数字。为什么? 170

14.3 我想做一些简单的三角函数运算,也包含了math.h ,但连接器总是提示sin、cos这样的函数未定义。为什么? 171 

14.4 我的浮点数计算程序表现得很奇怪,在不同的机器上给出了不同的结果。为什么? 171

14.5 有什么好的方法来检查浮点数在“足够接近”情况下的相等? 171

14.6 怎样取整? 172

14.7 为什么C语言不提供乘幂的操作符? 173

14.8 为什么我机器上的math.h没有预定义常量M_PI? 173

14.9 怎样将变量置为IEEE NaN(“Not a Number”)或检测变量是否为NaN及其他特殊值? 173

14.10 如何简洁地处理浮点异常? 174

14.11 在C语言中如何很好地实现复数? 174

14.12 我要寻找一些实现以下功能的程序源代码:快速傅立叶变换(FFT)、矩阵算术(乘法、求逆等函数)、复数算术。 175 

14.13 Turbo C的程序崩溃,显示错误为“floating point formats not linked”(浮点格式未连接)。我还缺点儿什么呢? 175 

第15章 可变参数列表 176

调用变参函数 176

15.1 为什么调用printf前必须要包含stdio.h?  176

15.2 为什么%f可以在printf参数中同时表示float和double?它们难道不是不同类型吗? 177

15.3 我遇到了一个令人十分受挫的问题,后来发现是这行代码造成的:printf("%d", n);原来n 是longint型。难道ANSI的函数原型不就是用来防止这类的参数类型不匹配吗? 177 

15.4 怎样写一个接受可变参数的函数?  177

15.5 怎样写一个函数,像printf那样接受一个格式串和可变参数,然后再把参数传给printf去完成大部分工作? 180

15.6 怎样写类似scanf的函数,再把参数传给scanf去完成大部分工作? 180

15.7 我用的是ANSI前的编译器,没有stdarg.h文件。我该怎么办? 181

提取可变参数 182

15.8 怎样知道实际上有多少个参数传入函数? 182

15.9 为什么编译器不允许我定义一个没有固定参数项的可变参数函数? 182

15.10 我有个接受float型的变参函数,为什么va_arg(argp, float)却不行? 183

15.11 为什么va_arg不能得到类型为函数指针的参数? 183

困难的问题 184

15.12 怎样实现一个可变参数函数,它把参数再传给另一个可变参数函数? 184

15.13 怎样调用一个在运行时才构建参数列表的函数? 186

第16 章 奇怪的问题 187

16.1 为什么这个循环只执行了一次?for(i=start;i end ; i ++);{printf("%d\n",i);} 187

*16.2 遇到不可理解的不合理语法错误,似乎大段的程序没有编译。 187

*16.3 为什么过程调用不起作用?编译器似乎直接跳过去了。 187

16.4 程序在执行之前就崩溃了!(用调试器单步跟踪,在main函数的第一个语句之前就死了。)为什么? 188 

16.5 程序执行正确,但退出时在main函数的最后一个语句之后崩溃了。为什么会这样? 188

16.6 程序在一台机器上运行完美,但在另一台上却得到怪异的结果。更奇怪的是,增加或去除调试的打印语句,就改变了症状…… 188 

16.7 为什么下面的代码会崩溃?char *p = "hello, world!"; p[0] = 'H'; 189

16.8 我有些代码是用来解析外部结构的,但它却崩溃了,报了“unaligned access ”(未对齐的访问)错误。这是什么意思? 190

16.9 “Segmentation violation”、“Bus error”和“General protection fault”是什么意思? 191

第17章 风格  192

17.1 什么是C最好的代码布局风格? 192

17.2 如何在源文件中合理分配函数? 193

17.3 用if(!strcmp(s1, s2))比较两个字符串是否相等是个好风格吗? 193

17.4 为什么有的人用if(0== x)而不是if(x== 0)? 193

17.5 为什么有些代码在每次调用printf 前增加了类型转换(void)? 194

17.6 既然NULL和0都是空指针常量,我到底该用哪一个? 194

17.7 是该用TRUE和FALSE这样的符号名称还是直接用1和0来作布尔常量? 194

17.8 什么是“匈牙利表示法”(Hungarian Notation )?是否值得一试? 194

17.9 哪里可以找到“Indian Hill Style Guide ”及其他编码标准? 194

17.10 有人说goto是邪恶的,永远都不该用它。这是否太极端了? 195

17.11 人们总是说良好的风格很重要,但当他们使用良好的风格写出清晰易读的程序后,又发现程序的效率似乎降低了。既然效率那么重要,是否可以为了效率牺牲一些风格和可读性呢? 196

第18章 工具和资源 197

18.1 能否列一个常用工具列表? 197

18.2 怎样捕获棘手的malloc问题? 198

18.3 有什么免费或便宜的编译器可以使用? 198

lint 198

18.4 刚刚输入完一个程序,但它表现得很奇怪。你能发现有什么错误的地方吗? 199

18.5 如何关掉lint对每个malloc调用报出的“warning: possible pointer alignment problem”警告消息? 199 

18.6 哪里可以找到兼容ANSI的lint? 199

18.7 难道ANSI函数原型说明没有使lint过时吗? 199

资源 200

18.8 网上有哪些C语言的教程或其他资源? 200

*18.9 哪里可以找到好的源代码实例,以供研究和学习? 201

18.10 有什么好的学习C语言的书?有哪些高级的书和参考? 201

18.11 哪里能找到K&R的练习答案? 201

18.12 哪里能找到Numerical Recipes in C 、Plauger的The Standard C Library或Kernighan和Pike的The UNIX Programming Enviroment等书里的源码? 201 

18.13 哪里可以找到标准C函数库的源代码? 202

18.14 是否有一个在线的C参考指南? 202

18.15 我需要分析和评估表达式的代码。从哪里可以找到? 202

18.16 哪里可以找到C的BNF或YACC语法?  202

*18.17 谁有C编译器的测试套件? 203

*18.18 哪里有一些有用的源代码片段和例子的收集? 203

*18.19 我需要执行多精度算术的代码。 203

18.20 在哪里和怎样取得这些可自由发布的程序? 203

第19章 系统依赖 205

键盘和屏幕I/O 205

19.1 怎样从键盘直接读入字符而不用等回车键?怎样防止字符输入时的回显? 205

19.2 怎样知道有未读的字符(如果有,有多少)?另外,如何在没有字符的时候不阻塞读入? 209

19.3 怎样显示一个在原地更新自己的百分比或“旋转棒”的进度指示器? 209

19.4 怎样清屏?怎样反色输出?怎样把光标移动到指定的x, y位置? 210

19.5 怎样读入方向键、功能键? 210

其他I/O 211

19.6 怎样读入鼠标输入? 211

19.7 怎样做串口(“comm”)的输入输出? 211

19.8 怎样直接输出到打印机? 211

19.9 怎样发送转义字符序列控制终端或其他设备? 211

19.10 怎样做图形? 212

*19.11 怎样显示GIF和JPEG图像? 212

文件和目录 212

19.12 怎样检验一个文件是否存在?如果请求的输入文件不存在,我希望向用户提出警告。 212

19.13 怎样在读入文件前,知道文件大小? 213

*19.14 怎样得到文件的修改日期和时间? 213

19.15 怎样原地缩短一个文件而不用清除或重写? 213

19.16 怎样在文件中插入或删除一行(或一条记录)? 214

19.17 怎样从一个打开的流或文件描述符得到文件名? 214

19.18 怎样删除一个文件? 214

*19.19 怎样复制文件? 215

19.20 为什么用了详尽的路径还不能打开文件?下面的代码会返回错误。Fopen("c:\newdir\file.dat", "r") 215 

*19.21 fopen不让我打开文件"$HOME/.profile"和"~~/.myrcfile"。 215

*19.22 怎样制止MS-DOS下令人恐怖的“Abort,Retry,Ignore? ”信息? 215

19.23 遇到“Too many open files(打开文件太多)”的错误,怎样增加同时打开文件的允许数目? 215

19.24 如何得到磁盘的可用空间大小? 216

19.25 怎样在C语言中读入目录? 216

19.26 如何创建目录?如何删除目录(及其内容)? 217

访问原始内存 217

19.27 怎样找出系统还有多少内存可用? 217

19.28 怎样分配大于64K的数组或结构? 217

19.29 错误信息“DGROUP data allocation exceeds 64K(DGROUP 数据分配内存超过64K)”什么意思?我应该怎么做?我以为使用了大内存模型,就可以使用大于64K的数据! 217 

19.30 怎样访问位于某特定地址的内存(内存映射的设备或图形显示内存)? 218

19.31 如何访问机器地址0处的中断向量?如果将指针设为0,编译器可能把它转成一个非零的内部空指针值。 218

“系统”命令 219

19.32 怎样在一个C程序中调用另一个程序(独立可执行的程序或系统命令)? 219

19.33 如果运行时才知道要执行的命令的参数(文件名等),应该如何调用system? 219

19.34 在MS-DOS上如何得到system返回的准确错误状态? 220

19.35 怎样调用另一个程序或命令,然后获取它的输出? 220

进程环境  220

19.36 怎样才能发现程序自己的执行文件的全路径? 220

19.37 怎样找出和执行文件在同一目录的配置文件? 221

19.38 进程如何改变它的调用者的环境变量? 221

19.39 如何打开命令行给出的文件并解析选项?  221

19.40 exit(status)是否真的和从main函数返回同样的status等价? 221

19.41 怎样读入一个对象文件并跳跃到其中的函数? 221

其他系统相关的操作 222

19.42 怎样以小于1秒的精度延时或计算用户响应时间? 222

19.43 怎样捕获或忽略control-C这样的键盘中断? 222

19.44 怎样简洁地处理浮点异常? 223

19.45 怎样使用socket?如何联网?如何写客户/服务器程序? 223

*19.46 怎样调用BIOS函数?如何写ISR?如何创建TSR?  224

*19.47 什么是“near”和“far”指针? 224

回顾 224

19.48 我不能使用这些非标准、依赖系统的函数,程序需要兼容ANSI! 224

19.49 为什么这些内容没有在C语言中进行标准化?任何现实程序都会用到这些东西。 224

第20章 杂项 226

20.1 怎样从函数返回多个值? 226

20.2 用什么数据结构存储文本行最好?我开始用固定大小的char型数组的数组,但是有很多局限。 227

20.3 怎样打开命令行提到的文件并处理参数? 229

20.4 如何正确地使用errno? 231

20.5 怎样写数据文件,使之可以在不同字大小、字节顺序或浮点格式的机器上读入? 232

20.6 怎样用char *指针指向的函数名调用函数? 232

位和字节  233

20.7 如何操作各个位? 233 

20.8 怎样实现位数组或集合? 234 

20.9 怎样判断机器的字节顺序是高字节在前还是低字节在前? 235 

*20.10 怎样调换字节? 236 

20.11 怎样将整数转换到二进制或十六进制? 237 

20.12 可以使用二进制常数(类似0b101010这样的东西)吗?printf有二进制的格式说明符吗? 237 

效率 238

20.13 用什么方法计算整数中为1的位的个数最高效? 238

20.14 怎样提高程序的效率? 238 

20.15 指针真的比数组快吗?函数调用会拖慢程序多少?++i比i=i+1快吗? 240

20.16 用移位操作符替换乘法和除法是否有价值? 240

*20.17 人们说编译器优化得很好,我们不再需要为速度而写汇编了,但我的编译器连用移位代替i/=2都做不到。 240

*20.18 怎样不用临时变量而交换两个值? 241

switch 语句 241

20.19 switch语句和if/else链哪个更高效? 241

20.20 是否有根据字符串进行条件切换的方法? 241

20.21 是否有使用非常量case行标的方法(如范围或任意的表达式)? 242

各种语言功能 243

20.22 return语句外层的括号是否真的可选择?  243

20.23 为什么C语言的注释不能嵌套?怎样注释掉含有注释的代码?引号包含的字符串内的注释是否合法? 243 

20.24 为什么C语言的操作符不设计得更全面一些?好像还缺了一些^^、&&=和-=这样的操作符。 244

*20.25 C语言有循环移位操作符吗? 244

*20.26 C是个伟大的语言还是别的什么东西?哪个其他语言可以写出像a+++++b这样的代码? 244

20.27 如果赋值操作符是:=,是不是就不容易意外地写出if(a=b)了? 245

20.28 C语言有和Pascal 的with等价的语句吗? 245

20.29 为什么C语言没有嵌套函数? 245

*20.30 assert是什么?如何使用? 246

其他语言  246

20.31 怎样从C中调用FORTRAN(C++、BASIC、Pascal、Ada、LISP)的函数?反之如何? 246

20.32 有什么程序可以将Pascal或FORTRAN(或LISP、Ada、awk、“老”C)程序转化为C程序? 246

20.33 C++是C的超集吗?可以用C++编译器来编译C代码吗? 247

20.34 我需要用到“近似”的strcmp例程,比较两个字符串的近似度,并不需要完全一样。有什么好办法? 247

20.35 什么是散列法? 248

20.36 如何生成正态或高斯分布的随机数? 248

20.37 如何知道某个日期是星期几? 249

20.38 (year % 4== 0)是否足以判断闰年?2000年是闰年吗? 250

20.39 为什么tm结构中的tm_sec的范围是0到61,暗示一分钟有62秒? 250

琐事 250

20.40 一个难题:怎样写一个输出自己源代码的程序? 250

20.41 什么是“达夫设备”(Duff’s Device)?  251

20.42 下届国际C语言混乱代码竞赛(International Obfuscated C Code Contest,IOCCC)什么时候进行?哪里可以找到当前和以前的获胜代码? 251 

20.43 K&R1提到的关键字entry是什么? 252

20.44 C的名字从何而来? 252

20.45 “char”如何发音? 252

*20.46 “lvalue”和“rvalue”代表什么意思? 252

20.47 哪里可以获得本书的在线版? 252

术语表 253

参考文献 261~

……

%f 与 %lf的区别

wss71104307

12-21

4441

%f是单精度浮点型,输出的时候要满足6位小数。

%lf就是输出数值总长度为L,整数个数加小数个数,不足补空,右顶格起

%f和%lf对scanf来说有差别,%f用于float,%lf用于double

在printf中,%f用于float和double,因为float会自动转为double,另外,%lf对于printf在C89标准中无

定义...

18 条评论

您还未登录,请先

登录

后发表或查看评论

你必须知道的495个C语言问题

05-08

第1章 声明和初始化

基本类型

1.1 我该如何决定使用哪种整数类型?

1.2 为什么不精确定义标准类型的大小?

1.3 因为C语言没有精确定义类型的大小,所以我一般都用typedef定义int16和int32。然后根据实际的机器环境把它们定义为int、short、long等类型。这样看来,所有的问题都解决了,是吗?

1.4 新的64位机上的64位类型是什么样的?

指针声明

1.5 这样的声明有什么问题?char*p1,p2;我在使用p2的时候报错了。

1.6 我想声明一个指针,并为它分配一些空间,但却不行。这样的代码有什么问题?char*p;*p=malloc(10);

声明风格

1.7 怎样声明和定义全局变量和函数最好?

1.8 如何在C中实现不透明(抽象)数据类型?

1.9 如何生成“半全局变量”,就是那种只能被部分源文件中的部分函数访问的变量?

存储类型

1.10 同一个静态(static)函数或变量的所有声明都必需包含static存储类型吗?

1.11 extern在函数声明中是什么意思?

1.12 关键字auto到底有什么用途?

类型定义(typedef)

1.13 对于用户定义类型,typedef和#define有什么区别?

1.14 我似乎不能成功定义一个链表。我试过typedefstruct{char*item;NODEPTRnext;}*NODEPTR;但是编译器报了错误信息。难道在C语言中结构不能包含指向自己的指针吗?

1.15 如何定义一对相互引用的结构?

1.16 Struct{ }x1;和typedefstruct{ }x2;这两个声明有什么区别?

1.17 “typedefint(*funcptr)();”是什么意思?

const限定词

1.18 我有这样一组声明:typedefchar*charp;constcharpp;为什么是p而不是它指向的字符为const?

1.19 为什么不能像下面这样在初始式和数组维度值中使用const值?constintn=5;inta[n];

1.20 constchar*p、charconst*p和char*constp有什么区别?

复杂的声明

1.21 怎样建立和理解非常复杂的声明?例如定义一个包含N个指向返回指向字符的指针的函数的指针的数组?

1.22 如何声明返回指向同类型函数的指针的函数?我在设计一个状态机,用函数表示每种状态,每个函数都会返回一个指向下一个状态的函数的指针。可我找不到任何方法来声明这样的函数——感觉我需要一个返回指针的函数,返回的指针指向的又是返回指针的函数……,如此往复,以至无穷。

数组大小

1.23 能否声明和传入数组大小一致的局部数组,或者由其他参数指定大小的参数数组?

1.24 我在一个文件中定义了一个extern数组,然后在另一个文件中使用,为什么sizeof取不到数组的大小?

声明问题

1.25 函数只定义了一次,调用了一次,但编译器提示非法重声明了。

*1.26 main的正确定义是什么?voidmain正确吗?

1.27 我的编译器总在报函数原型不匹配的错误,可我觉得没什么问题。这是为什么?

1.28 文件中的第一个声明就报出奇怪的语法错误,可我看没什么问题。这是为什么?

1.29 为什么我的编译器不允许我定义大数组,如doublearray[256][256]?

命名空间

1.30如何判断哪些标识符可以使用,哪些被保留了?

初始化

1.31 对于没有显式初始化的变量的初始值可以作怎样的假定?如果一个全局变量初始值为“零”,它可否作为空指针或浮点零?

1.32 下面的代码为什么不能编译?intf(){chara[]="Hello,world!";}

*1.33 下面的初始化有什么问题?编译器提示“invalidinitializers”或其他信息。char*p=malloc(10);

1.34 chara[]="stringliteral";和char*p="stringliteral";初始化有什么区别?当我向p[i]赋值的时候,我的程序崩溃了。

1.35 chara{[3]}="abc";是否合法?

1.36 我总算弄清楚函数指针的声明方法了,但怎样才能初始化呢?

1.37 能够初始化联合吗?

第2章 结构、联合和枚举

结构声明

2.1 structx1{ };和typedefstruct{ }x2;有什么不同?

2.2 这样的代码为什么不对?structx{ };xthestruct;

2.3 结构可以包含指向自己的指针吗?

2.4 在C语言中用什么方法实现抽象数据类型最好?

*2.5 在C语言中是否有模拟继承等面向对象程序设计特性的好方法?

2.6 为什么声明externf(structx*p);给我报了一个晦涩难懂的警告信息?

2.7 我遇到这样声明结构的代码:structname{intnamelen;charnamestr[1];};然后又使用一些内存分配技巧使namestr数组用起来好像有多个元素,namelen记录了元素个数。它是怎样工作的?这样是合法的和可移植的吗?

2.8 我听说结构可以赋给变量也可以对函数传入和传出。为什么K&R1却明确说明不能这样做?

2.9 为什么不能用内建的==和!=操作符比较结构?

2.10结构传递和返回是如何实现的?

2.11 如何向接受结构参数的函数传入常量值?怎样创建无名的中间的常量结构值?

2.12 怎样从/向数据文件读/写结构?

结构填充

2.13 为什么我的编译器在结构中留下了空洞?这导致空间浪费而且无法与外部数据文件进行“二进制”读写。能否关掉填充,或者控制结构域的对齐方式?

2.14 为什么sizeof返回的值大于结构大小的期望值,是不是尾部有填充?

2.15 如何确定域在结构中的字节偏移量?

2.16 怎样在运行时用名字访问结构中的域?

2.17 C语言中有和Pascal的with等价的语句吗?

2.18 既然数组名可以用作数组的基地址,为什么对结构不能这样?

2.19 程序运行正确,但退出时却“coredump”(核心转储)了,怎么回事?

联合

2.20 结构和联合有什么区别?

2.21 有办法初始化联合吗?

2.22 有没有一种自动方法来跟踪联合的哪个域在使用?

枚举

2.23 枚举和一组预处理的#define有什么不同?

2.24 枚举可移植吗?

2.25 有什么显示枚举值符号的容易方法吗?

位域

2.26 一些结构声明中的这些冒号和数字是什么意思?

2.27 为什么人们那么喜欢用显式的掩码和位操作而不直接声明位域?

第3章 表达式

求值顺序

3.1 为什么这样的代码不行?a[i]=i++;

3.2 使用我的编译器,下面的代码inti=7;printf("%d\n",i++*i++);打印出49。不管按什么顺序计算,难道不该是56吗?

3.3 对于代码inti=3;i=i++;不同编译器给出不同的i值,有的为3,有的为4,哪个是正确的?

*3.4 有这样一个巧妙的表达式:a^=b^=a^=b;它不需要临时变量就可以交换a和b的值。

3.5 可否用显式括号来强制执行我所需要的计算顺序并控制相关的副作用?就算括号不行,操作符优先级是否能够控制计算顺序呢?

3.6 可是&&和||操作符呢?我看到过类似while((c=getchar())!=EOF&&c!='\n')的代码……

3.7 是否可以安全地认为,一旦&&和||左边的表达式已经决定了整个表达式的结果,则右边的表达式不会被求值?

3.8 为什么表达式printf("%d%d",f1(),f2());先调用了f2?我觉得逗号表达式应该确保从左到右的求值顺序。

3.9 怎样才能理解复杂表达式并避免写出未定义的表达式?“序列点”是什么?

3.10在a[i]=i++;中,如果不关心a[]的哪一个分量会被写入,这段代码就没有问题,i也的确会增加1,对吗?

3.11 人们总是说i=i++的行为是未定义的。可我刚刚在一个ANSI编译器上尝试过,其结果正如我所期望的。

3.12 我不想学习那些复杂的规则,怎样才能避免这些未定义的求值顺序问题呢?

其他的表达式问题

*3.13 ++i和i++有什么区别?

3.14 如果我不使用表达式的值,那我应该用i++还是++i来做自增呢?

3.15 我要检查一个数是不是在另外两个数之间,为什么if(abc)不行?

3.16 为什么如下的代码不对?inta=1000,b=1000;longintc=a*b;

3.17 为什么下面的代码总是给出0?doubledegC,degF;degC=5.0/9*(degF-32);

3.18 需要根据条件把一个复杂的表达式赋给两个变量中的一个。可以用下面这样的代码吗?((condition)?a:b)=complicated_expression;

3.19 我有些代码包含这样的表达式。a?b=c:d有些编译器可以接受,有些却不能。为什么?

保护规则

3.20 “semanticsof‘’changeinANSIC”的警告是什么意思?

3.21 “无符号保护”和“值保护”规则的区别在哪里?

第4章 指针

基本的指针应用

4.1 指针到底有什么好处?

4.2 我想声明一个指针并为它分配一些空间,但却不行。这些代码有什么问题呢?char*p;*p=malloc(10);

4.3 *p++自增p还是p所指向的变量?

指针操作

4.4 我用指针操作int数组的时候遇到了麻烦。

4.5 我有一个char*型指针碰巧指向一些int型变量,我想跳过它们。为什么((int*)p)++;这样的代码不行?

4.6 为什么不能对void*指针进行算术操作?

4.7 我有些解析外部结构的代码,但是它却崩溃了,显示出了“unalignedaccess”(未对齐的访问)的信息。这是什么意思?

作为函数参数的指针

4.8 我有个函数,它应该接受并初始化一个指针:voidf(int*ip){staticintdummy=5;ip=&dummy;}但是当我如下调用时:int*ip;f(ip);调用者的指针没有任何变化。

4.9 能否用void**通用指针作为参数,使函数模拟按引用传递参数?

4.10 我有一个函数externintf(int*);,它接受指向int型的指针。我怎样用引用方式传入一个常数?调用f(&5);似乎不行。

4.11 C语言可以“按引用传参”吗?

其他指针问题

4.12 我看到了用指针调用函数的不同语法形式。到底怎么回事?

4.13 通用指针类型是什么?当我把函数指针赋向void*类型的时候,编译通不过。

4.14 怎样在整型和指针之间进行转换?能否暂时把整数放入指针变量中,或者相反?

*4.15 我怎样把一个int变量转换为char*型?我试了类型转换,但是不行。

第5章 空指针

空指针和空指针常量

5.1 臭名昭著的空指针到底是什么?

5.2 怎样在程序里获得一个空指针?

5.3 用缩写的指针比较“if(p)”检查空指针是否有效?如果空指针的内部表达不是0会怎样?

NULL宏

5.4 NULL是什么,它是怎么定义的?

5.5 在使用非零位模式作为空指针的内部表示的机器上,NULL是如何定义的?

5.6 如果NULL定义成#defineNULL((char*)0),不就可以向函数传入不加转换的NULL了吗?

5.7 我的编译器提供的头文件中定义的NULL为0L。为什么?

5.8 NULL可以合法地用作函数指针吗?

5.9 如果NULL和0作为空指针常量是等价的,那我到底该用哪一个呢?

5.10但是如果NULL的值改变了,比如在使用非零内部空指针的机器上,用NULL(而不是0)

不是更好吗?

5.11 我曾经使用过一个编译器,不使用NULL就不能编译。

5.12 我用预处理宏#defineNullptr(type)(type*)0帮助创建正确类型的空指针。

回顾 59

5.13 这有点奇怪:NULL可以确保是0,但空(null)指针却不一定?

5.14 为什么有那么多关于空指针的疑惑?为什么这些问题如此频繁地出现?

5.15 有没有什么简单点儿的办法理解所有这些与空指针有关的东西呢?

5.16 考虑到有关空指针的所有这些困惑,要求它们的内部表示都必须为0不是更简单吗?

5.17 说真的,真有机器用非零空指针吗,或者不同类型用不同的表示?

地址0上到底有什么?

5.18 运行时的整数值0转换为指针以后一定是空指针吗?

5.19 如何访问位于机器地址0处的中断向量?如果我将指针值设为0,编译器可能会自动将它转换为非零的空指针内部表示。

5.20运行时的“nullpointerassignment”错误是什么意思?应该怎样捕捉它?

第6章 数组和指针

数组和指针的基本关系

6.1 我在一个源文件中定义了chara[6],在另一个源文件中声明了externchar*a。为什么不行?

6.2 可是我听说chara[]和char*a是等价的。是这样的吗?

6.3 那么,在C语言中“指针和数组等价”到底是什么意思?

6.4 既然它们这么不同,那为什么作为函数形参的数组和指针声明可以互换呢?

数组不能被赋值

6.5 为什么不能这样向数组赋值?externchar*getpass();charstr[10];str=getpass("Enterpassword:");

6.6 既然不能向数组赋值,那这段代码为什么可以呢?intf(charstr[]){if(str[0]=='\0')str="none";…}

6.7 如果你不能给它赋值,那么数组如何能成为左值呢?

回顾

6.8 现实地讲,数组和指针的区别是什么?

6.9 有人跟我讲,数组不过是常指针。这样讲准确吗?

6.10 我还是很困惑。到底指针是一种数组,还是数组是一种指针?

6.11 我看到一些“搞笑”的代码,包含5["abcdef"]这样的“表达式”。这为什么是合法的C语言表达式呢?

数组的指针

6.12 既然数组引用会退化为指针,如果array是数组,那么array和&array又有什么区别呢?

6.13 如何声明一个数组的指针?

动态数组分配

6.14 如何在运行时设定数组的大小?怎样才能避免固定大小的数组?

6.15 我如何声明大小和传入的数组一样的局部数组?

6.16 如何动态分配多维数组?

6.17 有个很好的窍门,如果我这样写:intrealarray[10];int*array=&realarray[-1];我就可以把“array”当作下标从1 开始的数组。

函数和多维数组

6.18 当我向一个接受指针的指针的函数传入二维数组的时候,编译器报错了。

6.19 我怎样编写接受编译时宽度未知的二维数组的函数?

6.20 我怎样在函数参数传递时混用静态和动态多维数组?

数组的大小

6.21 当数组是函数的参数时,为什么sizeof不能正确报告数组的大小?

6.22 如何在一个文件中判断声明为extern的数组的大小(例如,数组定义和大小在另一个文件中)?sizeof操作符似乎不行。

6.23 sizeof返回的大小是以字节计算的,怎样才能判断数组中有多少个元素呢?

第7章 内存分配

基本的内存分配问题

7.1 为什么这段代码不行?char*answer;printf("Typesomething:\n");gets(answer);printf("Youtyped\"%s\"\n",answer);

7.2 我的strcat()不行。我试了下面的代码:char*s1="Hello,";char*s2="world!";char*s3=strcat(s1,s2);但是我得到了奇怪的结果。

7.3 但是strcat的文档说它接受两个char*型参数。我怎么知道(空间)分配的事情呢?

*7.4 我刚才试了这样的代码:char*p;strcpy(p,"abc");它运行正常。怎么回事?为什么它没有出错?

*7.5 一个指针变量分配多少内存?

7.6 我使用fgets将文件的所有行读入一个数组,为什么读入的每一行都是最后一行的内容呢?

7.7 我有个函数,本该返回一个字符串,但当它返回调用者的时候,返回的字符串却是垃圾信息。

为什么?

*7.8 那么返回字符串或其他聚集的正确方法是什么呢?

调用malloc

7.9 为什么在调用malloc()时报出了“waring:assignmentofpointerfromintegerlacksacast”?

7.10为什么有些代码小心翼翼地把malloc返回的值转换为分配的指针类型?

*7.11 在调用malloc()的时候,错误“不能把void*转换为int*”是什么意思?

7.12 我看到下面这样的代码:char*p=malloc(strlen(s)+1);strcpy(p,s);难道不应该是malloc((strlen(s)+1)*sizeof(char))吗?

7.13 我为malloc写了一个小小的封装函数。它为什么不行?

7.14 我想声明一个指针并向它分配一些内存,但是不行。这样的代码有什么问题?char*p;*p=malloc(10);

7.15 我如何动态分配数组?

7.16 怎样判断还有多少内存?

7.17 malloc(0)是返回空指针还是指向0个字节的指针?

7.18 我听说有的操作系统在程序使用的时候才真正分配malloc申请的内存。这合法吗?

有关malloc的问题

7.19 为什么malloc返回了离谱的指针值?我的确读过问题7.9,而且也在调用之前包含了externvoid*malloc();声明。

7.20 我用一行这样的代码分配一个巨大的数组,用于数值运算:double*array=malloc(256 *256 *sizeof(double));malloc()并没有返回空指针,但是程序运行得有些奇怪,好像改写了某些内存,或者malloc()并没有分配我申请的那么多内存。为什么?

7.21 我的PC机有8兆内存。为什么我只能分配640K左右的内存?

7.22 我的应用程序非常依赖数据结构的节点的动态分配,而malloc/free的代价成了瓶颈。我该怎么做?

7.23 我的程序总是崩溃,显然发生在malloc内部的某个地方。但是我看不出哪里有问题。是malloc有bug吗?

释放内存

7.24 动态分配的内存一旦释放之后就不能再使用,是吧?

7.25 为什么在调用free()之后指针没有变空?使用(赋值、比较)释放之后的指针有多么不安全?

7.26 当我调用malloc()为一个函数的局部指针分配内存时,我还需要用free()显式地释放吗?

7.27 我在分配一些结构,它们包含指向其他动态分配的对象的指针。我在释放结构的时候,还需要释放每一个下级指针吗?

7.28 我必须在程序退出之前释放分配的所有内存吗?

7.29 我有个程序分配了大量的内存,然后又释放了。但是从操作系统看,内存的占用率却并没有变回去。

分配内存块的大小

7.30 free()怎么知道有多少字节需要释放?

7.31 那么我能否查询malloc包,以查明可分配的最大块是多大?

7.32 为什么sizeof不能告诉我它所指的内存块的大小?

其他分配函数

7.33 (像问题6.14中那样)动态分配数组之后,还能改变它的大小吗?

7.34 向realloc()的第一个参数传入空指针合法吗?你为什么要这样做?

7.35 calloc()和malloc()有什么区别?应该用哪一个?利用calloc的零填充功能安全吗?free()可以释放calloc()分配的内存吗,还是需要一个cfree()?

7.36 alloca是什么?为什么不提倡使用它?

第8章 字符和字符串

8.1 为什么strcat(string,'!');不行?

8.2 我想检查一个字符串是否跟某个值匹配。为什么这样不行?if(string=="value")

8.3 如果我可以写chara[]="Hello,world!";那为什么不能写chara[14];a="Hello,world!";

8.4 为什么我的strcat不行?我试了char*s1="Hello,";char*s2="world!";char*s3 =strcat(s1,s2);可得到的结果很奇怪。

8.5 chara[]="stringliteral";和char*p="stringliteral";初始化有什么区别?当我对p[i]赋值的时候,程序崩溃了。

8.6 我怎么得到与字符相对应的数字(即ASCII或其他字符集下的)值?反过来又该怎么做?

8.7 C语言有类似其他语言的"substr"(提取子串)这样的函数吗?

8.8 我将用户键入的字符串读入数组,然后再显示出来。当用户键入\n这样的序列时,为什么不能正确处理呢?

8.9 我注意到sizeof('a')是2而不是1(即不是sizeof(char)),是不是我的编译器有问题?

8.10 我正开始考虑多语言字符集的问题。是否有必要担心sizeof(char)会被定义为2,以便表达16位的字符集呢?

第9章 布尔表达式和变量

9.1 C语言中布尔值该用什么类型?为什么它不是一个标准类型?我应该用#define或enum定义真值和假值吗?

9.2 既然在C语言中所有的非零值都被看作“真”,那是不是把TRUE定义为1很危险?如果某个内建的函数或关系操作符“返回”不是1的其他值怎么办?

9.3 当p是指针时,if(p)是合法的条件表达式吗?

9.4 我该使用像TRUE和FALSE这样的符号名称还是直接用1和0来作布尔常量?

9.5 我准备使用的一个第三方头文件定义了自己的TRUE和FALSE,它们跟我已经开发的部分不兼容。我该怎么办?

第10章 C预处理器

宏定义

10.1 我想定义一些函数式的宏,例如:#definesquare(x)x*x但它们并不总是正确的。为什么?

10.2 这里有一些的预处理宏,使用它们,我可以写出更像Pascal的C代码。你觉得怎么样?

10.3 怎么写一个交换两个值的通用宏?

10.4 书写多语句宏的最好方法是什么?

10.5 用typdef和预处理宏生成用户定义类型有什么区别?

头文件

10.6 我第一次把一个程序分成多个源文件,我不知道该把什么放到.c文件,把什么放到.h文件。(“.h”到底是什么意思?)

10.7 可以在一个头文件中包含另一头文件吗?

10.8 完整的头文件搜索规则是怎样的?

10.9 我在文件的第一个声明就遇到奇怪的语法错误,但是看上去没什么问题。

10.10 我使用了来自两个不同的第三方库的头文件,它们都定义了相同的宏,如TRUE、FALSE、Min()和Max()等,但是它们的定义相互冲突,而且跟我在自己的头文件中的定义也有冲突。我该怎么办?

10.11 我在编译一个程序,看起来我好像缺少需要的一个或多个头文件。谁能发给我一份?

条件编译

10.12 怎样构造比较字符串的#if预处理表达式?

10.13 sizeof操作符可以用在#if预处理指令中吗?

10.14 我可以像这样在#define行里使用#ifdef来定义两个不同的东西吗?

10.15 对typedef的类型定义有没有类似#ifdef的东西?

10.16 我如何用#if表达式来判断机器是高字节在前还是低字节在前?

10.17 为什么在我用#ifdef关掉的代码行中报出了奇怪的语法错误?

10.18 我拿到了一些代码,里边有太多的#ifdef。我不想使用预处理器把所有的#include和#ifdef都扩展开,有什么办法只保留一种条件的代码呢?

10.19 如何列出所有的预定义宏?

奇异的处理

10.20 我有些旧代码,试图用这样的宏来构造标识符:#definePaste(a,b)a/**/b但是不行了。为什么?

10.21 我有一个旧宏:#defineCTRL(c)('c'&037)不能用了。为什么?

10.22 为什么宏#defineTRACE(n)printf("TRACE:\%d\n",n)报出警告“macroreplacementwithinastringliteral”?它似乎把TRACE(count);扩展成了printf("TRACE:\%d\count",count);

10.23 如何在宏扩展的字符串字面量中使用宏参数?

10.24 我想用ANSI的“字符串化”预处理操作符#将符号常量的值放入消息中,但它总是对宏名称而不是它的值进行字符串化。这是什么原因?

10.25 我想用预处理器做某件事情,但却不知道如何下手。

可变参数列表的宏

10.26 怎样写可变参数宏?如何用预处理器“关掉”具有可变参数的函数调用?

10.27 如何在通用的调试宏中包含__FILE__和__LINE__宏?

第11章 ANSI/ISO标准C

标准

11.1 什么是“ANSIC标准”?

11.2 如何得到一份标准的副本?

*11.3 我在哪里可以找到标准的更新?

函数原型

11.4 为什么我的ANSI编译器对用float声明的参数会警告类型不匹配?

11.5 能否混用旧式的和新型的函数语法?

*11.6 为什么下述声明报出了一个奇怪的警告信息“StructXdeclaredinsideparameterlist”?externintf(structx*p);

11.7 有个问题一直困扰着我,它是由这一行printf("%d",n);导致的,因为n是个longint型。难道ANSI的函数原型不能检查这种函数的参数不匹配问题吗?

11.8 我听说必须在调用printf之前包含stdio.h。为什么?

const限定词

11.9 为什么不能在初始化和数组维度中使用const值?例如constintn=5;inta[n];

11.10“constchar*p”、“charconst*p”和“char*constp”有何区别?

11.11 为什么不能向接受constchar**的函数传入char**?

11.12 我这样声明:typedefchar*charp;constcharpp;为什么是p而不是它所指向的字符为const?

main()函数的使用

11.13 能否通过将main声明为void来关掉“main没有返回值”的警告?

11.14 main()的第3个参数envp是怎么回事?

11.15 我觉得把main()声明为void也不会失败,因为我调用了exit()而不是return,况且我的操作系统也忽略了程序的退出/返回状态。

*11.16 那么到底会出什么问题?真的有什么系统不支持voidmain()吗?

11.17 为什么以前流行的那些C语言书总是使用voidmain()?

11.18 在main()中调用exit(status)和返回同样的status真的等价吗?

预处理功能

11.19 我试图用ANSI“字符串化”预处理操作符'#'向信息中插入符号常量的值,但它字符串化的总是宏的名字而不是它的值。为什么?

11.20 警告信息“warning:macroreplacementwithinastringliteral”是什么意思?

11.21 为什么在我用#ifdef去掉的代码里出现了奇怪的语法错误?

11.22 #pragma是什么,有什么用?

11.23 “#pragmaonce”什么意思?我在一些头文件中看到了它。

其他的ANSIC问题

11.24 chara[3]="abc";合法吗?它是什么意思?

11.25 既然对数组的引用会退化为指针,那么,如果array是数组,array和&array之间有什么区别呢?

11.26 为什么我不能对void*指针进行算术运算?

11.27 memcpy()和memmove()有什么区别?

11.28 malloc(0)有什么用?返回一个空指针还是指向0字节的指针?

11.29 为什么ANSI标准规定了外部标识符的长度和大小写限制?

11.30 noalias是怎么回事?在它身上发生了什么?

老的或非标准的编译器

11.31 为什么我的编译器对最简单的测试程序都报出了一大堆的语法错误?对这段代码的第一行就报错了:main(intargc.char**argv){return0;}

11.32 为什么有些ASNI/ISO标准库函数未定义?我明明使用的就是ANSI编译器。

11.33 谁有可以在旧的C程序和ANSIC之间相互转换的工具,或者自动生成原型的工具?

11.34 为什么声称兼容ANSI的编译器不能编译这些代码?我知道这些代码是ANSI的,因为gcc可以编译。

兼容性

11.35 人们好像有些在意实现定义的(implementation-defined)、不确定的(unspecified)和未定义的(undefined)行为的区别。它们的区别到底在哪里?

*11.36 一个程序“合法(legal)”、“有效(valid)”或“符合标准的”(conforming)到底是什么意思?

11.37 我很吃惊,ANSI标准竟然有那么多未定义的东西。标准的唯一任务不就是让这些东西标准化吗?

11.38 有人说i=i++的行为是未定义的,但是我刚在一个兼容ANSI的编译器上测试,得到了我希望的结果。它真的是未定义的吗?

第12章 标准输入输出库

基本输入输出

12.1 这样的代码有什么问题?charc;while((c=getchar())!=EOF)

12.2 我有个读取直到EOF的简单程序,但是我如何才能在键盘上输入那个“\EOF”呢?我看stdio.h中定义的EOF是-1,是不是说我该输入-1?

12.3 为什么这些代码把最后一行复制了两遍?while(!feof(infp)){fgets(buf,MAXLINE,infp);fputs(buf,outfp);}

12.4 我用fgets将文件的每行内容读入指针数组。为什么结果所有的行都是最后一行的内容呢?

12.5 我的程序的屏幕提示和中间输出有时没有在屏幕上显示,尤其是当我用管道通过另一个程序输出的时候。为什么?

12.6 我怎样才能不等待回车键而一次输入一个字符?

printf格式

12.7 如何在printf的格式串中输出一个'%'字符?我试过\%,但是不行。

12.8 为什么这么写不对?longintn=123456;printf("%d\n",n);

12.9 有人告诉我不能在printf中使用%lf。为什么printf()用%f输出double型,而scanf却用%lf呢?

*12.10 对于size_t那样的类型定义,当我不知道它到底是long还是其他类型的时候,我应该使用什么样的printf格式呢?

12.11 如何用printf实现可变的域宽度?就是说,我想在运行时确定宽度而不是使用%8d?

12.12 如何输出在千位上用逗号隔开的数字?货币格式的数字呢?

12.13 为什么scanf("%d",i)调用不行?

*12.14 为什么chars[30];scamf("%s",s);不用&也可以?我原以为传给scanf的每个变量都要带&。

12.15 为什么这些代码不行?doubled;scanf("%f",&d);

12.16 为什么这段代码不行?shortints;scanf("%d",&s);

12.17 怎样在scanf格式串中指定可变的宽度?

12.18 怎样从特定格式的数据文件中读取数据?怎样读入10个float而不用使用包含10次%f的奇怪格式?如何将一行的任意多个域读入一个数组中?

scanf问题

12.19 我像这样用"%d\n"调用scanf从键盘读取数字:intn;scanf("%d\n",&n);printf("youtyped%d\n",n);好像要多输入一行才返回。为什么?

12.20 我用scanf和%d读取一个数字,然后再用gets()读取字符串,但是编译器好像跳过了gets()调用!

12.21 我发现如果坚持检查返回值以确保用户输入的是我期待的数值,则scanf的使用会安全很多。但有的时候好像会陷入无限循环。为什么?

12.22 为什么大家都说不要使用scanf?那我该用什么来代替呢?

其他stdio函数

12.23 我怎样才知道对于任意的sprintf调用需要多大的目标缓冲区?怎样才能避免sprintf目标缓冲区溢出?

12.24 sprintf的返回值是什么?是int还是char*?

12.25 为什么大家都说不要使用gets?

12.26 我觉得我应该在一长串的printf调用之后检查errno,以确定是否有失败的调用。为什么当我将输出重定向到文件的时候会输出奇怪的“printffailed:Notatypewriter”信息?

12.27 fgetops/fsetops和ftell/fseek之间有什么区别?fgetops和fsetops到底有什么用处?

12.28 如何清除用户的多余输入,以防止在下一个提示符下读入?用fflush(stdin)可以吗?

打开和操作文件

12.29 我写了一个函数用来打开文件:myfopen(char*filename,FILE*fp){fp=fopen(filename,"r");}可我这样调用的时候:FILE*infp;myfopen("filename.dat",infp);,infp指针并没有正确设置。为什么?

12.30 连一个最简单的fopen调用都不成功!这个调用有什么问题?FILE*fp=fopen(filename,'r');

12.31 为什么我不能用完整路径名打开一个文件?这个调用总是失败:fopen("c:\newdir\file.dat","r");

12.32 我想用fopen模式"r+"打开一个文件,读出一个字符串,修改之后再写入,从而就地更新一个文件。可是这样不行。为什么?

12.33 如何在文件中间插入或删除一行(一条记录)?

12.34 怎样从打开的流中恢复文件名?

重定向stdin和stdout

12.35 怎样在程序里把stdin或stdout重定向到文件?

12.36 一旦使用freopen之后,怎样才能恢复原来的stdout(或stdin)?

12.37 如何判断标准输入或输出是否经过了重定向,即是否在命令行上使用了“”或“”?

12.38 我想写个像"more"那样的程序。怎样才能在stdin被重定向之后再回到交互键盘?

*12.39 怎样同时向两个地方输出,如同时输出到屏幕和文件?

“二进制”输入输出

12.40 我希望按字节在内存和文件之间直接读写数字,而不像fprintf和fscanf进行格式化。我该怎么办?

12.41 怎样正确地读取二进制文件?有时看到0x0a和0x0d容易混淆,而且如果数据中包含0x1a的话,我好像会提前遇到EOF。

12.42 我在写一个二进制文件的“过滤器”,但是stdin和stdout却被作为文本流打开了。怎样才能把它们的模式改为二进制?

12.43 文本和二进制输入输出有什么区别?

12.44 如何在数据文件中读写结构?

12.45 怎样编写符合旧的二进制数据格式的代码?

第13章 库函数

字符串函数

13.1 怎样把数字转为字符串(与atoi相反)?有itoa函数吗?

13.2 为什么strncpy不能总在目标串放上终止符'\0'?

13.3 C语言有类似于其他语言中的“substr”(取出子串)的例程吗?

13.4 怎样把一个字符串中所有字符转换成大写或小写?

13.5 为什么有些版本的toupper对大写字符会有奇怪的反应?为什么有的代码在调用toupper前先调用islower?

13.6 怎样将字符串分割成用空白分隔的字段?怎样实现类似main处理argc和argv的过程?

13.7 哪里可以找到处理正则表达式或通配符匹配的代码?

排序

13.8 我想用strcmp作为比较函数,调用qsort对一个字符串数组排序,但是不行。为什么?

13.9 我想用qsort()对一个结构数组排序。我的比较函数接受结构指针,但是编译器认为这个函数不是qsort需要的类型。我要怎样转换这个函数指针才能避免这样的警告?

13.10 怎样对一个链表排序?

13.11 怎样对大于内存容量的数据排序?

日期和时间

13.12 怎样在C程序中取得当前日期或时间?

13.13 我知道库函数localtime可以把time_t转换成结构structtm,而ctime可以把time_t转换成为可打印的字符串。怎样才能进行反向操作,把structtm或一个字符串转换成time_t?

13.14 怎样在日期上加n天?怎样取得两个日期的时间间隔?

随机数

13.15 怎么生成一个随机数?

13.16 怎样获得某一范围内的随机整数?

13.17 每次执行程序,rand都返回相同的数字序列。为什么?

13.18 我需要随机的真/假值,所以我就直接用rand()%2,可是我得到交替的0,1,0,1,0…。为什么? 164

13.19 如何获取根本不重复的随机数?

13.20 怎样产生正态分布或高斯分布的随机数?

13.21 我在移植一个程序,里边调用了一个函数drand48 ,而我的库又没有这个。这是个什么函数?

其他库函数

13.22 exit(status)是否真的跟从main函数返回status等价?

13.23 memcpy和memmove有什么区别?

13.24 我想移植这个旧程序。为什么报出这些“undefinedexternal”错误:index?、rindex?、bcopy?、bcmp?、bzero??

13.25 我不断得到库函数未定义错误,但是我已经包含了所有用到的头文件了。

13.26 虽然我在连接时明确地指定了正确的函数库,我还是得到库函数未定义错误。

13.27 一个最简单的程序,不过在一个窗口里打印出“Hello,World”,为什么会编译出巨大的可执行代码(数百K)?我该少包含一些头文件吗?

13.28 连接器报告_end未定义代表什么意思?

*13.29 我的编译器提示printf未定义!这怎么可能?

第14章 浮点运算

14.1 一个float变量赋值为3.1时,为什么printf输出的值为3.0999999?

14.2 我想计算一些平方根,我把程序简化成这样:main(){printf("%f\h",sqrt(144.));可得到的结果却是疯狂的数字。为什么?

14.3 我想做一些简单的三角函数运算,也包含了math.h,但连接器总是提示sin、cos这样的函数未定义。为什么?

14.4 我的浮点数计算程序表现得很奇怪,在不同的机器上给出了不同的结果。为什么?

14.5 有什么好的方法来检查浮点数在“足够接近”情况下的相等?

14.6 怎样取整?

14.7 为什么C语言不提供乘幂的操作符?

14.8 为什么我机器上的math.h没有预定义常量M_PI?

14.9 怎样将变量置为IEEENaN(“NotaNumber”)或检测变量是否为NaN及其他特殊值?

14.10 如何简洁地处理浮点异常?

14.11 在C语言中如何很好地实现复数?

14.12 我要寻找一些实现以下功能的程序源代码:快速傅立叶变换(FFT)、矩阵算术(乘法、求逆等函数)、复数算术。

14.13 TurboC的程序崩溃,显示错误为“floatingpointformatsnotlinked”(浮点格式未连接)。我还缺点儿什么呢?

第15章 可变参数列表

调用变参函数

15.1 为什么调用printf前必须要包含stdio.h?

15.2 为什么%f可以在printf参数中同时表示float和double?它们难道不是不同类型吗?

15.3 我遇到了一个令人十分受挫的问题,后来发现是这行代码造成的:printf("%d",n);原来n是longint型。难道ANSI的函数原型不就是用来防止这类的参数类型不匹配吗?

15.4 怎样写一个接受可变参数的函数?

15.5 怎样写一个函数,像printf那样接受一个格式串和可变参数,然后再把参数传给printf去完成大部分工作?

15.6 怎样写类似scanf的函数,再把参数传给scanf去完成大部分工作?

15.7 我用的是ANSI前的编译器,没有stdarg.h文件。我该怎么办?

提取可变参数

15.8 怎样知道实际上有多少个参数传入函数?

15.9 为什么编译器不允许我定义一个没有固定参数项的可变参数函数?

15.10 我有个接受float型的变参函数,为什么va_arg(argp,float)却不行?

15.11 为什么va_arg不能得到类型为函数指针的参数?

困难的问题

15.12 怎样实现一个可变参数函数,它把参数再传给另一个可变参数函数?

15.13 怎样调用一个在运行时才构建参数列表的函数?

第16 章奇怪的问题

16.1 为什么这个循环只执行了一次?for(i=start;iend;i++);{printf("%d\n",i);}

*16.2 遇到不可理解的不合理语法错误,似乎大段的程序没有编译。

*16.3 为什么过程调用不起作用?编译器似乎直接跳过去了。

16.4 程序在执行之前就崩溃了!(用调试器单步跟踪,在main函数的第一个语句之前就死了。)为什么? 16.5 程序执行正确,但退出时在main函数的最后一个语句之后崩溃了。为什么会这样?

16.6 程序在一台机器上运行完美,但在另一台上却得到怪异的结果。更奇怪的是,增加或去除调试的打印语句,就改变了症状……

16.7 为什么下面的代码会崩溃?char*p="hello,world!";p[0]='H';

16.8 我有些代码是用来解析外部结构的,但它却崩溃了,报了“unalignedaccess”(未对齐的访问)错误。这是什么意思?

16.9 “Segmentationviolation”、“Buserror”和“Generalprotectionfault”是什么意思?

第17章 风格

17.1 什么是C最好的代码布局风格?

17.2 如何在源文件中合理分配函数?

17.3 用if(!strcmp(s1,s2))比较两个字符串是否相等是个好风格吗?

17.4 为什么有的人用if(0==x)而不是if(x==0)?

17.5 为什么有些代码在每次调用printf前增加了类型转换(void)?

17.6 既然NULL和0都是空指针常量,我到底该用哪一个?

17.7 是该用TRUE和FALSE这样的符号名称还是直接用1和0来作布尔常量?

17.8 什么是“匈牙利表示法”(HungarianNotation)?是否值得一试?

17.9 哪里可以找到“IndianHillStyleGuide”及其他编码标准?

17.10 有人说goto是邪恶的,永远都不该用它。这是否太极端了?

17.11 人们总是说良好的风格很重要,但当他们使用良好的风格写出清晰易读的程序后,又发现程序的效率似乎降低了。既然效率那么重要,是否可以为了效率牺牲一些风格和可读性呢?

第18章 工具和资源

18.1 能否列一个常用工具列表?

18.2 怎样捕获棘手的malloc问题?

18.3 有什么免费或便宜的编译器可以使用?

lint

18.4 刚刚输入完一个程序,但它表现得很奇怪。你能发现有什么错误的地方吗?

18.5 如何关掉lint对每个malloc调用报出的“warning:possiblepointeralignmentproblem”警告消息?

18.6 哪里可以找到兼容ANSI的lint?

18.7 难道ANSI函数原型说明没有使lint过时吗?

资源

18.8 网上有哪些C语言的教程或其他资源?

*18.9 哪里可以找到好的源代码实例,以供研究和学习?

18.10 有什么好的学习C语言的书?有哪些高级的书和参考?

18.11 哪里能找到K&R的练习答案?

18.12 哪里能找到NumericalRecipesinC、Plauger的TheStandardCLibrary或Kernighan和Pike的TheUNIXProgrammingEnviroment等书里的源码?

18.13 哪里可以找到标准C函数库的源代码?

18.14 是否有一个在线的C参考指南?

18.15 我需要分析和评估表达式的代码。从哪里可以找到?

18.16 哪里可以找到C的BNF或YACC语法?

*18.17 谁有C编译器的测试套件?

*18.18 哪里有一些有用的源代码片段和例子的收集?

*18.19 我需要执行多精度算术的代码。

18.20 在哪里和怎样取得这些可自由发布的程序?

第19章 系统依赖

键盘和屏幕I/O

19.1 怎样从键盘直接读入字符而不用等回车键?怎样防止字符输入时的回显?

19.2 怎样知道有未读的字符(如果有,有多少)?另外,如何在没有字符的时候不阻塞读入?

19.3 怎样显示一个在原地更新自己的百分比或“旋转棒”的进度指示器?

19.4 怎样清屏?怎样反色输出?怎样把光标移动到指定的x,y位置?

19.5 怎样读入方向键、功能键?

其他I/O

19.6 怎样读入鼠标输入?

19.7 怎样做串口(“comm”)的输入输出?

19.8 怎样直接输出到打印机?

19.9 怎样发送转义字符序列控制终端或其他设备?

19.10 怎样做图形?

*19.11 怎样显示GIF和JPEG图像?

文件和目录

19.12 怎样检验一个文件是否存在?如果请求的输入文件不存在,我希望向用户提出警告。

19.13 怎样在读入文件前,知道文件大小?

*19.14 怎样得到文件的修改日期和时间?

19.15 怎样原地缩短一个文件而不用清除或重写?

19.16 怎样在文件中插入或删除一行(或一条记录)?

19.17 怎样从一个打开的流或文件描述符得到文件名?

19.18 怎样删除一个文件?

*19.19 怎样复制文件?

19.20 为什么用了详尽的路径还不能打开文件?下面的代码会返回错误。Fopen("c:\newdir\file.dat","r")

*19.21 fopen不让我打开文件"$HOME/.profile"和"~~/.myrcfile"。

*19.22 怎样制止MS-DOS下令人恐怖的“Abort,Retry,Ignore?”信息?

19.23 遇到“Toomanyopenfiles(打开文件太多)”的错误,怎样增加同时打开文件的允许数目?

19.24 如何得到磁盘的可用空间大小?

19.25 怎样在C语言中读入目录?

19.26 如何创建目录?如何删除目录(及其内容)?

访问原始内存

19.27 怎样找出系统还有多少内存可用?

19.28 怎样分配大于64K的数组或结构?

19.29 错误信息“DGROUPdataallocationexceeds64K(DGROUP数据分配内存超过64K)”什么意思?我应该怎么做?我以为使用了大内存模型,就可以使用大于64K的数据!

19.30 怎样访问位于某特定地址的内存(内存映射的设备或图形显示内存)?

19.31 如何访问机器地址0处的中断向量?如果将指针设为0,编译器可能把它转成一个非零的内部空指针值。

“系统”命令

19.32 怎样在一个C程序中调用另一个程序(独立可执行的程序或系统命令)?

19.33 如果运行时才知道要执行的命令的参数(文件名等),应该如何调用system?

19.34 在MS-DOS上如何得到system返回的准确错误状态?

19.35 怎样调用另一个程序或命令,然后获取它的输出?

进程环境

19.36 怎样才能发现程序自己的执行文件的全路径?

19.37 怎样找出和执行文件在同一目录的配置文件?

19.38 进程如何改变它的调用者的环境变量?

19.39 如何打开命令行给出的文件并解析选项?

19.40 exit(status)是否真的和从main函数返回同样的status等价?

19.41 怎样读入一个对象文件并跳跃到其中的函数?

其他系统相关的操作

19.42 怎样以小于1秒的精度延时或计算用户响应时间?

19.43 怎样捕获或忽略control-C这样的键盘中断?

19.44 怎样简洁地处理浮点异常?

19.45 怎样使用socket?如何联网?如何写客户/服务器程序?

*19.46 怎样调用BIOS函数?如何写ISR?如何创建TSR?

*19.47 什么是“near”和“far”指针?

回顾

19.48 我不能使用这些非标准、依赖系统的函数,程序需要兼容ANSI!

19.49 为什么这些内容没有在C语言中进行标准化?任何现实程序都会用到这些东西。

第20章 杂项

20.1 怎样从函数返回多个值?

20.2 用什么数据结构存储文本行最好?我开始用固定大小的char型数组的数组,但是有很多局限。

20.3 怎样打开命令行提到的文件并处理参数?

20.4 如何正确地使用errno?

20.5 怎样写数据文件,使之可以在不同字大小、字节顺序或浮点格式的机器上读入?

20.6 怎样用char*指针指向的函数名调用函数?

位和字节

20.7 如何操作各个位?

20.8 怎样实现位数组或集合? 234

20.9 怎样判断机器的字节顺序是高字节在前还是低字节在前?

*20.10 怎样调换字节?

20.11 怎样将整数转换到二进制或十六进制?

20.12 可以使用二进制常数(类似0b101010这样的东西)吗?printf有二进制的格式说明符吗?

效率

20.13 用什么方法计算整数中为1的位的个数最高效?

20.14 怎样提高程序的效率?

20.15 指针真的比数组快吗?函数调用会拖慢程序多少?++i比i=i+1快吗?

20.16 用移位操作符替换乘法和除法是否有价值?

*20.17 人们说编译器优化得很好,我们不再需要为速度而写汇编了,但我的编译器连用移位代替i/=2都做不到。

*20.18 怎样不用临时变量而交换两个值?

switch语句

20.19 switch语句和if/else链哪个更高效?

20.20 是否有根据字符串进行条件切换的方法?

20.21 是否有使用非常量case行标的方法(如范围或任意的表达式)?

各种语言功能

20.22 return语句外层的括号是否真的可选择?

20.23 为什么C语言的注释不能嵌套?怎样注释掉含有注释的代码?引号包含的字符串内的注释是否合法?

20.24 为什么C语言的操作符不设计得更全面一些?好像还缺了一些^^、&&=和-=这样的操作符。

*20.25 C语言有循环移位操作符吗?

*20.26 C是个伟大的语言还是别的什么东西?哪个其他语言可以写出像a+++++b这样的代码?

20.27 如果赋值操作符是:=,是不是就不容易意外地写出if(a=b)了?

20.28 C语言有和Pascal的with等价的语句吗?

20.29 为什么C语言没有嵌套函数?

*20.30 assert是什么?如何使用?

其他语言

20.31 怎样从C中调用FORTRAN(C++、BASIC、Pascal、Ada、LISP)的函数?反之如何?

20.32 有什么程序可以将Pascal或FORTRAN(或LISP、Ada、awk、“老”C)程序转化为C程序?

20.33 C++是C的超集吗?可以用C++编译器来编译C代码吗?

20.34 我需要用到“近似”的strcmp例程,比较两个字符串的近似度,并不需要完全一样。有什么好办法?

20.35 什么是散列法?

20.36 如何生成正态或高斯分布的随机数?

20.37 如何知道某个日期是星期几?

20.38 (year%4==0)是否足以判断闰年?2000年是闰年吗?

20.39 为什么tm结构中的tm_sec的范围是0到61,暗示一分钟有62秒?

琐事

20.40 一个难题:怎样写一个输出自己源代码的程序?

20.41 什么是“达夫设备”(Duff’sDevice)?

20.42 下届国际C语言混乱代码竞赛(InternationalObfuscatedCCodeContest,IOCCC)什么时候进行?哪里可以找到当前和以前的获胜代码?

20.43 K&R1提到的关键字entry是什么?

20.44 C的名字从何而来?

20.45 “char”如何发音?

*20.46 “lvalue”和“rvalue”代表什么意思?

20.47 哪里可以获得本书的在线版?

术语表

参考文献

C语言中%f和%lf的区别

daxunniao6402的博客

04-18

1万+

(1)对于printf()来说二者没有区别

(2)使用scanf()输入数据时应该区分%f和%lf,当输入数据是float时用%f,当输入数据是double时用%lf

读者可以运行一下下面的例子感受一下区别:

#include

main()

{

const double PI = 3.14159;

double r; ...

c语言简单计算器

04-09

diaoyong(int a,double e,double f)

{

printf("请输入你要输入的元素(1-4):\n");

scanf("%d",&a);

printf("请输入你要相加的两个元素:\n");

scanf("%lf%lf",&e,&f);

c语言%f和%lf的区别

热门推荐

FZM0206的博客

12-28

4万+

由于精度的原因,输出%lf和%f的数据不同,可能会造成错误。

主要有一下四点区别:

1、代表的数据类型不同

%f代表单精度浮点型数据(float),%lf代表双精度浮点型数据(double)。

2、有效数字位数不同

单精度浮点数有效数字保证6位,部分7位,双精度浮点数有效数字保证15位,部分16位。

3、所能表示数的范围不同

单精度浮点的表示范围:-3.40E+38 ~ +3.40E+38,双精度浮点的表示范围:-1.79E+308 ~ +1.79E+308

4、在程序中处理速度不同

一般来

【C语言入门】%f 和 %lf 的区别

m0_56361048的博客

04-05

3万+

C语言中 %f 和 %lf 的区别

C语言中的%f和%lf的区别

李桥桉的博客

01-19

3万+

大家肯定知道在C语言中用于格式化输入输出时:

整数值用%d;

实数(浮点数)用%f;

%f和%lf分别对应float类型和double类型用于格式化输入输出时的格式符号。

其中:

float,单精度浮点型,对应%f。

double,双精度浮点型,对应%lf。

用于输入时:

double 类型使用了%f格式,会导致输入值错误。

float类型使用%lf格式不仅会导致输入错误,还可能引起程序崩溃。

用于输出时:

float类型可以使用%lf格式,但不会有任何好处。

double类型如果使用了%f

%lf和%f的部分区别

大聪明的博客

08-20

792

scanf函数是通过指针指向变量的。

%f告诉scanf函数在所传地址位置上存储一个float型值, 而%lf告诉scanf函数在所传地址位置上存储一个double型值。

这里float和double的区别是非常重要的。

如果给出了错误的转换说明,那么scanf函数将可能存储错误的字节数量

(没有提到的是,float型的为模式可能不同于double型的位模式)。 Taku —— SegmentFault上的回答

输入时:

float型输入用%f

double型输入用%lf

输出时:

最好是都用%f输出

.

C语言格式字符串常识

Hovering_Penguin的专栏

06-29

8512

在Turbo C中格式字符串的一般形式为: [标志][输出最小宽度][.精度][长度]类型其中方括号[]中的项为可选项。各项的意义介绍如下:1.类型类型字符用以表示输出数据的类型,其格式符和意义下表所示:表示输出类型的格式字符       格式字符意义a                                                                 浮点数、

C语言函数及相关知识

10-30

C语言函数及相关知识 函数名: abort

功 能: 异常终止一个进程

用 法: void abort(void);

程序例:

#include

#include

int main(void)

{

printf("Calling abort()\n");

abort();

return 0; /* This is never reached */

}

函数名: abs

功 能: 求整数的绝对值

用 法: int abs(int i);

程序例:

#include

#include

int main(void)

{

int number = -1234;

printf("number: %d absolute value: %d\n", number, abs(number));

return 0;

}

函数名: absread, abswirte

功 能: 绝对磁盘扇区读、写数据

用 法: int absread(int drive, int nsects, int sectno, void *buffer);

int abswrite(int drive, int nsects, in tsectno, void *buffer);

程序例:

/* absread example */

#include

#include

#include

#include

int main(void)

{

int i, strt, ch_out, sector;

char buf[512];

printf("Insert a diskette into drive A and press any key\n");

getch();

sector = 0;

if (absread(0, 1, sector, &buf) != 0)

{

perror("Disk problem");

exit(1);

}

printf("Read OK\n");

strt = 3;

for (i=0; i<80; i++)

{

ch_out = buf[strt+i];

putchar(ch_out);

}

printf("\n");

return(0);

}

函数名: access

功 能: 确定文件的访问权限

用 法: int access(const char *filename, int amode);

程序例:

#include

#include

int file_exists(char *filename);

int main(void)

{

printf("Does NOTEXIST.FIL exist: %s\n",

file_exists("NOTEXISTS.FIL") ? "YES" : "NO");

return 0;

}

int file_exists(char *filename)

{

return (access(filename, 0) == 0);

}

函数名: acos

功 能: 反余弦函数

用 法: double acos(double x);

程序例:

#include

#include

int main(void)

{

double result;

double x = 0.5;

result = acos(x);

printf("The arc cosine of %lf is %lf\n", x, result);

return 0;

}

函数名: allocmem

功 能: 分配DOS存储段

用 法: int allocmem(unsigned size, unsigned *seg);

程序例:

#include

#include

#include

int main(void)

{

unsigned int size, segp;

int stat;

size = 64; /* (64 x 16) = 1024 bytes */

stat = allocmem(size, &segp);

if (stat == -1)

printf("Allocated memory at segment: %x\n", segp);

else

printf("Failed: maximum number of paragraphs available is %u\n",

stat);

return 0;

}

函数名: arc

功 能: 画一弧线

用 法: void far arc(int x, int y, int stangle, int endangle, int radius);

程序例:

#include

#include

#include

#include

int main(void)

{

/* request auto detection */

int gdriver = DETECT, gmode, errorcode;

int midx, midy;

int stangle = 45, endangle = 135;

int radius = 100;

/* initialize graphics and local variables */

initgraph(&gdriver, &gmode, "");

/* read result of initialization */

errorcode = graphresult(); /* an error occurred */

if (errorcode != grOk)

{

printf("Graphics error: %s\n", grapherrormsg(errorcode));

printf("Press any key to halt:");

getch();

exit(1); /* terminate with an error code */

}

midx = getmaxx() / 2;

midy = getmaxy() / 2;

setcolor(getmaxcolor());

/* draw arc */

arc(midx, midy, stangle, endangle, radius);

/* clean up */

getch();

closegraph();

return 0;

}

函数名: asctime

功 能: 转换日期和时间为ASCII码

用 法: char *asctime(const struct tm *tblock);

程序例:

#include

#include

#include

int main(void)

{

struct tm t;

char str[80];

/* sample loading of tm structure */

t.tm_sec = 1; /* Seconds */

t.tm_min = 30; /* Minutes */

t.tm_hour = 9; /* Hour */

t.tm_mday = 22; /* Day of the Month */

t.tm_mon = 11; /* Month */

t.tm_year = 56; /* Year - does not include century */

t.tm_wday = 4; /* Day of the week */

t.tm_yday = 0; /* Does not show in asctime */

t.tm_isdst = 0; /* Is Daylight SavTime; does not show in asctime */

/* converts structure to null terminated

string */

strcpy(str, asctime(&t));

printf("%s\n", str);

return 0;

}

函数名: asin

功 能: 反正弦函数

用 法: double asin(double x);

程序例:

#include

#include

int main(void)

{

double result;

double x = 0.5;

result = asin(x);

printf("The arc sin of %lf is %lf\n", x, result);

return(0);

}

函数名: assert

功 能: 测试一个条件并可能使程序终止

用 法: void assert(int test);

程序例:

#include

#include

#include

struct ITEM {

int key;

int value;

};

/* add item to list, make sure list is not null */

void additem(struct ITEM *itemptr) {

assert(itemptr != NULL);

/* add item to list */

}

int main(void)

{

additem(NULL);

return 0;

}

函数名: atan

功 能: 反正切函数

用 法: double atan(double x);

程序例:

#include

#include

int main(void)

{

double result;

double x = 0.5;

result = atan(x);

printf("The arc tangent of %lf is %lf\n", x, result);

return(0);

}

函数名: atan2

功 能: 计算Y/X的反正切值

用 法: double atan2(double y, double x);

程序例:

#include

#include

int main(void)

{

double result;

double x = 90.0, y = 45.0;

result = atan2(y, x);

printf("The arc tangent ratio of %lf is %lf\n", (y / x), result);

return 0;

}

函数名: atexit

功 能: 注册终止函数

用 法: int atexit(atexit_t func);

程序例:

#include

#include

void exit_fn1(void)

{

printf("Exit function #1 called\n");

}

void exit_fn2(void)

{

printf("Exit function #2 called\n");

}

int main(void)

{

/* post exit function #1 */

atexit(exit_fn1);

/* post exit function #2 */

atexit(exit_fn2);

return 0;

}

函数名: atof

功 能: 把字符串转换成浮点数

用 法: double atof(const char *nptr);

程序例:

#include

#include

int main(void)

{

float f;

char *str = "12345.67";

f = atof(str);

printf("string = %s float = %f\n", str, f);

return 0;

}

函数名: atoi

功 能: 把字符串转换成长整型数

用 法: int atoi(const char *nptr);

程序例:

#include

#include

int main(void)

{

int n;

char *str = "12345.67";

n = atoi(str);

printf("string = %s integer = %d\n", str, n);

return 0;

}

函数名: atol

功 能: 把字符串转换成长整型数

用 法: long atol(const char *nptr);

程序例:

#include

#include

int main(void)

{

long l;

char *str = "98765432";

l = atol(lstr);

printf("string = %s integer = %ld\n", str, l);

return(0);

}

C语言的四则运算问题(不含括号)

10-21

#include

#include

struct four

{

double a;

struct four *next; //定义结构体,作为链表的节点.

};

void main()

{

double sum(void); //函数声明. 该函数返回等式的计算结果. 有优先级的运算符号在函数内部先进行计算。

double sum1;

printf("请输入等式,以 '=' 结束, 例如“ 2*2*3-2/2= ” 结果将自动保留六位有效数字\n");

sum1=sum();

printf("该等式的结果为:\t%f\n\n",sum1);

}

double sum(void)

{

struct four *head,*pnew,*ptail,*p,*q; //结构体成员.

char ah;

double s=0,last; //last作为 pnew->a 的前一个数值.

int j=1;

q=(struct four *)malloc(sizeof(struct four));

scanf("%lf%c",&q->a,&ah);

last=q->a;

while(j==1 && ah!='=') //头节点的建立.

{

switch(ah) //对运算符号的优先级进行选择,优先级高的先进行计算.

{

case '+':

j=0;

continue;

break;

case '-':

j=0;

continue;

break;

case '*':

q=(struct four *)malloc(sizeof(struct four));

scanf("%lf",&q->a);

q->a=last*q->a;

break;

case '/':

q=(struct four *)malloc(sizeof(struct four));

scanf("%lf",&q->a);

q->a=last/q->a;

break;

default:

printf("Error!\n"); //当运算符号出错时的处理.

exit(0);

}

last=q->a;

scanf("%c",&ah);

}

pnew=(struct four *)malloc(sizeof(struct four));

pnew->a=q->a; //将头节点的信息传递给 head 和 ptail.

head=ptail=pnew;

while(ah!='=') //接下来节点的建立.

{

pnew=(struct four *)malloc(sizeof(struct four));

scanf("%lf",&pnew->a);

switch(ah)

{

case '*':

pnew->a=last*pnew->a;

break;

case '/':

pnew->a=last/pnew->a;

break;

case '+':

break;

case '-':

pnew->a=-pnew->a;break;

default:

printf("Error!\n"); //当运算符号出错时的处理.

exit(0);

}

scanf("%c",&ah);

if(ah=='-' || ah=='+'|| ah=='=') //将值进行传递 ptail->next=pnew.

{

ptail->next=pnew;

ptail=pnew;

}

last=pnew->a;

}

ptail->next=NULL;

p=head;

while(p!=NULL) //各个节点数值相加的结果,有优先级符号的已经先计算了.

{

s=s+(p->a);

p=p->next;

}

return s; //返回运算结果.

}

ndk:ndk基础 cc++

04-06

ndk

ndk基础 c/c++

c语言基础

创建C语言程序

xcode -> create new xcode project -> macos -> command line tools

在macos系统即可创建一个c语言程序

基本数据类型

int 整型,占4个字节

double 双精度小数 占8个字节

float 单精度小数 占4个字节

char 字符 占1个字节

int i = 2;

printf("i的值:%d,所占字节%d\n", i, sizeof(i));

double db = 1.34;

printf("db的值:%lf,所占字节%d\n", db, sizeof(db));

float fl = 1.12;

printf("fl的值:%f,所占字节%d\n", fl, sizeof(fl));

char ch = 'A';

printf("ch的值:%c,所占字节%d\

C语言FAQ 常见问题列表

10-28

previous up contents next

C 语言常见问题集

原著:Steve Summit

翻译:朱群英, 孙 云

修订版 0.9.4, 2005年6月23日

版权所有 © 2005

* 目录

* 1. 前言

* 2. 声明和初始化

o 2.1 我如何决定使用那种整数类型?

o 2.2 64 位机上的 64 位类型是什么样的?

o 2.3 怎样定义和声明全局变量和函数最好?

o 2.4 extern 在函数声明中是什么意思?

o 2.5 关键字 auto 到底有什么用途?

o 2.6 我似乎不能成功定义一个链表。我试过 typedef struct { char *item; NODEPTR next; } *NODEPTR; 但是编译器报了错误信息。难道在C语言中一个结构不能包含指向自己的指针吗?

o 2.7 怎样建立和理解非常复杂的声明?例如定义一个包含 N 个指向返回指向字符的指针的函数的指针的数组?

o 2.8 函数只定义了一次, 调用了一次, 但编译器提示非法重定义了。

o 2.9 main() 的正确定义是什么? void main() 正确吗?

o 2.10 对于没有初始化的变量的初始值可以作怎样的假定?如果一个全局变量初始值为 ``零", 它可否作为空指针或浮点零?

o 2.11 代码 int f() { char a[] = "Hello, world!";} 不能编译。

o 2.12 这样的初始化有什么问题?char *p = malloc(10); 编译器提示 ``非法初始式" 云云。

o 2.13 以下的初始化有什么区别?char a[] = "string literal"; char *p = "string literal"; 当我向 p[i] 赋值的时候, 我的程序崩溃了。

o 2.14 我总算弄清除函数指针的声明方法了, 但怎样才能初始化呢?

* 3. 结构、联合和枚举

o 3.1 声明 struct x1 { ...}; 和 typedef struct { ...} x2; 有什么不同?

o 3.2 为什么 struct x { ...}; x thestruct; 不对?

o 3.3 一个结构可以包含指向自己的指针吗?

o 3.4 在 C 语言中实现抽象数据类型什么方法最好?

o 3.5 在 C 中是否有模拟继承等面向对象程序设计特性的好方法?

o 3.6 我遇到这样声明结构的代码: struct name { int namelen; char namestr[1];}; 然后又使用一些内存分配技巧使 namestr 数组用起来好像有多个元素。这样合法和可移植吗?

o 3.7 是否有自动比较结构的方法?

o 3.8 如何向接受结构参数的函数传入常数值?

o 3.9 怎样从/向数据文件读/写结构?

o 3.10 我的编译器在结构中留下了空洞, 这导致空间浪费而且无法与外部数据文件进行 "二进制" 读写。能否关掉填充, 或者控制结构域的对齐方式?

o 3.11 为什么 sizeof 返回的值大于结构的期望值, 是不是尾部有填充?

o 3.12 如何确定域在结构中的字节偏移?

o 3.13 怎样在运行时用名字访问结构中的域?

o 3.14 程序运行正确, 但退出时却 ``core dump''了,怎么回事?

o 3.15 可以初始化一个联合吗?

o 3.16 枚举和一组预处理的 #define 有什么不同?

o 3.17 有什么容易的显示枚举值符号的方法?

* 4. 表达式

o 4.1 为什么这样的代码: a[i] = i++; 不能工作?

o 4.2 使用我的编译器,下面的代码 int i=7; printf("%d\n", i++ * i++); 返回 49?不管按什么顺序计算, 难道不该打印出56吗?

o 4.3 对于代码 in

计算机二级C语言上机真题

05-12

给定程序中,函数fun的功能是:将形参n所指变量中,各位上为偶数的数去

除,剩余的数按原来从高位到低位的顺序组成一个新的数,并通过形参指针n传回

所指变量。

例如,输入一个数:27638496,新的数:为739。

请在程序的下划线处填入正确的内容并把下划线删除, 使程序得出正确的结

果。

注意:源程序存放在考生文件夹下的BLANK1.C中。

不得增行或删行,也不得更改程序的结构!

给定源程序:

#include

void fun(unsigned long *n)

{ unsigned long x=0, i; int t;

i=1;

while(*n)

/**********found**********/

{ t=*n ;

/**********found**********/

if(t%2!= 0)

{ x=x+t*i; i=i*10; }

*n =*n /10;

}

/**********found**********/

*n=x;

}

main()

{ unsigned long n=-1;

while(n>99999999||n<0)

{ printf("Please input(0

fun(&n);

printf("\nThe result is: %ld\n",n);

}

解题思路:

第一处:t是通过取模的方式来得到*n的个位数字,所以应填:10。

第二处:判断是否是奇数,所以应填:0。

第三处:最后通形参n来返回新数x,所以应填:x。

定程序MODI1.C中函数 fun 的功能是:计算n!。

例如,给n输入5,则输出120.000000。

请改正程序中的错误,使程序能输出正确的结果。

注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!

给定源程序:

#include

double fun ( int n )

{ double result = 1.0 ;

/************found************/

if (n = = 0 )

return 1.0 ;

while( n >1 && n < 170 )

/************found************/

result *= n-- ;

return result ;

}

main ( )

{ int n ;

printf("Input N:") ;

scanf("%d", &n) ;

printf("\n\n%d! =%lf\n\n", n, fun(n)) ;

}

解题思路:

第一处:条件语句书写格式错误,应改为:if (n==0)。

第二处:语句后缺少分号。

***************************************************

请编写一个函数fun,它的功能是:将一个数字字符串转换为一个整数(不得

调用C语言提供的将字符串转换为整数的函数)。例如,若输入字符串"-1234",则

函数把它转换为整数值 -1234。函数fun中给出的语句仅供参考。

注意: 部分源程序存在文件PROG1.C文件中。

请勿改动主函数main和其它函数中的任何内容, 仅在函数fun的花括号中填

入你编写的若干语句。

给定源程序:

#include

#include

long fun ( char *p)

{

/* 以下代码仅供参考 */

int i, len, t; /* len为串长,t为正负标识 */

long x=0;

len=strlen(p);

if(p[0]=='-')

{ t=-1; len--; p++; }

else t=1;

/* 以下完成数字字符串转换为一个数字 */

for(i=1;i

x=x*10+p[i]-48;

return x*t;

}

main() /* 主函数 */

{ char s[6];

long n;

printf("Enter a string:\n") ;

gets(s);

n = fun(s);

printf("%ld\n",n);

NONO ( );

}

NONO ( )

{/* 本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。 */

FILE *fp, *wf ;

int i ;

char s[20] ;

long n ;

fp = fopen("c:\\test\\in.dat","r") ;

wf = fopen("c:\\test\\out.dat","w") ;

for(i = 0 ; i < 10 ; i++) {

fscanf(fp, "%s", s) ;

n = fun(s);

fprintf(wf, "%ld\n", n) ;

}

fclose(fp) ;

fclose(wf) ;

}

解题思路:

本题是将一个数字字符串转换为一个整数。

参考答案:

#include

#include

long fun ( char *p)

{

/* 以下代码仅供参考 */

int i, len, t; /* len为串长,t为正负标识 */

long x=0;

len=strlen(p);

if(p[0]=='-')

{ t=-1; len--; p++; }

else t=1;

/* 以下完成数字字符串转换为一个数字 */

while(*p) x = x*10-48+(*p++);

return x*t;

}

main() /* 主函数 */

{ char s[6];

long n;

printf("Enter a string:\n") ;

gets(s);

n = fun(s);

printf("%ld\n",n);

NONO ( );

}

NONO ( )

{/* 本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。 */

FILE *fp, *wf ;

int i ;

char s[20] ;

long n ;

fp = fopen("c:\\test\\in.dat","r") ;

wf = fopen("c:\\test\\out.dat","w") ;

for(i = 0 ; i < 10 ; i++) {

fscanf(fp, "%s", s) ;

n = fun(s);

fprintf(wf, "%ld\n", n) ;

}

fclose(fp) ;

fclose(wf) ;

}

注意:由于NONO( )这个函数是改卷人用的,与考生没有什么关系,故下面从第2套试题开始均省略NONO( )

UART.rar_2407 串口_F2407_TMS320LF2407_uart c语言

09-23

TMS320LF2407串口通讯程序,C语言实现

你必须知道的495个C语言问题(PDF)

09-15

和typedef struct f . . . g x2; 有什么不同? . 7 2.2 为什么struct x f . . . g; x thestruct; 不对? . . . . . . . . . . . . . 7 2.3 一个结构可以包含指向自己的指针吗? . . . . . . . . . . . . . . . 7 ...

c语言实现的计算器

01-07

#include #include #include /*****************************************/ /* 将数字字符转化成浮点型实数进行计算 */ /* */ /********************************... printf("%.*lf\n",wei,evalpost(f)); return 0; }

C语言程序设计标准教程

05-22

其中“%f”和“%lf ”格式的输出相同,说明“l”符对“f”类型无影响。“%5.4lf”指定输出宽度为5,精度为4,由于实际长度超过5故应该按实际位数输出,小数位数超过4位部分被截去。第九行输出双精度实数,“%8.4lf ...

C语言%lf和%f的区别

最新发布

05-26

在 C 语言中,%f 和 %lf 都是用来格式化输出浮点数的占位符,但是它们之间有一些区别。

%f 是用来输出单精度浮点数的,也就是 float 类型的数据。而 %lf 是用来输出双精度浮点数的,也就是 double 类型的数据。

在实际使用中,如果你需要输出 double 类型的数据,建议使用 %lf,因为有时候使用 %f 会导致输出结果不准确。

另外需要注意的是,如果你在使用 scanf 函数读取浮点数时,需要使用 %lf 而不是 %f,因为 scanf 函数默认读取的是 double 类型的数据。

“相关推荐”对你有帮助么?

非常没帮助

没帮助

一般

有帮助

非常有帮助

提交

meme_yun

CSDN认证博客专家

CSDN认证企业博客

码龄7年

暂无认证

2

原创

52万+

周排名

220万+

总排名

10万+

访问

等级

360

积分

27

粉丝

202

获赞

18

评论

443

收藏

私信

关注

热门文章

C语言问题:%f和%lf的区别

107511

基于奇异值分解的推荐 java实现

1479

分类专栏

机器学习

1篇

java

1篇

c语言

1篇

输入

1篇

输出

1篇

最新评论

C语言问题:%f和%lf的区别

m0_73845666:

听我说谢谢你

C语言问题:%f和%lf的区别

未完的童话:

l是修饰d,o,x,u这些整数型的,

L是修饰f,e,g浮点型的,所以根本没有%lf。

%f表示输出的是float和double,而%Lf表示输出long double。

C语言问题:%f和%lf的区别

BuffaloX_X:

对头

C语言问题:%f和%lf的区别

加油啊同学:

c编译系统里把浮点型常量都按双精度处理, 像如果有 float a=1.92384; 在编译的时候对float变量分配的是4个字节,而对浮点型常量1.92384分配的是8个字节。这相当于你把一个双精度常量转化为了float型,显然导致精度的损失、、这时候可以在1.92384后面加一个f表明它是float型常量///这都题外话了

对于这个问题 :f格式符是用来输出实数(这其中就包括了单、双、长双精度)默认输出6位小数

所以输出没有什么%lf

C语言问题:%f和%lf的区别

Tutulxk:

确实输出浮点数都用%f,但是你说话说的太绝对了,第6版C primetr plus中文版习题解答第41页第7题写到“double类型也可以使用%lf……但是打印时的转换并不能提高原float类型数据的精度”

您愿意向朋友推荐“博客详情页”吗?

强烈不推荐

不推荐

一般般

推荐

强烈推荐

提交

最新文章

基于奇异值分解的推荐 java实现

2019年1篇

2017年1篇

目录

目录

分类专栏

机器学习

1篇

java

1篇

c语言

1篇

输入

1篇

输出

1篇

目录

评论 18

被折叠的  条评论

为什么被折叠?

到【灌水乐园】发言

查看更多评论

添加红包

祝福语

请填写红包祝福语或标题

红包数量

红包个数最小为10个

红包总金额

红包金额最低5元

余额支付

当前余额3.43元

前往充值 >

需支付:10.00元

取消

确定

下一步

知道了

成就一亿技术人!

领取后你会自动成为博主和红包主的粉丝

规则

hope_wisdom 发出的红包

实付元

使用余额支付

点击重新获取

扫码支付

钱包余额

0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。 2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值

CRLF和LF的差异 - 知乎

CRLF和LF的差异 - 知乎首发于后沿技术切换模式写文章登录/注册CRLF和LF的差异不知味之味人心不古大多数人应该对这两个并不陌生,但是你有深入了解过这两个概念吗?今天我们通过这篇来深入探讨一下,希望你读完这篇文章之后不会再感到困扰。CRLF 与 LF:换行到底是什么?要真正理解 CRLF 与 LF 换行的问题,我们需要复习一些排版历史。人们使用字母、数字和符号来相互交流。但是计算机只能理解和处理数字。由于计算机上的文件由人类可读的字符串组成,因此我们需要一个允许我们在这两种格式之间来回转换的系统。 ASCII 标准就是这样的系统——它将 A 和 z 等字符映射到数字,弥合了人类语言和计算机语言之间的鸿沟。有趣的是,ASCII 标准不仅仅适用于字母和数字等可见字符。某个子集是控制字符,也称为非打印字符。它们不用于渲染可见字符;相反,它们用于执行独特的操作,例如删除前一个字符或插入换行符。LF 和 CR 就是两个这样的控制字符,它们都与文件中的行尾有关。它们的历史可以追溯到打字机时代,因此我将简要介绍其工作原理,以便了解为什么我们有两个不同的控制字符而不是一个。然后,我们将看看这如何影响开发人员的体验。LF:换行LF(Line Feed)代表“换行”,但你可能更熟悉术语换行符(转义序列 \n)。简单地说,这个字符代表一行文本的结束。在 Linux 和 Mac 上,这相当于新文本行的开始。这种区别很重要,因为 Windows 不遵循此约定。我们了解回车之后再讨论为什么不同。CR:回车CR(Carriage Return)代表回车(转义序列\r),将光标移动到当前行的开头。终端上的下载进度条就是通过CR实现的,通过使用回车符,你的终端可以通过将光标返回到当前行的开头并覆盖任何先前呈现的文本来将文本动画化。打字机和回车(CR)将一张纸固定在称为托架的机械卷上,为设备送入一张纸。每次击键时,打字机都会使用墨水在您的纸张上打印字母,将笔架向左移动以确保键入的下一个字母会出现在前一个字母的右侧。当然,一旦当前行的空间用完,打字员就需要向下移动到纸张上的下一行。这是通过旋转滑架将纸张相对于打字机的“笔”向上移动一定距离来完成的。但是还需要重置托架(carriage),以便键入的下一个字符将与纸张的左侧边距对齐。换句话说,打字员需要某种方式将托架返回到其起始位置。而这正是回车的工作:一个金属杆连接到托架的左侧,当推动时,将托架返回到其起始位置。电传打字机和回车换行(CRLF)进入 20 世纪初,出现了电传打字机。基本上,它的工作方式与手动打字机相同,除了不是打印到物理纸上,而是通过传输器通过物理电线或无线电波将消息发送给接收方。虽然打印方式不同,但是同样需要使用换行符 (LF) 和回车符 (CR),而且这些设备需要同时使用换行符 (LF) 和回车符 (CR) 以允许打字员从下一行文本的开头输入。毕竟手动打字机就是这样工作的,只是它没有任何“字符”的概念,因为它是一种机械操作的设备。我们可以将 LF 和 CR 视为代表水平或垂直方向上的独立运动,而不是同时代表两者,这样更容易将其形象化。为了实现这个功能,电传打字机在一些最早的操作系统中设定了 CRLF 行尾的标准,比如流行的 MS-DOS。将CR 代表“回车”——CR 控制字符将打印头(“回车”)返回到第 0 列,而无需推进纸张。 LF 代表“换行”——LF 控制字符在不移动打印头的情况下将纸张前进一行。因此,如果您想将打印头返回到第 0 列(准备打印下一行)并推进纸张(以便在新纸上打印),则需要 CR 和 LF。MS-DOS 使用 CRLF 的两个字符组合来表示文件中的行尾,现代 Windows 计算机一直使用 CRLF 作为行尾。同时,从一开始,Unix 就使用 LF 来表示行尾,为了一致性和简单性而放弃了 CRLF。 Apple 最初仅在 Mac Classic 上使用 CR,但最终在 OS X 上改用了 LF,与 Unix 一致。虽然这似乎是操作系统之间的差异,但 CRLF 与 LF 的这个问题已经引起人们很长时间的头痛。其实按照今天的标准 CRLF 是多余的——同时使用回车和换行是假设你受到打字机的物理限制,你必须明确地向上移动你的纸,然后重置移动到左边距。但是对于电子文件,将换行符定义为隐式完成换行和回车的工作就足够了。换句话说,只要操作系统定义换行符表示下一行从开头开始而不是从某个任意的列偏移处开始,那么除了换行之外,我们不需要显式回车——一个符号可以完成两者的工作。现在我们知道CRLF和CR是如何起源的,接下来我们来学习以下怎么处理相关的问题。检查和转换行尾(在 Bash 中)在 bash中,你可以使用带有 A 标志的 cat 查看特定文件的行尾:如果文件使用 CRLF,您将在每行末尾看到字符串 ^M$,其中 ^M 表示回车,$ 表示换行。下面是一个示例: line one^M$

line two^M$

line three^M$

如果文件使用 LF,那么您只会看到美元符号: line one$

line two$

line three$

ps: 你可以使用dos2unix命令行程序将文件从CRLF转换为LF。Git中的行尾诚然,这需要很多背景知识!但这是值得的,因为我们终于准备好讨论与 git 相关的行尾(以及如何在任何给定的代码库中解决 CRLF 与 LF 的问题)。我们从前面可以知道CRLF和LF是不同的字符表示,因此缺少通用行结尾为 git 等版本控制软件带来了麻烦,这类软件依赖于非常精确的字符比较来确定文件自上次签入以来是否发生了变化。如果开发人员使用 Windows 并且另一个使用 Mac 或 Linux,他们每个人都保存和提交相同的文件,他们可能会在他们的 git diff 中看到行结束更改——从 CRLF 到 LF 的转换,反之亦然。由于单字符更改,这会导致不必要的麻烦,非常烦人。使用 core.autocrlf 在 Git 中配置行尾可以使用core.autocrlf配置告诉git如何处理系统上的行尾。可以通过以下命令完成: git config --global core.autocrlf [true|false|input]

注意,false值会关闭行尾转换,这通常是不可取的,除非是团队中的每个人都使用相同的操作系统。当然,我觉得这种情况很少发生,所以慎用(除非你使用 .gitattributes 配置,在这种情况下,它会优先于你的 git 配置——稍后会详细介绍)。所以,一般来说我们只有两个选择:autocrlf true 和 autocrlf input。这两者有什么区别?autocrlf true当 autocrlf 为 true 时(git默认行为),文件将使用 git 在本地检出为 CRLF,但是每当你提交文件时,CRLF 的所有实例都将替换为 LF。基本上,此设置可确保你的代码库在所有文件的最终版本中始终使用 LF,但在获取时在本地使用 CRLF。这是 Windows 开发人员的推荐设置,因为 CRLF 是 Windows 的本机行结尾。如果使用此选项,则每次在 Windows 上暂存文件以进行提交时可能会看到下面警告: warning: CRLF will be replaced by LF in .

The file will have its original line endings in your working directory.

这并不是说出现问题, Git 只是警告你,根据此设置的预期行为,你的 CRLF 行结尾将在提交时规范化为 LF。autocrlf input使用 autocrlf input,文件在提交时转换为 LF,但在获取时不会转换为任何内容。因此名称为“输入”——你得到是你最初输入的内容。如果一个文件最初被 Windows 开发人员意外提交为 CRLF,你会在本地看到它是 CRLF(如果你修改它,你会强制它变成LF)。如果文件最初是作为 LF 添加的,您会看到它是LF。这通常是一件好事,因为这意味着你将始终在代码库中获得 LF 行结尾(假设你从一开始就使用它)。input 和 ​​true 之间的唯一区别是输入不会在本地获取时处理行尾。这是 Mac/Linux 开发人员的推荐设置,因为这些操作系统默认使用 LF。使用 .gitattributes 在 Git 中规范行尾在你的 repo 的根目录创建一个 .gitattributes 文件来一劳永逸地行尾不一致的问题。 Git 会读取此文件并在您本地获取或提交文件时应用其规则,确保无论每个开发人员如何在本地配置 git 或他们使用什么操作系统,都强制执行行尾约定。一个简单的 .gitattributes 配置这是一个 .gitattributes 文件,应该涵盖大多数用例:# We'll let Git's auto-detection algorithm infer if a file is text. If it is,

# enforce LF line endings regardless of OS or git configurations.

* text=auto eol=lf

# Isolate binary files in case the auto-detection algorithm fails and

# marks them as text files (which could brick them).

*.{png,jpg,jpeg,gif,webp,woff,woff2} binary

提交该文件并将其推送到远程服务器。git 使用一种简单的算法来检测你的 repo 中的特定文件是文本文件还是二进制文件(例如,可执行文件、图像或字体文件)。默认情况下,此算法用于比较已更改的文件,但它也可以用于强制行尾约定。这就是上面配置中 text=auto 的作用——它告诉 git 应用其自动检测算法来确定文件是否是文本文件。然后, eol=lf 告诉 git 在本地获取和提交时强制执行文本文件的 LF 行结尾。这适用于 Windows 和 Linux,因为现在大多数跨平台文本编辑器都支持 LF。Git 的自动检测算法相当准确,但如果它无法正确区分文本文件和二进制文件(如图像或字体文件),我们也可以将文件的子集显式标记为二进制文件以避免作为文本文件处理他们。这可以用下面的代码实现: *.{png,jpg,jpeg,gif,webp,woff,woff2} binary

现在,提交此文件后,最后一步是重新规范化所有在添加 .gitattributes 之前已签入 git 的文件的所有行尾。你可以使用以下命令执行此操作: git add --renormalize .

这会根据 .gitattributes 配置中定义的规则重新格式化所有文件。如果先前提交的文件在 git 的索引中使用 CRLF 并且由于此重新规范化而转换为 LF,则它们的行尾将在索引中更新,并且这些文件将暂存以进行提交。唯一要做的就是提交这些更改并将它们推送到远程存储库。之后引入的新文件,其行尾都将作为 LF 签入(和签出)。Git 行尾:工作树与索引提交这些重新规范化的文件时,您可能会看到以下消息: warning: CRLF will be replaced by LF in .

The file will have its original line endings in your working directory.

这是预期的行为——CRLF 将成为 Git 索引中的 LF,这意味着当你将这些文件推送到你的存储库时,它们将在你的远程代码库中具有 LF 行结尾。任何后来提取或获取该代码的人都会在本地看到 LF 行结尾。但是 git 实际上并没有更改文件的本地文件(即其工作树中的那些)的行尾。因此,警告消息的最后一点表示刚刚重新规范化的文件仍会继续在本地使用 CRLF。在 Git 中验证任何文件的行尾如果想在所有这些步骤之后仔细检查 Git 索引中的文件是否使用正确的行结尾,可以运行以下命令: git ls-files --eol

这将显示 git 正在跟踪的所有文件的行尾信息,格式如下: i/lf w/crlf attr/text=auto eol=lf file.txt

从左到右分别是:i:索引中的行尾(被推送到你的仓库的行)。应该是LF。w:工作树中的行尾(可能是 CRLF,但如果索引是 LF 也可以)。attr:适用于此文件的 .gitattributes 规则。文件名。或者,你可以在将代码推送到远程后,通过在 Windows 机器上重新克隆您的存储库来仔细检查 git 是否正确规范了您的行尾。你应该看到文件的索引和工作树副本都使用 LF 而不是 CRLF(假设LF是您选择规范化行尾的方式)。.editorconfig 文件从技术上讲,一个 .gitattributes 文件是你执行代码库远程副本上显示的行尾所需的全部内容。但是,正如我们在上面看到的,你可能仍然会在本地看到你创建的文件的 CRLF 行结尾,因为 .gitattributes 不会告诉 git 更改文件的工作副本。当然,这并不意味着 git 的规范化过程不起作用。但是,如果你还使用 ESLint 和 Prettier 对代码进行 linting,这可能会很烦人,在这种情况下,它们会不断抛出错误并告诉您删除那些额外的 CR:所以,你可以使用 .editorconfig 文件更进一步;这是一个与编辑器无关的项目,旨在创建用于自定义任何给定文本编辑器行为的标准化格式。许多文本编辑器(包括 VS Code,IDEA,GitHub)支持并自动读取此文件(如果存在)。你可以将这样的内容放在工作区的根目录中,你可以在这里深入了解: root = true

[*]

end_of_line = lf

除了一堆其他设置之外,你还可以指定应用于通过此文本编辑器创建的任何新文件的行尾。这样,如果使用 VS Code 在 Windows 上创建一个新文件,你将始终在工作树中看到行结尾为 LF。参考https://stackoverflow.com/a/56858538/5323344https://www.aleksandrhovhannisyan.com/blog/crlf-vs-lf-normalizing-line-endings-in-git/https://editorconfig.org/=========p.s. 欢迎大家关注我的微信公众号编辑于 2022-01-30 11:41排版Git打字机​赞同 88​​5 条评论​分享​喜欢​收藏​申请转载​文章被以下专栏收录后沿技术分享一些CS/Linux/OSS相关

LF(钢包精炼炉)_百度百科

包精炼炉)_百度百科 网页新闻贴吧知道网盘图片视频地图文库资讯采购百科百度首页登录注册进入词条全站搜索帮助首页秒懂百科特色百科知识专题加入百科百科团队权威合作下载百科APP个人中心LF是一个多义词,请在下列义项上选择浏览(共6个义项)添加义项收藏查看我的收藏0有用+10LF播报讨论上传视频钢包精炼炉LF(Ladle Furnace)精炼技术的研究始于1968年。当时发现用电弧炉预造还原渣、钢渣混出、钢包吹氩处理,还原精炼效果显著,因此进行了以省略电弧炉还原期为目的的有电弧加热功能的钢包精炼技术的开发。1971年,日本大同特殊钢厂第一台钢包精炼炉(LF)投入使用。1973年,新日铁八幡制铁所在转炉厂设置了LF。外文名LFL    FLadle Furnace始    于1968年关    键关键于快速造白渣领    域工业目录1产品简介2工艺分析产品简介播报编辑电炉流程及转炉流程普遍采用的出钢后变渣处理工艺,即:电弧炉或转炉出钢→LF精炼(加铝、加渣料、加Ca-Si或加改渣剂)→铸造LF设置在电弧炉炼钢厂,减少了电弧炉还原时间,最终取消了电弧炉的还原期.缩短了电弧炉的冶炼周期,提高了电弧炉的生产率,同时在一定时间内为连铸提供符合温度、成分及洁净度要求的钢液,保证了电弧炉+ LF精炼+连铸工艺的顺行,使电弧炉发展成为可以用普通废钢和生铁生产普通钢种的高效率的短流程炼钢方式,而不再仅仅是生产高质量钢种的设备。电弧炉发展的第一阶段是包括熔化、氧化、还原的传统型电弧炉。第二阶段是由于电弧炉炉型(出钢槽式电弧炉)的原因,为避免氧化渣污染钢液及发挥钢渣脱氧、脱硫的作用,在电弧炉内必须造好还原渣。钢渣混出,由LF来完成进一步还原精炼的任务。第三阶段是由于无渣出钢技术的开发,还原期全部由LF精炼来完成,也即形成了现代电弧炉炼钢流程EAF+LF+CC的形式。LF用于转炉流程生产特殊钢,淘汰了过去用炼钢方法来区别钢质量的方式,确立了“初炼(电炉或转炉)+LF精炼+连铸”的生产多品种、高质量钢的思想。LF技术开发成功后,向多功能方向发展,1981年在日本钢管福山制铁所开发了NK-AP法.即擦入式喷枪代替透气砖进行气体搅拌法,1987年开发了有喷吹设备和真空设备的LF。由于LF设备结构简单。具有多种冶金功能和使用中的灵活性、精炼效果显著,具有较高的经济效益,成为钢铁生产流程中的重要设备。工艺分析播报编辑LF炉精炼是炉外精炼的主要方法之一,其在关键于快速造白渣。LF造渣的目的是脱硫、脱氧、提高合金收得率、去除夹杂,但在控铝钢的造渣过程中,脱硫回硅、增氮、去除夹杂物存在一定的矛盾,需要统筹考虑。在LF快速而稳定的造出流动性好并有一定乳化性的还原性白渣,是LF脱硫、吸附夹杂及保证钢水质量所必需的。以欧标S235JR控铝钢(低硅钢种)为例,生产工艺流程:复吹转炉→氩站→LF→CC。转炉出钢时,利用出钢时搅拌动能,加入适量的石灰进行渣洗预造还原渣,保证碱度,防止回磷回硅;出钢过程全程软搅拌均匀成分和温度;采用钢芯铝(或铝锰镁)进行钢液脱氧;根据下渣量大小(一般下渣量约5kg/t),出钢后及时加入适量改质剂;采用高碳锰进行合金化。通过对造渣过程、炉渣成分转变过程、炉渣综合碱度变化等的分析得出以下几点快速造白渣的工艺措施:(1)转炉出钢炉渣提前改质,可为LF快速造渣提供有利条件;同时转炉出钢时还应严格控制:补吹、挡渣、底吹、包况、一次脱氧几个环节。(2)前期快速化渣是造渣的前提。控制要点:快速升温、埋弧、搅拌、分批次合理加入造渣剂。(3)强搅拌脱硫(4.0~6.0L/(min·t)),速度要快,时间要短,在保证脱硫的同时,尽量控制二次氧化和钢液吸氮时间。一般在LF开始处理后的10~20min内完成,本阶段是LF精炼的主要阶段。(4)脱硫完成后LF的主要任务是控温、合金化和去除夹杂物,此阶段要保证炉渣粘度、控制搅拌强度在0.5~1.0L/(min·t)(以液面波动但不裸露钢液面为原则),要求保持时间大于8min。新手上路成长任务编辑入门编辑规则本人编辑我有疑问内容质疑在线客服官方贴吧意见反馈投诉建议举报不良信息未通过词条申诉投诉侵权信息封禁查询与解封©2024 Baidu 使用百度前必读 | 百科协议 | 隐私政策 | 百度百科合作平台 | 京ICP证030173号 京公网安备110000020000

C语言中printf 中 %f 和 %lf 的区别_printf 中使用 %lf 格式是不正确的-CSDN博客

>

C语言中printf 中 %f 和 %lf 的区别_printf 中使用 %lf 格式是不正确的-CSDN博客

C语言中printf 中 %f 和 %lf 的区别

最新推荐文章于 2022-10-06 21:48:11 发布

May Hacker

最新推荐文章于 2022-10-06 21:48:11 发布

阅读量2.4w

收藏

163

点赞数

63

分类专栏:

C语言

文章标签:

c语言

printf

c++

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/weixin_43889841/article/details/104106209

版权

C语言

专栏收录该内容

13 篇文章

6 订阅

订阅专栏

前言

其实这个问题就是错的,printf中根本没有%lf格式输出这一说,这是笔者自己常犯的错误,特此与大家分享一波。

scanf中的格式控制

printf中的格式控制

在printf中,无论是float类型还是double类型,输出都需要用%f,在有些系统中用%lf也不会出错,但是尽量还是按照标准来。

参考

《算法笔记》

优惠劵

May Hacker

关注

关注

63

点赞

163

收藏

觉得还不错?

一键收藏

知道了

7

评论

C语言中printf 中 %f 和 %lf 的区别

前言其实这个问题就是错的,printf中根本没有%lf格式输出这一说,这是笔者自己常犯的错误,特此与大家分享一波。scanf中的格式控制printf中的格式控制在printf中,无论是float类型还是double类型,输出都需要用%f,在有些系统中用%lf也不会出错,但是尽量还是按照标准来。...

复制链接

扫一扫

专栏目录

高级语言程序设计 (C语言)第三节课实践

04-22

一、实验目的

(1)能够使用C语言进行简单的算术运算、关系运算和逻辑运算。

(2)掌握不同的类型数据之间赋值的规行。

(3)进一步熟悉C语言程序的编辑、编 译和运行的过程。

二、实验原理

(技术原理:文字、图、表、公式等)

编写一个简单的C语言程序的源文件并编译该源文件、连接目标文件得到可执行文件,

然后运行可执行文件,即运行程序,查看程序运行结果。

三、实验过程

(详细写出具体的实验步骤:文字、公式计算、流程图、代码、实验结果)

任务一运行代码

#include

#include

int main()

{

int a=2,b=3;

float x=3.9,y=2.3;

float result;

result=(float)(a+b)/2+(int)x%(int)y;

printf("%lf",result);

return 0;

}

运行结果

任务二运行代码

#include

#include

int main()

{

int num;

int a1,a2,a3;

printf

为什么使用%lf读取double型的值,而用%f进行显示?

shenzhou111的专栏

08-03

9232

今天看到一篇好文章,mark一下。

出去旅游了一下,所以有些天没敲代码,于是又弱爆了~忘掉了题目中的东西,结果出现了问题,好难找哈~

死记硬背是很难记住一些东西的,只有理解原理才记得深入!

 

 

注意scanf函数和printf函数是不同寻常的函数,因为它们都没有将函数的参数限制为固定数量。scanf函数和printf函数又可变长度的参数列表。当调用带可变长度参数列表的函数时,编译器会

7 条评论

您还未登录,请先

登录

后发表或查看评论

c语言 printf 输出double %lf,C++玄学问题 关于printf输出double类型显示0.000000的原因...

weixin_39692830的博客

05-19

5466

运行环境 win10 codeblocks 17.12一、 C++ double类型用 %lf 格式输出【输出错误】:-0.000000 二、 C++ double类型用 %f 格式输出【输出正确】 三、 C语言 double类型用 %lf 或 %f 格式输出 【均输出正确】这让我感到十分玄学,为什么第一种输出就不对了呢,double类型为什么不能写%lf输出?(编译器选用 dev c++ 或者 ...

C/C++中printf中的%f和%lf格式的区别

学习永无止境

03-15

5374

刚写了一道算法题,我用的是double类型的数据,输出用的是%lf,结果总是报错,后面发现改成%f就通过了,再去深究,才发现这个细节,所以做下笔记。

首先,来看一下scanf和printf的输出格式:

对,你没看错,scanf中对于float和double类型是有区分的,即前者是用的%f,后者是用的%lf,但是到了printf,则统一都是%f,对于这个小细节,我自己用的编译器——jetbrain中的clion好像是自动处理,并没有给我报错,所以我之前一直都是以为scanf和printf都是一样的处理方法

用C语言来求三角形面积

最新发布

10-18

C语言求三角形面积

方法一:使用海伦公式

#include

#include

double calcArea(double a, double b, double c) {

double s = (a + b + c) / 2;

return sqrt(s * (s - a) * (s - b) * (s - c));

}

int main() {

double a, b, c;

printf("请输入三角形的三边长:\n");

scanf("%lf %lf %lf", &a, &b, &c);

double area = calcArea(a, b, c);

printf("三角形的面积为:%lf\n", area);

return 0;

}

方法二:使用向量法

#include

#include

typedef struct {

double x;

double y;

} Vector;

doubl

【小细节】关于printf中%lf占位符的问题

A's World

01-17

2764

为什么printf()用%f输出double型,而scanf却用%lf呢

c语言printf双精度还需要lf,printf()的最终解释是详细解释

weixin_42524171的博客

05-19

3260

printf()是一种C语言标准库函数,用于将格式化的字符串输出到标准输出. 标准输出是标准输出文件,与终端的屏幕相对应. 在stdio.h头文件中声明了printf().功能原型:int printf ( const char * format, ... );返回值: 返回正确输出的字符总数,并且错误返回负值. 同时,将设置输入和输出流错误标志. 指示器ferror可用于检查输入和输出流错误标志...

c语言 printf 输出double %lf,为什么printf()用%f输出double型,而scanf却用%lf呢?

weixin_42299346的博客

05-19

6348

之前没有注意过这个问题, 转自:http://book.51cto.com/art/200901/106880.htm问:有人告诉我不能在printf中使用%lf。为什么printf()用%f输出double型,而scanf却用%lf呢?答:printf的%f说明符的确既可以输出float型又可以输出double型。 根据"默认参数提升"规则(在printf这样的函数的可变参数列表中 ,不论作...

C语言使用printf(“%lf“)输出double类型显示-0.000000问题,CodeBlocks

q2972112的博客

10-06

3474

C语言使用printf函数和"%lf"输出double类型显示-0.000000问题,CodeBlocks

c语言编写printf函数,C语言之printf函数详解

weixin_33649132的博客

05-19

3142

一 基本用法格式化控制符:%d %c %ld %lf意思是:相当于在要输出的语句里面挖了一个坑,也就是在内存中开辟空间,然后再那个坑的位置(也就是开辟好的空间),填上你想要显示的值printf("%d\n",age);printf("%c\n",ch);printf("%f\n",f);printf("%ld\n",lNum);printf("%lf\n",d);%d:代表挖一个int类型的坑,...

c语言计算三角形面积代码

01-01

代码如下://面积公式s = (a+b+c) / 2   area = sqrt(s * (s – a) * (s – b) * (s – c));//小作业 求三角形的面积

int check(double a);int check2(double a, double b, double c);

#include #include int main(void){    double area = 0;    double s;    double a,b,c;    printf(“请输入三角形的三边的长(a b c):”);    scanf(“%lf %

c语言double类型默认输出小数几位

12-20

C语言中常用的小数有两种类型,分别是 float 或 double;float 称为单精度浮点型,double 称为双精度浮点型。不像整数,小数没有那么多幺蛾子,小数的长度是固定的,float 始终占用4个字节,double 始终占用8个字节。

c语言double类型默认输出几位小数?

C语言中,输出double类型(双精度实型)以及float类型(单精度实型)时,默认输出6位小数(不足六位以 0 补齐,超过六位按四舍五入截断)。

double a = 1;

printf("%lf\n", a);

输出会是:

1.000000

但是有时六位会显得很长,没必要。比如计算平均分,一到两位小数

你必须知道的495个C语言问题

05-08

第1章 声明和初始化

基本类型

1.1 我该如何决定使用哪种整数类型?

1.2 为什么不精确定义标准类型的大小?

1.3 因为C语言没有精确定义类型的大小,所以我一般都用typedef定义int16和int32。然后根据实际的机器环境把它们定义为int、short、long等类型。这样看来,所有的问题都解决了,是吗?

1.4 新的64位机上的64位类型是什么样的?

指针声明

1.5 这样的声明有什么问题?char*p1,p2;我在使用p2的时候报错了。

1.6 我想声明一个指针,并为它分配一些空间,但却不行。这样的代码有什么问题?char*p;*p=malloc(10);

声明风格

1.7 怎样声明和定义全局变量和函数最好?

1.8 如何在C中实现不透明(抽象)数据类型?

1.9 如何生成“半全局变量”,就是那种只能被部分源文件中的部分函数访问的变量?

存储类型

1.10 同一个静态(static)函数或变量的所有声明都必需包含static存储类型吗?

1.11 extern在函数声明中是什么意思?

1.12 关键字auto到底有什么用途?

类型定义(typedef)

1.13 对于用户定义类型,typedef和#define有什么区别?

1.14 我似乎不能成功定义一个链表。我试过typedefstruct{char*item;NODEPTRnext;}*NODEPTR;但是编译器报了错误信息。难道在C语言中结构不能包含指向自己的指针吗?

1.15 如何定义一对相互引用的结构?

1.16 Struct{ }x1;和typedefstruct{ }x2;这两个声明有什么区别?

1.17 “typedefint(*funcptr)();”是什么意思?

const限定词

1.18 我有这样一组声明:typedefchar*charp;constcharpp;为什么是p而不是它指向的字符为const?

1.19 为什么不能像下面这样在初始式和数组维度值中使用const值?constintn=5;inta[n];

1.20 constchar*p、charconst*p和char*constp有什么区别?

复杂的声明

1.21 怎样建立和理解非常复杂的声明?例如定义一个包含N个指向返回指向字符的指针的函数的指针的数组?

1.22 如何声明返回指向同类型函数的指针的函数?我在设计一个状态机,用函数表示每种状态,每个函数都会返回一个指向下一个状态的函数的指针。可我找不到任何方法来声明这样的函数——感觉我需要一个返回指针的函数,返回的指针指向的又是返回指针的函数……,如此往复,以至无穷。

数组大小

1.23 能否声明和传入数组大小一致的局部数组,或者由其他参数指定大小的参数数组?

1.24 我在一个文件中定义了一个extern数组,然后在另一个文件中使用,为什么sizeof取不到数组的大小?

声明问题

1.25 函数只定义了一次,调用了一次,但编译器提示非法重声明了。

*1.26 main的正确定义是什么?voidmain正确吗?

1.27 我的编译器总在报函数原型不匹配的错误,可我觉得没什么问题。这是为什么?

1.28 文件中的第一个声明就报出奇怪的语法错误,可我看没什么问题。这是为什么?

1.29 为什么我的编译器不允许我定义大数组,如doublearray[256][256]?

命名空间

1.30如何判断哪些标识符可以使用,哪些被保留了?

初始化

1.31 对于没有显式初始化的变量的初始值可以作怎样的假定?如果一个全局变量初始值为“零”,它可否作为空指针或浮点零?

1.32 下面的代码为什么不能编译?intf(){chara[]="Hello,world!";}

*1.33 下面的初始化有什么问题?编译器提示“invalidinitializers”或其他信息。char*p=malloc(10);

1.34 chara[]="stringliteral";和char*p="stringliteral";初始化有什么区别?当我向p[i]赋值的时候,我的程序崩溃了。

1.35 chara{[3]}="abc";是否合法?

1.36 我总算弄清楚函数指针的声明方法了,但怎样才能初始化呢?

1.37 能够初始化联合吗?

第2章 结构、联合和枚举

结构声明

2.1 structx1{ };和typedefstruct{ }x2;有什么不同?

2.2 这样的代码为什么不对?structx{ };xthestruct;

2.3 结构可以包含指向自己的指针吗?

2.4 在C语言中用什么方法实现抽象数据类型最好?

*2.5 在C语言中是否有模拟继承等面向对象程序设计特性的好方法?

2.6 为什么声明externf(structx*p);给我报了一个晦涩难懂的警告信息?

2.7 我遇到这样声明结构的代码:structname{intnamelen;charnamestr[1];};然后又使用一些内存分配技巧使namestr数组用起来好像有多个元素,namelen记录了元素个数。它是怎样工作的?这样是合法的和可移植的吗?

2.8 我听说结构可以赋给变量也可以对函数传入和传出。为什么K&R1却明确说明不能这样做?

2.9 为什么不能用内建的==和!=操作符比较结构?

2.10结构传递和返回是如何实现的?

2.11 如何向接受结构参数的函数传入常量值?怎样创建无名的中间的常量结构值?

2.12 怎样从/向数据文件读/写结构?

结构填充

2.13 为什么我的编译器在结构中留下了空洞?这导致空间浪费而且无法与外部数据文件进行“二进制”读写。能否关掉填充,或者控制结构域的对齐方式?

2.14 为什么sizeof返回的值大于结构大小的期望值,是不是尾部有填充?

2.15 如何确定域在结构中的字节偏移量?

2.16 怎样在运行时用名字访问结构中的域?

2.17 C语言中有和Pascal的with等价的语句吗?

2.18 既然数组名可以用作数组的基地址,为什么对结构不能这样?

2.19 程序运行正确,但退出时却“coredump”(核心转储)了,怎么回事?

联合

2.20 结构和联合有什么区别?

2.21 有办法初始化联合吗?

2.22 有没有一种自动方法来跟踪联合的哪个域在使用?

枚举

2.23 枚举和一组预处理的#define有什么不同?

2.24 枚举可移植吗?

2.25 有什么显示枚举值符号的容易方法吗?

位域

2.26 一些结构声明中的这些冒号和数字是什么意思?

2.27 为什么人们那么喜欢用显式的掩码和位操作而不直接声明位域?

第3章 表达式

求值顺序

3.1 为什么这样的代码不行?a[i]=i++;

3.2 使用我的编译器,下面的代码inti=7;printf("%d\n",i++*i++);打印出49。不管按什么顺序计算,难道不该是56吗?

3.3 对于代码inti=3;i=i++;不同编译器给出不同的i值,有的为3,有的为4,哪个是正确的?

*3.4 有这样一个巧妙的表达式:a^=b^=a^=b;它不需要临时变量就可以交换a和b的值。

3.5 可否用显式括号来强制执行我所需要的计算顺序并控制相关的副作用?就算括号不行,操作符优先级是否能够控制计算顺序呢?

3.6 可是&&和||操作符呢?我看到过类似while((c=getchar())!=EOF&&c!='\n')的代码……

3.7 是否可以安全地认为,一旦&&和||左边的表达式已经决定了整个表达式的结果,则右边的表达式不会被求值?

3.8 为什么表达式printf("%d%d",f1(),f2());先调用了f2?我觉得逗号表达式应该确保从左到右的求值顺序。

3.9 怎样才能理解复杂表达式并避免写出未定义的表达式?“序列点”是什么?

3.10在a[i]=i++;中,如果不关心a[]的哪一个分量会被写入,这段代码就没有问题,i也的确会增加1,对吗?

3.11 人们总是说i=i++的行为是未定义的。可我刚刚在一个ANSI编译器上尝试过,其结果正如我所期望的。

3.12 我不想学习那些复杂的规则,怎样才能避免这些未定义的求值顺序问题呢?

其他的表达式问题

*3.13 ++i和i++有什么区别?

3.14 如果我不使用表达式的值,那我应该用i++还是++i来做自增呢?

3.15 我要检查一个数是不是在另外两个数之间,为什么if(abc)不行?

3.16 为什么如下的代码不对?inta=1000,b=1000;longintc=a*b;

3.17 为什么下面的代码总是给出0?doubledegC,degF;degC=5.0/9*(degF-32);

3.18 需要根据条件把一个复杂的表达式赋给两个变量中的一个。可以用下面这样的代码吗?((condition)?a:b)=complicated_expression;

3.19 我有些代码包含这样的表达式。a?b=c:d有些编译器可以接受,有些却不能。为什么?

保护规则

3.20 “semanticsof‘’changeinANSIC”的警告是什么意思?

3.21 “无符号保护”和“值保护”规则的区别在哪里?

第4章 指针

基本的指针应用

4.1 指针到底有什么好处?

4.2 我想声明一个指针并为它分配一些空间,但却不行。这些代码有什么问题呢?char*p;*p=malloc(10);

4.3 *p++自增p还是p所指向的变量?

指针操作

4.4 我用指针操作int数组的时候遇到了麻烦。

4.5 我有一个char*型指针碰巧指向一些int型变量,我想跳过它们。为什么((int*)p)++;这样的代码不行?

4.6 为什么不能对void*指针进行算术操作?

4.7 我有些解析外部结构的代码,但是它却崩溃了,显示出了“unalignedaccess”(未对齐的访问)的信息。这是什么意思?

作为函数参数的指针

4.8 我有个函数,它应该接受并初始化一个指针:voidf(int*ip){staticintdummy=5;ip=&dummy;}但是当我如下调用时:int*ip;f(ip);调用者的指针没有任何变化。

4.9 能否用void**通用指针作为参数,使函数模拟按引用传递参数?

4.10 我有一个函数externintf(int*);,它接受指向int型的指针。我怎样用引用方式传入一个常数?调用f(&5);似乎不行。

4.11 C语言可以“按引用传参”吗?

其他指针问题

4.12 我看到了用指针调用函数的不同语法形式。到底怎么回事?

4.13 通用指针类型是什么?当我把函数指针赋向void*类型的时候,编译通不过。

4.14 怎样在整型和指针之间进行转换?能否暂时把整数放入指针变量中,或者相反?

*4.15 我怎样把一个int变量转换为char*型?我试了类型转换,但是不行。

第5章 空指针

空指针和空指针常量

5.1 臭名昭著的空指针到底是什么?

5.2 怎样在程序里获得一个空指针?

5.3 用缩写的指针比较“if(p)”检查空指针是否有效?如果空指针的内部表达不是0会怎样?

NULL宏

5.4 NULL是什么,它是怎么定义的?

5.5 在使用非零位模式作为空指针的内部表示的机器上,NULL是如何定义的?

5.6 如果NULL定义成#defineNULL((char*)0),不就可以向函数传入不加转换的NULL了吗?

5.7 我的编译器提供的头文件中定义的NULL为0L。为什么?

5.8 NULL可以合法地用作函数指针吗?

5.9 如果NULL和0作为空指针常量是等价的,那我到底该用哪一个呢?

5.10但是如果NULL的值改变了,比如在使用非零内部空指针的机器上,用NULL(而不是0)

不是更好吗?

5.11 我曾经使用过一个编译器,不使用NULL就不能编译。

5.12 我用预处理宏#defineNullptr(type)(type*)0帮助创建正确类型的空指针。

回顾 59

5.13 这有点奇怪:NULL可以确保是0,但空(null)指针却不一定?

5.14 为什么有那么多关于空指针的疑惑?为什么这些问题如此频繁地出现?

5.15 有没有什么简单点儿的办法理解所有这些与空指针有关的东西呢?

5.16 考虑到有关空指针的所有这些困惑,要求它们的内部表示都必须为0不是更简单吗?

5.17 说真的,真有机器用非零空指针吗,或者不同类型用不同的表示?

地址0上到底有什么?

5.18 运行时的整数值0转换为指针以后一定是空指针吗?

5.19 如何访问位于机器地址0处的中断向量?如果我将指针值设为0,编译器可能会自动将它转换为非零的空指针内部表示。

5.20运行时的“nullpointerassignment”错误是什么意思?应该怎样捕捉它?

第6章 数组和指针

数组和指针的基本关系

6.1 我在一个源文件中定义了chara[6],在另一个源文件中声明了externchar*a。为什么不行?

6.2 可是我听说chara[]和char*a是等价的。是这样的吗?

6.3 那么,在C语言中“指针和数组等价”到底是什么意思?

6.4 既然它们这么不同,那为什么作为函数形参的数组和指针声明可以互换呢?

数组不能被赋值

6.5 为什么不能这样向数组赋值?externchar*getpass();charstr[10];str=getpass("Enterpassword:");

6.6 既然不能向数组赋值,那这段代码为什么可以呢?intf(charstr[]){if(str[0]=='\0')str="none";…}

6.7 如果你不能给它赋值,那么数组如何能成为左值呢?

回顾

6.8 现实地讲,数组和指针的区别是什么?

6.9 有人跟我讲,数组不过是常指针。这样讲准确吗?

6.10 我还是很困惑。到底指针是一种数组,还是数组是一种指针?

6.11 我看到一些“搞笑”的代码,包含5["abcdef"]这样的“表达式”。这为什么是合法的C语言表达式呢?

数组的指针

6.12 既然数组引用会退化为指针,如果array是数组,那么array和&array又有什么区别呢?

6.13 如何声明一个数组的指针?

动态数组分配

6.14 如何在运行时设定数组的大小?怎样才能避免固定大小的数组?

6.15 我如何声明大小和传入的数组一样的局部数组?

6.16 如何动态分配多维数组?

6.17 有个很好的窍门,如果我这样写:intrealarray[10];int*array=&realarray[-1];我就可以把“array”当作下标从1 开始的数组。

函数和多维数组

6.18 当我向一个接受指针的指针的函数传入二维数组的时候,编译器报错了。

6.19 我怎样编写接受编译时宽度未知的二维数组的函数?

6.20 我怎样在函数参数传递时混用静态和动态多维数组?

数组的大小

6.21 当数组是函数的参数时,为什么sizeof不能正确报告数组的大小?

6.22 如何在一个文件中判断声明为extern的数组的大小(例如,数组定义和大小在另一个文件中)?sizeof操作符似乎不行。

6.23 sizeof返回的大小是以字节计算的,怎样才能判断数组中有多少个元素呢?

第7章 内存分配

基本的内存分配问题

7.1 为什么这段代码不行?char*answer;printf("Typesomething:\n");gets(answer);printf("Youtyped\"%s\"\n",answer);

7.2 我的strcat()不行。我试了下面的代码:char*s1="Hello,";char*s2="world!";char*s3=strcat(s1,s2);但是我得到了奇怪的结果。

7.3 但是strcat的文档说它接受两个char*型参数。我怎么知道(空间)分配的事情呢?

*7.4 我刚才试了这样的代码:char*p;strcpy(p,"abc");它运行正常。怎么回事?为什么它没有出错?

*7.5 一个指针变量分配多少内存?

7.6 我使用fgets将文件的所有行读入一个数组,为什么读入的每一行都是最后一行的内容呢?

7.7 我有个函数,本该返回一个字符串,但当它返回调用者的时候,返回的字符串却是垃圾信息。

为什么?

*7.8 那么返回字符串或其他聚集的正确方法是什么呢?

调用malloc

7.9 为什么在调用malloc()时报出了“waring:assignmentofpointerfromintegerlacksacast”?

7.10为什么有些代码小心翼翼地把malloc返回的值转换为分配的指针类型?

*7.11 在调用malloc()的时候,错误“不能把void*转换为int*”是什么意思?

7.12 我看到下面这样的代码:char*p=malloc(strlen(s)+1);strcpy(p,s);难道不应该是malloc((strlen(s)+1)*sizeof(char))吗?

7.13 我为malloc写了一个小小的封装函数。它为什么不行?

7.14 我想声明一个指针并向它分配一些内存,但是不行。这样的代码有什么问题?char*p;*p=malloc(10);

7.15 我如何动态分配数组?

7.16 怎样判断还有多少内存?

7.17 malloc(0)是返回空指针还是指向0个字节的指针?

7.18 我听说有的操作系统在程序使用的时候才真正分配malloc申请的内存。这合法吗?

有关malloc的问题

7.19 为什么malloc返回了离谱的指针值?我的确读过问题7.9,而且也在调用之前包含了externvoid*malloc();声明。

7.20 我用一行这样的代码分配一个巨大的数组,用于数值运算:double*array=malloc(256 *256 *sizeof(double));malloc()并没有返回空指针,但是程序运行得有些奇怪,好像改写了某些内存,或者malloc()并没有分配我申请的那么多内存。为什么?

7.21 我的PC机有8兆内存。为什么我只能分配640K左右的内存?

7.22 我的应用程序非常依赖数据结构的节点的动态分配,而malloc/free的代价成了瓶颈。我该怎么做?

7.23 我的程序总是崩溃,显然发生在malloc内部的某个地方。但是我看不出哪里有问题。是malloc有bug吗?

释放内存

7.24 动态分配的内存一旦释放之后就不能再使用,是吧?

7.25 为什么在调用free()之后指针没有变空?使用(赋值、比较)释放之后的指针有多么不安全?

7.26 当我调用malloc()为一个函数的局部指针分配内存时,我还需要用free()显式地释放吗?

7.27 我在分配一些结构,它们包含指向其他动态分配的对象的指针。我在释放结构的时候,还需要释放每一个下级指针吗?

7.28 我必须在程序退出之前释放分配的所有内存吗?

7.29 我有个程序分配了大量的内存,然后又释放了。但是从操作系统看,内存的占用率却并没有变回去。

分配内存块的大小

7.30 free()怎么知道有多少字节需要释放?

7.31 那么我能否查询malloc包,以查明可分配的最大块是多大?

7.32 为什么sizeof不能告诉我它所指的内存块的大小?

其他分配函数

7.33 (像问题6.14中那样)动态分配数组之后,还能改变它的大小吗?

7.34 向realloc()的第一个参数传入空指针合法吗?你为什么要这样做?

7.35 calloc()和malloc()有什么区别?应该用哪一个?利用calloc的零填充功能安全吗?free()可以释放calloc()分配的内存吗,还是需要一个cfree()?

7.36 alloca是什么?为什么不提倡使用它?

第8章 字符和字符串

8.1 为什么strcat(string,'!');不行?

8.2 我想检查一个字符串是否跟某个值匹配。为什么这样不行?if(string=="value")

8.3 如果我可以写chara[]="Hello,world!";那为什么不能写chara[14];a="Hello,world!";

8.4 为什么我的strcat不行?我试了char*s1="Hello,";char*s2="world!";char*s3 =strcat(s1,s2);可得到的结果很奇怪。

8.5 chara[]="stringliteral";和char*p="stringliteral";初始化有什么区别?当我对p[i]赋值的时候,程序崩溃了。

8.6 我怎么得到与字符相对应的数字(即ASCII或其他字符集下的)值?反过来又该怎么做?

8.7 C语言有类似其他语言的"substr"(提取子串)这样的函数吗?

8.8 我将用户键入的字符串读入数组,然后再显示出来。当用户键入\n这样的序列时,为什么不能正确处理呢?

8.9 我注意到sizeof('a')是2而不是1(即不是sizeof(char)),是不是我的编译器有问题?

8.10 我正开始考虑多语言字符集的问题。是否有必要担心sizeof(char)会被定义为2,以便表达16位的字符集呢?

第9章 布尔表达式和变量

9.1 C语言中布尔值该用什么类型?为什么它不是一个标准类型?我应该用#define或enum定义真值和假值吗?

9.2 既然在C语言中所有的非零值都被看作“真”,那是不是把TRUE定义为1很危险?如果某个内建的函数或关系操作符“返回”不是1的其他值怎么办?

9.3 当p是指针时,if(p)是合法的条件表达式吗?

9.4 我该使用像TRUE和FALSE这样的符号名称还是直接用1和0来作布尔常量?

9.5 我准备使用的一个第三方头文件定义了自己的TRUE和FALSE,它们跟我已经开发的部分不兼容。我该怎么办?

第10章 C预处理器

宏定义

10.1 我想定义一些函数式的宏,例如:#definesquare(x)x*x但它们并不总是正确的。为什么?

10.2 这里有一些的预处理宏,使用它们,我可以写出更像Pascal的C代码。你觉得怎么样?

10.3 怎么写一个交换两个值的通用宏?

10.4 书写多语句宏的最好方法是什么?

10.5 用typdef和预处理宏生成用户定义类型有什么区别?

头文件

10.6 我第一次把一个程序分成多个源文件,我不知道该把什么放到.c文件,把什么放到.h文件。(“.h”到底是什么意思?)

10.7 可以在一个头文件中包含另一头文件吗?

10.8 完整的头文件搜索规则是怎样的?

10.9 我在文件的第一个声明就遇到奇怪的语法错误,但是看上去没什么问题。

10.10 我使用了来自两个不同的第三方库的头文件,它们都定义了相同的宏,如TRUE、FALSE、Min()和Max()等,但是它们的定义相互冲突,而且跟我在自己的头文件中的定义也有冲突。我该怎么办?

10.11 我在编译一个程序,看起来我好像缺少需要的一个或多个头文件。谁能发给我一份?

条件编译

10.12 怎样构造比较字符串的#if预处理表达式?

10.13 sizeof操作符可以用在#if预处理指令中吗?

10.14 我可以像这样在#define行里使用#ifdef来定义两个不同的东西吗?

10.15 对typedef的类型定义有没有类似#ifdef的东西?

10.16 我如何用#if表达式来判断机器是高字节在前还是低字节在前?

10.17 为什么在我用#ifdef关掉的代码行中报出了奇怪的语法错误?

10.18 我拿到了一些代码,里边有太多的#ifdef。我不想使用预处理器把所有的#include和#ifdef都扩展开,有什么办法只保留一种条件的代码呢?

10.19 如何列出所有的预定义宏?

奇异的处理

10.20 我有些旧代码,试图用这样的宏来构造标识符:#definePaste(a,b)a/**/b但是不行了。为什么?

10.21 我有一个旧宏:#defineCTRL(c)('c'&037)不能用了。为什么?

10.22 为什么宏#defineTRACE(n)printf("TRACE:\%d\n",n)报出警告“macroreplacementwithinastringliteral”?它似乎把TRACE(count);扩展成了printf("TRACE:\%d\count",count);

10.23 如何在宏扩展的字符串字面量中使用宏参数?

10.24 我想用ANSI的“字符串化”预处理操作符#将符号常量的值放入消息中,但它总是对宏名称而不是它的值进行字符串化。这是什么原因?

10.25 我想用预处理器做某件事情,但却不知道如何下手。

可变参数列表的宏

10.26 怎样写可变参数宏?如何用预处理器“关掉”具有可变参数的函数调用?

10.27 如何在通用的调试宏中包含__FILE__和__LINE__宏?

第11章 ANSI/ISO标准C

标准

11.1 什么是“ANSIC标准”?

11.2 如何得到一份标准的副本?

*11.3 我在哪里可以找到标准的更新?

函数原型

11.4 为什么我的ANSI编译器对用float声明的参数会警告类型不匹配?

11.5 能否混用旧式的和新型的函数语法?

*11.6 为什么下述声明报出了一个奇怪的警告信息“StructXdeclaredinsideparameterlist”?externintf(structx*p);

11.7 有个问题一直困扰着我,它是由这一行printf("%d",n);导致的,因为n是个longint型。难道ANSI的函数原型不能检查这种函数的参数不匹配问题吗?

11.8 我听说必须在调用printf之前包含stdio.h。为什么?

const限定词

11.9 为什么不能在初始化和数组维度中使用const值?例如constintn=5;inta[n];

11.10“constchar*p”、“charconst*p”和“char*constp”有何区别?

11.11 为什么不能向接受constchar**的函数传入char**?

11.12 我这样声明:typedefchar*charp;constcharpp;为什么是p而不是它所指向的字符为const?

main()函数的使用

11.13 能否通过将main声明为void来关掉“main没有返回值”的警告?

11.14 main()的第3个参数envp是怎么回事?

11.15 我觉得把main()声明为void也不会失败,因为我调用了exit()而不是return,况且我的操作系统也忽略了程序的退出/返回状态。

*11.16 那么到底会出什么问题?真的有什么系统不支持voidmain()吗?

11.17 为什么以前流行的那些C语言书总是使用voidmain()?

11.18 在main()中调用exit(status)和返回同样的status真的等价吗?

预处理功能

11.19 我试图用ANSI“字符串化”预处理操作符'#'向信息中插入符号常量的值,但它字符串化的总是宏的名字而不是它的值。为什么?

11.20 警告信息“warning:macroreplacementwithinastringliteral”是什么意思?

11.21 为什么在我用#ifdef去掉的代码里出现了奇怪的语法错误?

11.22 #pragma是什么,有什么用?

11.23 “#pragmaonce”什么意思?我在一些头文件中看到了它。

其他的ANSIC问题

11.24 chara[3]="abc";合法吗?它是什么意思?

11.25 既然对数组的引用会退化为指针,那么,如果array是数组,array和&array之间有什么区别呢?

11.26 为什么我不能对void*指针进行算术运算?

11.27 memcpy()和memmove()有什么区别?

11.28 malloc(0)有什么用?返回一个空指针还是指向0字节的指针?

11.29 为什么ANSI标准规定了外部标识符的长度和大小写限制?

11.30 noalias是怎么回事?在它身上发生了什么?

老的或非标准的编译器

11.31 为什么我的编译器对最简单的测试程序都报出了一大堆的语法错误?对这段代码的第一行就报错了:main(intargc.char**argv){return0;}

11.32 为什么有些ASNI/ISO标准库函数未定义?我明明使用的就是ANSI编译器。

11.33 谁有可以在旧的C程序和ANSIC之间相互转换的工具,或者自动生成原型的工具?

11.34 为什么声称兼容ANSI的编译器不能编译这些代码?我知道这些代码是ANSI的,因为gcc可以编译。

兼容性

11.35 人们好像有些在意实现定义的(implementation-defined)、不确定的(unspecified)和未定义的(undefined)行为的区别。它们的区别到底在哪里?

*11.36 一个程序“合法(legal)”、“有效(valid)”或“符合标准的”(conforming)到底是什么意思?

11.37 我很吃惊,ANSI标准竟然有那么多未定义的东西。标准的唯一任务不就是让这些东西标准化吗?

11.38 有人说i=i++的行为是未定义的,但是我刚在一个兼容ANSI的编译器上测试,得到了我希望的结果。它真的是未定义的吗?

第12章 标准输入输出库

基本输入输出

12.1 这样的代码有什么问题?charc;while((c=getchar())!=EOF)

12.2 我有个读取直到EOF的简单程序,但是我如何才能在键盘上输入那个“\EOF”呢?我看stdio.h中定义的EOF是-1,是不是说我该输入-1?

12.3 为什么这些代码把最后一行复制了两遍?while(!feof(infp)){fgets(buf,MAXLINE,infp);fputs(buf,outfp);}

12.4 我用fgets将文件的每行内容读入指针数组。为什么结果所有的行都是最后一行的内容呢?

12.5 我的程序的屏幕提示和中间输出有时没有在屏幕上显示,尤其是当我用管道通过另一个程序输出的时候。为什么?

12.6 我怎样才能不等待回车键而一次输入一个字符?

printf格式

12.7 如何在printf的格式串中输出一个'%'字符?我试过\%,但是不行。

12.8 为什么这么写不对?longintn=123456;printf("%d\n",n);

12.9 有人告诉我不能在printf中使用%lf。为什么printf()用%f输出double型,而scanf却用%lf呢?

*12.10 对于size_t那样的类型定义,当我不知道它到底是long还是其他类型的时候,我应该使用什么样的printf格式呢?

12.11 如何用printf实现可变的域宽度?就是说,我想在运行时确定宽度而不是使用%8d?

12.12 如何输出在千位上用逗号隔开的数字?货币格式的数字呢?

12.13 为什么scanf("%d",i)调用不行?

*12.14 为什么chars[30];scamf("%s",s);不用&也可以?我原以为传给scanf的每个变量都要带&。

12.15 为什么这些代码不行?doubled;scanf("%f",&d);

12.16 为什么这段代码不行?shortints;scanf("%d",&s);

12.17 怎样在scanf格式串中指定可变的宽度?

12.18 怎样从特定格式的数据文件中读取数据?怎样读入10个float而不用使用包含10次%f的奇怪格式?如何将一行的任意多个域读入一个数组中?

scanf问题

12.19 我像这样用"%d\n"调用scanf从键盘读取数字:intn;scanf("%d\n",&n);printf("youtyped%d\n",n);好像要多输入一行才返回。为什么?

12.20 我用scanf和%d读取一个数字,然后再用gets()读取字符串,但是编译器好像跳过了gets()调用!

12.21 我发现如果坚持检查返回值以确保用户输入的是我期待的数值,则scanf的使用会安全很多。但有的时候好像会陷入无限循环。为什么?

12.22 为什么大家都说不要使用scanf?那我该用什么来代替呢?

其他stdio函数

12.23 我怎样才知道对于任意的sprintf调用需要多大的目标缓冲区?怎样才能避免sprintf目标缓冲区溢出?

12.24 sprintf的返回值是什么?是int还是char*?

12.25 为什么大家都说不要使用gets?

12.26 我觉得我应该在一长串的printf调用之后检查errno,以确定是否有失败的调用。为什么当我将输出重定向到文件的时候会输出奇怪的“printffailed:Notatypewriter”信息?

12.27 fgetops/fsetops和ftell/fseek之间有什么区别?fgetops和fsetops到底有什么用处?

12.28 如何清除用户的多余输入,以防止在下一个提示符下读入?用fflush(stdin)可以吗?

打开和操作文件

12.29 我写了一个函数用来打开文件:myfopen(char*filename,FILE*fp){fp=fopen(filename,"r");}可我这样调用的时候:FILE*infp;myfopen("filename.dat",infp);,infp指针并没有正确设置。为什么?

12.30 连一个最简单的fopen调用都不成功!这个调用有什么问题?FILE*fp=fopen(filename,'r');

12.31 为什么我不能用完整路径名打开一个文件?这个调用总是失败:fopen("c:\newdir\file.dat","r");

12.32 我想用fopen模式"r+"打开一个文件,读出一个字符串,修改之后再写入,从而就地更新一个文件。可是这样不行。为什么?

12.33 如何在文件中间插入或删除一行(一条记录)?

12.34 怎样从打开的流中恢复文件名?

重定向stdin和stdout

12.35 怎样在程序里把stdin或stdout重定向到文件?

12.36 一旦使用freopen之后,怎样才能恢复原来的stdout(或stdin)?

12.37 如何判断标准输入或输出是否经过了重定向,即是否在命令行上使用了“”或“”?

12.38 我想写个像"more"那样的程序。怎样才能在stdin被重定向之后再回到交互键盘?

*12.39 怎样同时向两个地方输出,如同时输出到屏幕和文件?

“二进制”输入输出

12.40 我希望按字节在内存和文件之间直接读写数字,而不像fprintf和fscanf进行格式化。我该怎么办?

12.41 怎样正确地读取二进制文件?有时看到0x0a和0x0d容易混淆,而且如果数据中包含0x1a的话,我好像会提前遇到EOF。

12.42 我在写一个二进制文件的“过滤器”,但是stdin和stdout却被作为文本流打开了。怎样才能把它们的模式改为二进制?

12.43 文本和二进制输入输出有什么区别?

12.44 如何在数据文件中读写结构?

12.45 怎样编写符合旧的二进制数据格式的代码?

第13章 库函数

字符串函数

13.1 怎样把数字转为字符串(与atoi相反)?有itoa函数吗?

13.2 为什么strncpy不能总在目标串放上终止符'\0'?

13.3 C语言有类似于其他语言中的“substr”(取出子串)的例程吗?

13.4 怎样把一个字符串中所有字符转换成大写或小写?

13.5 为什么有些版本的toupper对大写字符会有奇怪的反应?为什么有的代码在调用toupper前先调用islower?

13.6 怎样将字符串分割成用空白分隔的字段?怎样实现类似main处理argc和argv的过程?

13.7 哪里可以找到处理正则表达式或通配符匹配的代码?

排序

13.8 我想用strcmp作为比较函数,调用qsort对一个字符串数组排序,但是不行。为什么?

13.9 我想用qsort()对一个结构数组排序。我的比较函数接受结构指针,但是编译器认为这个函数不是qsort需要的类型。我要怎样转换这个函数指针才能避免这样的警告?

13.10 怎样对一个链表排序?

13.11 怎样对大于内存容量的数据排序?

日期和时间

13.12 怎样在C程序中取得当前日期或时间?

13.13 我知道库函数localtime可以把time_t转换成结构structtm,而ctime可以把time_t转换成为可打印的字符串。怎样才能进行反向操作,把structtm或一个字符串转换成time_t?

13.14 怎样在日期上加n天?怎样取得两个日期的时间间隔?

随机数

13.15 怎么生成一个随机数?

13.16 怎样获得某一范围内的随机整数?

13.17 每次执行程序,rand都返回相同的数字序列。为什么?

13.18 我需要随机的真/假值,所以我就直接用rand()%2,可是我得到交替的0,1,0,1,0…。为什么? 164

13.19 如何获取根本不重复的随机数?

13.20 怎样产生正态分布或高斯分布的随机数?

13.21 我在移植一个程序,里边调用了一个函数drand48 ,而我的库又没有这个。这是个什么函数?

其他库函数

13.22 exit(status)是否真的跟从main函数返回status等价?

13.23 memcpy和memmove有什么区别?

13.24 我想移植这个旧程序。为什么报出这些“undefinedexternal”错误:index?、rindex?、bcopy?、bcmp?、bzero??

13.25 我不断得到库函数未定义错误,但是我已经包含了所有用到的头文件了。

13.26 虽然我在连接时明确地指定了正确的函数库,我还是得到库函数未定义错误。

13.27 一个最简单的程序,不过在一个窗口里打印出“Hello,World”,为什么会编译出巨大的可执行代码(数百K)?我该少包含一些头文件吗?

13.28 连接器报告_end未定义代表什么意思?

*13.29 我的编译器提示printf未定义!这怎么可能?

第14章 浮点运算

14.1 一个float变量赋值为3.1时,为什么printf输出的值为3.0999999?

14.2 我想计算一些平方根,我把程序简化成这样:main(){printf("%f\h",sqrt(144.));可得到的结果却是疯狂的数字。为什么?

14.3 我想做一些简单的三角函数运算,也包含了math.h,但连接器总是提示sin、cos这样的函数未定义。为什么?

14.4 我的浮点数计算程序表现得很奇怪,在不同的机器上给出了不同的结果。为什么?

14.5 有什么好的方法来检查浮点数在“足够接近”情况下的相等?

14.6 怎样取整?

14.7 为什么C语言不提供乘幂的操作符?

14.8 为什么我机器上的math.h没有预定义常量M_PI?

14.9 怎样将变量置为IEEENaN(“NotaNumber”)或检测变量是否为NaN及其他特殊值?

14.10 如何简洁地处理浮点异常?

14.11 在C语言中如何很好地实现复数?

14.12 我要寻找一些实现以下功能的程序源代码:快速傅立叶变换(FFT)、矩阵算术(乘法、求逆等函数)、复数算术。

14.13 TurboC的程序崩溃,显示错误为“floatingpointformatsnotlinked”(浮点格式未连接)。我还缺点儿什么呢?

第15章 可变参数列表

调用变参函数

15.1 为什么调用printf前必须要包含stdio.h?

15.2 为什么%f可以在printf参数中同时表示float和double?它们难道不是不同类型吗?

15.3 我遇到了一个令人十分受挫的问题,后来发现是这行代码造成的:printf("%d",n);原来n是longint型。难道ANSI的函数原型不就是用来防止这类的参数类型不匹配吗?

15.4 怎样写一个接受可变参数的函数?

15.5 怎样写一个函数,像printf那样接受一个格式串和可变参数,然后再把参数传给printf去完成大部分工作?

15.6 怎样写类似scanf的函数,再把参数传给scanf去完成大部分工作?

15.7 我用的是ANSI前的编译器,没有stdarg.h文件。我该怎么办?

提取可变参数

15.8 怎样知道实际上有多少个参数传入函数?

15.9 为什么编译器不允许我定义一个没有固定参数项的可变参数函数?

15.10 我有个接受float型的变参函数,为什么va_arg(argp,float)却不行?

15.11 为什么va_arg不能得到类型为函数指针的参数?

困难的问题

15.12 怎样实现一个可变参数函数,它把参数再传给另一个可变参数函数?

15.13 怎样调用一个在运行时才构建参数列表的函数?

第16 章奇怪的问题

16.1 为什么这个循环只执行了一次?for(i=start;iend;i++);{printf("%d\n",i);}

*16.2 遇到不可理解的不合理语法错误,似乎大段的程序没有编译。

*16.3 为什么过程调用不起作用?编译器似乎直接跳过去了。

16.4 程序在执行之前就崩溃了!(用调试器单步跟踪,在main函数的第一个语句之前就死了。)为什么? 16.5 程序执行正确,但退出时在main函数的最后一个语句之后崩溃了。为什么会这样?

16.6 程序在一台机器上运行完美,但在另一台上却得到怪异的结果。更奇怪的是,增加或去除调试的打印语句,就改变了症状……

16.7 为什么下面的代码会崩溃?char*p="hello,world!";p[0]='H';

16.8 我有些代码是用来解析外部结构的,但它却崩溃了,报了“unalignedaccess”(未对齐的访问)错误。这是什么意思?

16.9 “Segmentationviolation”、“Buserror”和“Generalprotectionfault”是什么意思?

第17章 风格

17.1 什么是C最好的代码布局风格?

17.2 如何在源文件中合理分配函数?

17.3 用if(!strcmp(s1,s2))比较两个字符串是否相等是个好风格吗?

17.4 为什么有的人用if(0==x)而不是if(x==0)?

17.5 为什么有些代码在每次调用printf前增加了类型转换(void)?

17.6 既然NULL和0都是空指针常量,我到底该用哪一个?

17.7 是该用TRUE和FALSE这样的符号名称还是直接用1和0来作布尔常量?

17.8 什么是“匈牙利表示法”(HungarianNotation)?是否值得一试?

17.9 哪里可以找到“IndianHillStyleGuide”及其他编码标准?

17.10 有人说goto是邪恶的,永远都不该用它。这是否太极端了?

17.11 人们总是说良好的风格很重要,但当他们使用良好的风格写出清晰易读的程序后,又发现程序的效率似乎降低了。既然效率那么重要,是否可以为了效率牺牲一些风格和可读性呢?

第18章 工具和资源

18.1 能否列一个常用工具列表?

18.2 怎样捕获棘手的malloc问题?

18.3 有什么免费或便宜的编译器可以使用?

lint

18.4 刚刚输入完一个程序,但它表现得很奇怪。你能发现有什么错误的地方吗?

18.5 如何关掉lint对每个malloc调用报出的“warning:possiblepointeralignmentproblem”警告消息?

18.6 哪里可以找到兼容ANSI的lint?

18.7 难道ANSI函数原型说明没有使lint过时吗?

资源

18.8 网上有哪些C语言的教程或其他资源?

*18.9 哪里可以找到好的源代码实例,以供研究和学习?

18.10 有什么好的学习C语言的书?有哪些高级的书和参考?

18.11 哪里能找到K&R的练习答案?

18.12 哪里能找到NumericalRecipesinC、Plauger的TheStandardCLibrary或Kernighan和Pike的TheUNIXProgrammingEnviroment等书里的源码?

18.13 哪里可以找到标准C函数库的源代码?

18.14 是否有一个在线的C参考指南?

18.15 我需要分析和评估表达式的代码。从哪里可以找到?

18.16 哪里可以找到C的BNF或YACC语法?

*18.17 谁有C编译器的测试套件?

*18.18 哪里有一些有用的源代码片段和例子的收集?

*18.19 我需要执行多精度算术的代码。

18.20 在哪里和怎样取得这些可自由发布的程序?

第19章 系统依赖

键盘和屏幕I/O

19.1 怎样从键盘直接读入字符而不用等回车键?怎样防止字符输入时的回显?

19.2 怎样知道有未读的字符(如果有,有多少)?另外,如何在没有字符的时候不阻塞读入?

19.3 怎样显示一个在原地更新自己的百分比或“旋转棒”的进度指示器?

19.4 怎样清屏?怎样反色输出?怎样把光标移动到指定的x,y位置?

19.5 怎样读入方向键、功能键?

其他I/O

19.6 怎样读入鼠标输入?

19.7 怎样做串口(“comm”)的输入输出?

19.8 怎样直接输出到打印机?

19.9 怎样发送转义字符序列控制终端或其他设备?

19.10 怎样做图形?

*19.11 怎样显示GIF和JPEG图像?

文件和目录

19.12 怎样检验一个文件是否存在?如果请求的输入文件不存在,我希望向用户提出警告。

19.13 怎样在读入文件前,知道文件大小?

*19.14 怎样得到文件的修改日期和时间?

19.15 怎样原地缩短一个文件而不用清除或重写?

19.16 怎样在文件中插入或删除一行(或一条记录)?

19.17 怎样从一个打开的流或文件描述符得到文件名?

19.18 怎样删除一个文件?

*19.19 怎样复制文件?

19.20 为什么用了详尽的路径还不能打开文件?下面的代码会返回错误。Fopen("c:\newdir\file.dat","r")

*19.21 fopen不让我打开文件"$HOME/.profile"和"~~/.myrcfile"。

*19.22 怎样制止MS-DOS下令人恐怖的“Abort,Retry,Ignore?”信息?

19.23 遇到“Toomanyopenfiles(打开文件太多)”的错误,怎样增加同时打开文件的允许数目?

19.24 如何得到磁盘的可用空间大小?

19.25 怎样在C语言中读入目录?

19.26 如何创建目录?如何删除目录(及其内容)?

访问原始内存

19.27 怎样找出系统还有多少内存可用?

19.28 怎样分配大于64K的数组或结构?

19.29 错误信息“DGROUPdataallocationexceeds64K(DGROUP数据分配内存超过64K)”什么意思?我应该怎么做?我以为使用了大内存模型,就可以使用大于64K的数据!

19.30 怎样访问位于某特定地址的内存(内存映射的设备或图形显示内存)?

19.31 如何访问机器地址0处的中断向量?如果将指针设为0,编译器可能把它转成一个非零的内部空指针值。

“系统”命令

19.32 怎样在一个C程序中调用另一个程序(独立可执行的程序或系统命令)?

19.33 如果运行时才知道要执行的命令的参数(文件名等),应该如何调用system?

19.34 在MS-DOS上如何得到system返回的准确错误状态?

19.35 怎样调用另一个程序或命令,然后获取它的输出?

进程环境

19.36 怎样才能发现程序自己的执行文件的全路径?

19.37 怎样找出和执行文件在同一目录的配置文件?

19.38 进程如何改变它的调用者的环境变量?

19.39 如何打开命令行给出的文件并解析选项?

19.40 exit(status)是否真的和从main函数返回同样的status等价?

19.41 怎样读入一个对象文件并跳跃到其中的函数?

其他系统相关的操作

19.42 怎样以小于1秒的精度延时或计算用户响应时间?

19.43 怎样捕获或忽略control-C这样的键盘中断?

19.44 怎样简洁地处理浮点异常?

19.45 怎样使用socket?如何联网?如何写客户/服务器程序?

*19.46 怎样调用BIOS函数?如何写ISR?如何创建TSR?

*19.47 什么是“near”和“far”指针?

回顾

19.48 我不能使用这些非标准、依赖系统的函数,程序需要兼容ANSI!

19.49 为什么这些内容没有在C语言中进行标准化?任何现实程序都会用到这些东西。

第20章 杂项

20.1 怎样从函数返回多个值?

20.2 用什么数据结构存储文本行最好?我开始用固定大小的char型数组的数组,但是有很多局限。

20.3 怎样打开命令行提到的文件并处理参数?

20.4 如何正确地使用errno?

20.5 怎样写数据文件,使之可以在不同字大小、字节顺序或浮点格式的机器上读入?

20.6 怎样用char*指针指向的函数名调用函数?

位和字节

20.7 如何操作各个位?

20.8 怎样实现位数组或集合? 234

20.9 怎样判断机器的字节顺序是高字节在前还是低字节在前?

*20.10 怎样调换字节?

20.11 怎样将整数转换到二进制或十六进制?

20.12 可以使用二进制常数(类似0b101010这样的东西)吗?printf有二进制的格式说明符吗?

效率

20.13 用什么方法计算整数中为1的位的个数最高效?

20.14 怎样提高程序的效率?

20.15 指针真的比数组快吗?函数调用会拖慢程序多少?++i比i=i+1快吗?

20.16 用移位操作符替换乘法和除法是否有价值?

*20.17 人们说编译器优化得很好,我们不再需要为速度而写汇编了,但我的编译器连用移位代替i/=2都做不到。

*20.18 怎样不用临时变量而交换两个值?

switch语句

20.19 switch语句和if/else链哪个更高效?

20.20 是否有根据字符串进行条件切换的方法?

20.21 是否有使用非常量case行标的方法(如范围或任意的表达式)?

各种语言功能

20.22 return语句外层的括号是否真的可选择?

20.23 为什么C语言的注释不能嵌套?怎样注释掉含有注释的代码?引号包含的字符串内的注释是否合法?

20.24 为什么C语言的操作符不设计得更全面一些?好像还缺了一些^^、&&=和-=这样的操作符。

*20.25 C语言有循环移位操作符吗?

*20.26 C是个伟大的语言还是别的什么东西?哪个其他语言可以写出像a+++++b这样的代码?

20.27 如果赋值操作符是:=,是不是就不容易意外地写出if(a=b)了?

20.28 C语言有和Pascal的with等价的语句吗?

20.29 为什么C语言没有嵌套函数?

*20.30 assert是什么?如何使用?

其他语言

20.31 怎样从C中调用FORTRAN(C++、BASIC、Pascal、Ada、LISP)的函数?反之如何?

20.32 有什么程序可以将Pascal或FORTRAN(或LISP、Ada、awk、“老”C)程序转化为C程序?

20.33 C++是C的超集吗?可以用C++编译器来编译C代码吗?

20.34 我需要用到“近似”的strcmp例程,比较两个字符串的近似度,并不需要完全一样。有什么好办法?

20.35 什么是散列法?

20.36 如何生成正态或高斯分布的随机数?

20.37 如何知道某个日期是星期几?

20.38 (year%4==0)是否足以判断闰年?2000年是闰年吗?

20.39 为什么tm结构中的tm_sec的范围是0到61,暗示一分钟有62秒?

琐事

20.40 一个难题:怎样写一个输出自己源代码的程序?

20.41 什么是“达夫设备”(Duff’sDevice)?

20.42 下届国际C语言混乱代码竞赛(InternationalObfuscatedCCodeContest,IOCCC)什么时候进行?哪里可以找到当前和以前的获胜代码?

20.43 K&R1提到的关键字entry是什么?

20.44 C的名字从何而来?

20.45 “char”如何发音?

*20.46 “lvalue”和“rvalue”代表什么意思?

20.47 哪里可以获得本书的在线版?

术语表

参考文献

C语言实现外卖管理系统

01-20

本文为大家分享了C语言外卖管理系统的具体代码,供大家参考,具体内容如下

内容

说明(废话):上学期写的课程设计,主题是外卖管理系统,希望可以模拟网上订餐,店家工作,专人管理的过程。并实现注册与登录以及基本信息的输出,因为个人比较懒,一直没有整理上去,今天得空,要是得到大家的宝贵意见的话,会不胜荣幸。

重点内容

  三端登录 :分别为管理员,用户以及店主;两端注册,分别为用户以及店铺,其中店铺的注册成功需要得到管理员的审核。

  管理员端可以查看店铺信息,店铺信息修改(分为增删改查),处理申请店铺,和修改本人信息。

  用户端分为用户相关(为用户本人对自己信息的操作),查看订单,查看

C语言 strstr()函数介绍

热门推荐

阳光大男孩!!!的博客

11-22

2万+

前言

C语言中,strstr()函数用于找到子串在一个字符串中第一次出现的位置,在string.h头文件中。

例如:char *strstr(const char *str1, const char *str2)

str1是总串,str2是需要匹配的第一个字串位置,返回值为char * 类型。

代码实践

int main(int argc, char *argv[]) {

char origin_str[100],match_str[100];

gets(origin_str);

gets(matc

C语言 逆序输出字符串

阳光大男孩!!!的博客

10-27

1万+

前言

逆序输出字符串最可能先想到的是遍历时用栈保存字符,最后出栈。既然栈可以实现,那我们也可以用递归的方法来实现,并且一定会比较简单。

除了以上两种,还可以对字符串进行原地逆置,最后再将该字符串输出即可。

一、简单递归实现

void fun(char *s)

{

if(*s!='\0') // 递归终止条件

{

fun(s+1); // 注意这里是先递归再输出,这样就可以从后面开始逆序输出

printf("%c",*s);

}

}

int main(int argc, char *a

C语言 将整数n分解为若干质数(素数)之积

阳光大男孩!!!的博客

10-27

6635

C语言代码

#include

int main(int argc, char** argv) {

int n;

scanf("%d",&n);

int i=2;//2是最小的素数

while(n>i)

{

if(n%i==0)

{

printf("%d ",i);

n/=i;

}else

{

i++;

}

}

printf("%d",n);//最后无法分解了,则剩下的这个数就是最后一个质数因子

retur

C语言 字符串按单词逆序输出

阳光大男孩!!!的博客

12-14

4037

题目描述

给定字符串

Hello world I

逆序输出为

I world Hello

C语言实现

// “Hello world I”

// “I world Hello ”

void wordReversePrint(char s[])

{

int i,len = strlen(s);

char *start = s;

s+=len-1;

for(i=len-1; i>=0; i--)

{

if(*s==' ')//碰见空格就输出空

C语言中%lf是什么意思

05-24

在C语言中,%lf是格式化输出控制符,用于格式化输出双精度浮点数类型的数据。它指示printf()函数或其他类似函数输出一个双精度浮点数,其中l代表long,f代表float。例如,下面的代码可以输出一个双精度浮点数变量x的值:

```

double x = 3.14159;

printf("x的值为:%lf", x);

```

输出结果为:

```

x的值为:3.141590

```

“相关推荐”对你有帮助么?

非常没帮助

没帮助

一般

有帮助

非常有帮助

提交

May Hacker

CSDN认证博客专家

CSDN认证企业博客

码龄5年

暂无认证

733

原创

8万+

周排名

180万+

总排名

143万+

访问

等级

1万+

积分

1320

粉丝

1434

获赞

552

评论

5478

收藏

私信

关注

热门文章

CRC 循环冗余码的计算方法

50917

Android Studio 运行按钮灰色解决方法

37242

Matlab如何调用并使用函数

35892

加减交替法(不恢复余数法)

32271

超详细 Docker 安装Jenkins(避坑!!!)

28834

分类专栏

Redis

18篇

Flink

3篇

机器学习

1篇

ClickHouse

1篇

1篇

Serverless

1篇

Bug

2篇

Java

44篇

JVM

8篇

算法

31篇

Java 多线程

18篇

数据库

26篇

Java GUI

4篇

spring cloud alibaba

4篇

分布式系统

17篇

考研及研究生期间

4篇

Arthas

2篇

Hadoop

16篇

Spring boot

15篇

操作系统

11篇

设计模式

7篇

Docker

9篇

Linux

7篇

MQ

6篇

Spring Security

5篇

Dubbo

2篇

Spring Cloud

2篇

C语言

13篇

Maven

1篇

杂文

11篇

Vue

5篇

Git

1篇

Go

10篇

Jetpack

3篇

Tensorflow2.0

需要注意的PTA题目

7篇

VHDL

6篇

计算机网络

6篇

计算机组成原理

9篇

微信小程序

3篇

HBU OJ

1篇

Android

56篇

CSP

19篇

Matlab

1篇

C++

14篇

Leetcode

229篇

python

6篇

javaScript

3篇

数据结构

19篇

PTA

71篇

最新评论

【PTA】特殊堆栈

岳麓山车神710:

我不理解,insert代码复杂到O(N2)了为什么可以过

分布式唯一ID生成算法—雪花算法思路

May Hacker:

感谢指正,打字打快了

加减交替法(不恢复余数法)

m0_71447839:

符号位为1即负时,商0,不够减,用y补,符号位为0时即为正,商1,够减用-y补

加减交替法(不恢复余数法)

m0_71447839:

选最左边的来作为最终的符号位

【PTA】 7-10 倒数第N个字符串

约里娜:

为什么正着数不是第26L - N+1个?

您愿意向朋友推荐“博客详情页”吗?

强烈不推荐

不推荐

一般般

推荐

强烈推荐

提交

最新文章

Mysql中的隐式查询导致索引失效

Flink UDF

简单总结:Flink和Kafka是如何做到精准一致性的

2023年3篇

2022年73篇

2021年312篇

2020年166篇

2019年180篇

2018年2篇

目录

目录

分类专栏

Redis

18篇

Flink

3篇

机器学习

1篇

ClickHouse

1篇

1篇

Serverless

1篇

Bug

2篇

Java

44篇

JVM

8篇

算法

31篇

Java 多线程

18篇

数据库

26篇

Java GUI

4篇

spring cloud alibaba

4篇

分布式系统

17篇

考研及研究生期间

4篇

Arthas

2篇

Hadoop

16篇

Spring boot

15篇

操作系统

11篇

设计模式

7篇

Docker

9篇

Linux

7篇

MQ

6篇

Spring Security

5篇

Dubbo

2篇

Spring Cloud

2篇

C语言

13篇

Maven

1篇

杂文

11篇

Vue

5篇

Git

1篇

Go

10篇

Jetpack

3篇

Tensorflow2.0

需要注意的PTA题目

7篇

VHDL

6篇

计算机网络

6篇

计算机组成原理

9篇

微信小程序

3篇

HBU OJ

1篇

Android

56篇

CSP

19篇

Matlab

1篇

C++

14篇

Leetcode

229篇

python

6篇

javaScript

3篇

数据结构

19篇

PTA

71篇

目录

评论 7

被折叠的  条评论

为什么被折叠?

到【灌水乐园】发言

查看更多评论

添加红包

祝福语

请填写红包祝福语或标题

红包数量

红包个数最小为10个

红包总金额

红包金额最低5元

余额支付

当前余额3.43元

前往充值 >

需支付:10.00元

取消

确定

下一步

知道了

成就一亿技术人!

领取后你会自动成为博主和红包主的粉丝

规则

hope_wisdom 发出的红包

实付元

使用余额支付

点击重新获取

扫码支付

钱包余额

0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。 2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值

为什么double类型输入(scanf)用%lf,输出(printf)用%f? - 知乎

为什么double类型输入(scanf)用%lf,输出(printf)用%f? - 知乎首页知乎知学堂发现等你来答​切换模式登录/注册编程计算机C(编程语言)C / C++C 语言入门为什么double类型输入(scanf)用%lf,输出(printf)用%f?这个问题我尝试过搜索解决。然而大家说的答案都实在相差很大。不知道取信哪一个。我搜到比较像正确答案的一个,然而我一个新手实在不是很确定。 No, sim…显示全部 ​关注者43被浏览61,303关注问题​写回答​邀请回答​好问题 2​添加评论​分享​3 个回答默认排序知乎用户​float是浮点型,double是double float的意思,也就是双精度浮点型。%f是以float类型格式化输入或输出,%lf是long float的意思(估计是和%ld对应),也就是指double类型。scanf读%f时,系统会按照4字节长度来读,读完要放到一个4字节的空间位置,也就是一个float所在的位置。那么double有8字节空间,比4字节还大,能不能来放?答案是不能。因为float和double的关系不像int和long的关系那样,简单的在后面增加4字节的位置。float和double有自己专门的数据排列格式,如下:如果读的时候明明是按照float的格式来读,但是却存在double的空间内,并且之后一直按double来操作,那么里面数据的符号位、阶码、尾数就全错位了。除非你在用的时候把每个double强制转换成float来用,但是何必多次一举?同理,如果读用%lf来读,却存在float中,不仅格式错位,而且存储空间也不够,会有数据丢失。所以用scanf读的时候,读%f就规规矩矩的放进float中来存,读%lf就放进double中,这样在使用的时候里面的数据才不会错位。在printf的时候,首先C里面的float其实在使用过程中都是被隐式转换成了double来用。所以你在printf时用float还是double其实是一样的。用%f和%lf都可以。编辑于 2017-02-08 14:10​赞同 77​​12 条评论​分享​收藏​喜欢收起​步响曲鸣和头像一样聪明顶呱呱​ 关注所以才说明晰函数的参数类型(而不是模模糊糊地想着double变量取地址)很重要。准确来讲,是scanf里lf要接收double*,f要用接收float*,而printf里无论写lf还是f都是当成double。明晰一下其实应该就能自己发现答案了因为float和double可以直接转换,所以可以统一成其中一个。但是float*和double*不能,就算借助(void*)那也不会有编码上的变化,必须分开处理。发布于 2021-12-01 21:47​赞同 4​​添加评论​分享​收藏​喜欢收起​​

回车(CR)与换行(LF), '\r'和'\n'的区别 - 知乎

回车(CR)与换行(LF), '\r'和'\n'的区别 - 知乎切换模式写文章登录/注册回车(CR)与换行(LF), '\r'和'\n'的区别嵌入式er终极理想稚晖君一:回车”(Carriage Return)和“换行”(Line Feed)起源首先,弄清两个概念:回车CR-将光标移动到当前行的开头。换行LF-将光标“垂直”移动到下一行。(而并不移动到下一行的开头,即不改变光标水平位置) 在计算机还没有出现之前,有一种叫做电传打字机(Teletype Model 33,Linux/Unix下的tty概念也来自于此)的玩意,每秒钟可以打10个字符。但是它有一个问题,就是打完一行换行的时候,要用去0.2秒,正好可以打两个字符。要是在这0.2秒里面,又有新的字符传过来,那么这个字符将丢失。【嵌入式物联网单片机学习】大家可以加我微信一起学习,我整理了100多G(全网最全)的学习资料包(持续更新)、最新的学习路线思维导图。各种学习群、项目开发教程。还可以围观我朋友圈中的一手行业消息,每周的技术大咖直播答疑吹水于是,研制人员想了个办法解决这个问题,就是在每行后面加两个表示结束的字符。一个叫做“回车”,告诉打字机把打印头定位在左边界;另一个叫做“换行”,告诉打字机把纸向下移一行。这就是“换行”和“回车”的来历,从它们的英语名字上也可以看出一二。后来,计算机发明了,这两个概念也就被般到了计算机上。那时,存储器很贵,一些科学家认为在每行结尾加两个字符太浪费了,加一个就可以。于是,就出现了分歧。Unix系统里,每行结尾只有“<换行>”,即"\n";Windows系统里面,每行结尾是“<换行><回车>”,即“\n\r”;Mac系统里,每行结尾是“<回车>”,即"\n";一个直接后果是,Unix/Mac系统下的文件在 Windows里打开的话,所有文字会变成一行;而Windows里的文件在Unix/Mac下打开的话,在每行的结尾可能会多出一个^M符号。二:区别 CR用符号'\r'表示, 十进制ASCII代码是13, 十六进制代码为0x0DLF使用'\n'符号表示, ASCII代码是10, 十六制为0x0A Dos和windows采用回车+换行CR/LF表示下一行,而UNIX/Linux采用换行符LF表示下一行,苹果机(MAC OS系统)则采用回车符CR表示下一行. 所以Windows平台上换行在文本文件中是使用 0d 0a 两个字节表示, 而UNIX和苹果平台上换行则是使用0a或0d一个字节表示. 注1:关于“回车键”的来历,还得从机械英文打字机说起。在机械英文打字机上,有一个部件叫“字车”,每打一个单词,“字车”就前进一格。当打满一行字符后,打字者就得推动“字车”到起始位置,这时打字机会有两个动作响应:一是“字车”被归位,二是滚筒上卷一行,以便开始输入下一行,这个推动“字车”的动作叫“回车”。 注2:这种差别在编程、不同OS之间传输纯文本时最需要注意。转载自:单机片爱好者原文来源于回车(CR)与换行(LF), '\r'和'\n'的区别原文链接:回车(CR)与换行(LF), '\r'和'\n'的区别编辑于 2022-04-21 22:31编程​赞同 2​​添加评论​分享​喜欢​收藏​申请

回车(CR)与换行(LF) - 知乎

回车(CR)与换行(LF) - 知乎切换模式写文章登录/注册回车(CR)与换行(LF)终究慎独​whu起因:看到回车和换行 - 阮一峰的网络日志这篇文章,讲的很清楚,但是我一直没搞懂^M是怎么出现的,查了好久好久终于找到答案了vim显示不可见特殊字符_jichenchen1990的专栏-CSDN博客_vim查看隐藏字符,省流:不可见字符\r在vi/vim中显示为其输入^M 在这个过程中学到了很多,算是一个似懂非懂的问题终于搞懂了,特来写一篇文章记录一下。如今的windows系统中的换行与回车似乎是一个意思,也就是通俗所指的ENTER键 ,但是其实这两个词具有不同的含义最开始的机械英文打字机大致设计如下,具体的打字使用情况可以参考Halda Star机械打字机输入速度测试_哔哩哔哩_bilibili·回车(CR),即 carriage return,其中车代表上方卷着纸的纸车/字车,打字开始时需要将上方纸车拉至最后右,拉紧弹簧,随着打字弹簧逐渐将上方纸车拉回,即回车换行(LF),即line feed,指每次需要向下搬动左侧把手,卷动纸车使打字位置向下一行,即换行也就是说,其实回车只是只回到当前行的行首,换行只是只向下移动一行,组合起来才是我们熟悉的移动至下一行的行首后来出现了电传打字机,可以根据传入的信号自动打字。但是每一次换行的时候需要耗时0.2s,如果在机器换行期间传入电流信号则会丢失字符,当时电传打字机速度为10字符/秒,平均0.2s能打两个字符,为了解决这个问题研发人员决定在每行后面加两个表示结束的字符。一个叫做"回车",告诉打字机把打印头定位在左边界;另一个叫做"换行",告诉打字机把纸向下移一行,这样这个时间间隔就被完美的填补上了。再后来计算机出现,这两个概念也就被般到了计算机上。那时,存储器很贵,一些科学家认为在每行结尾加两个字符太浪费了,加一个就可以。于是,就出现了分歧:Linux/Unix系统里,每行结尾只有"<换行>",即"\n";Windows系统里面,每行结尾是"<回车><换行>",即"\r\n";Mac系统里,每行结尾是"<回车>",即"\r";(现在已改成跟Unix/Linux一样的"\n")这会出现一个什么问题呢?一个直接后果是,*nix系统下的文件在Windows里打开的话,所有文字会变成一行;而Windows里的文件在*nix下打开的话,在每行的结尾可能会多出一个^M符号。这里解释一下^M,*nix系统vim中可见特殊字符(如abc*=13)正常显示,不可见字符会显示为该字符在命令行的输入方式,回车(\r)的输入方式是 ctrl+v+m,因此显示^M,与字符^和字符M无关 ,见vim显示不可见特殊字符_jichenchen1990的专栏-CSDN博客_vim查看隐藏字符我做了一个小测试,在windows中创建a.txt,写入123(enter)456,保存。可以看到windows采用的是CRLF的换行方式,大小为8字节(1 2 3 CR LF 4 5 6)然后我们传入linux服务器( openEuler 20.03),使用vim a.txt打开,好像并没有看到^M? 是文件有什么问题么,还是vim的问题么?我们使用cat FILENAME来查看文件内容,使用du -b FILENAME 来查看文件的所占字节数这里的456后直接跟了[root],这是正常的,因为文件结尾没有换行,其他信息会接着cat显示的内容之后输出我们可以看到内容,大小都是没有问题的,那么肯定是vim的问题了,原因是vim的fileformat,它是由Vim在读取文件时设置的,也可以在命令中指定,告诉Vim如何读取文件该选项是全局的,并指定在 Vim 读取文件时将尝试哪些文件格式(unix,dos,mac)除非另有指定,否则 Vim 会尝试自动检测应使用哪种文件格式来读取文件:如果文件中的所有行都以CRLF结尾,则将应用dos文件格式,这意味着在将行读入缓冲区时,将删除每个CRLF,并且缓冲区“ff”选项将为dos。如果一行或多行仅以LF结尾,则将应用unix文件格式,这意味着每个LF都将被删除(但每个CR将出现在缓冲区中,并显示为^M),缓冲区“ff”选项将为unix由于vim检测到a.txt中所有行都已CRLF结尾,所以虽然在Linux系统中仍然采用了dos文件格式预览。参考资料:https://vim.fandom.com/wiki/File_format我们有两种方式可以使用vim查看到^M:使用:e ++ff=unix将vim的fileformat选项置为unix视图模式使用vim -b a.txt以二进制模式查看关于文本模式和二进制模式见文末那么每一行结尾多出一个来自windows的回车符\r,表现为^M,会有什么后果呢?对于大部分代码是没有问题的,我在知乎问出了这个问题并得到一个很好的回答,感谢!python在PEP 278 – 通用换行线支持|peps.python.org中提到:本 PEP 讨论了 Python 可以支持对具有非平台上本机格式的换行符格式的文件进行 I/O 的一种方式,以便每个平台上的 Python 都可以读取和导入带有 CR (Macintosh)、LF (Unix) 或 CR LF (Windows) 行尾的文件。越来越常见的是,行尾与当前平台上的标准不匹配:通过网络下载的文件,不同平台上的远程挂载文件系统,Mac OS X具有Mac和Unix行尾的双重标准等。许多工具(如编辑器和编译器)已经优雅地处理了这一点,如果Python也这样做会很好c在初始处理(C 预处理器) (gnu.org)中提到:不同的系统使用不同的约定来指示行的末尾。GCC接受ASCII控制序列,并作为行尾标记。这些是Unix,DOS和VMS以及经典Mac OS(OSX之前)分别使用的规范序列。因此,您可以安全地将任何这些系统上编写的源代码复制到其他系统,并在不转换的情况下使用它。(如果文件不能始终如一地使用一种约定,GCC 可能会丢失对当前行号的跟踪,有时在共享网络文件系统的具有不同约定的计算机上编辑时会发生这种情况。可以理解为优秀的编译器已经优雅的处理了这个问题,代码不会因为操作系统的规定的换行符不同导致编译问题。但是并不是所有代码文件都是支持多平台的,比如在windows下新建了一个shell脚本文件#!/bin/sh

echo hello

echo world在windows中(git bash)执行效果为hello

world在linux执行效果为a.sh: line 2: $'\r': command not found

hello

world其中 $'\r'就是windows系统的文件转移至linux系统时换行符多出来的'\r',前面使用$符号表示变量。对于这个例子来说hello world正常输出了只在空行报错了, 但是一旦shell的脚本变得复杂起来存在嵌套关系时,比如:#!/bin/sh

if [ $# -lt 1 ] ; then

echo "未检测到输入参数,退出!"

exit 1

fi直接传输到linux中就会完全无法使用,其根本原因就在于bash是完全的unix shell,只接受以\n结尾的命令,需要将每行结尾的\r去掉才能使用 那么既然unix/windows的换行符不统一,那么我们怎么在两个系统之间对于操作符进行对应的改变呢?从windows到linux:以之前提到的a.txt为例,其大小为8字节:123

456 在vim中打开,依次执行:e ++ff=dos 以dos模式编辑:setlocal ff=unix 将结尾模式切换到LF :wq 保存退出文件中的换行符就已经被完美解决转换了,我们再次查看一下很奇怪,明明是\r\n变\n居然还是8个字节,并且与之前的相比结尾莫名其妙的换行了?经搜索后发现原来是vim根据fileformat不同会自动在结尾添加对应的换行符,unix表现为在最后一行添加一个\n ,由此导致了字节数-1+1没变化。我们可以进行如下处理,文件大小就合理了:vim -b a.txt 以二进制打开文件 :set noeol 开启noeol(no-eol)(没有-行末结束符)(no end of line) :wq 保存退出这里要补充说一点,按说文件结尾没有eol是一种不正确的文件格式,vim默认添加行末结束符(EOL)是很好的做法,但windows的文件大部分都是这样,比如记事本。这个我们暂且不讨论,这里的例子只是用来解释转化后字节数-1参考Vim 编辑器底端 [noeol], [dos] 的含义从linux到windows:理论上来说linux的换行符只有\n,文件转移到windows打开后会由于找不到\r\n的连续换行符标志导致都显示在一行,但是目前windows系统中绝大多数的代码编辑器,文本编辑器都已经优雅的处理了这个问题,我们也没必要再为此操心在问题Unix/Linux/Mac 与 Windows 的换行符不统一的原因/目的是什么?下,已有人从操作系统/协议/打字机到计算机等方面做出了解释,其中有两个回答深得我心 回答1:文本(text)和字符串(string)和二进制(binary)是三个层面的东西。字符串是对文本的序列化,二进制是对字符串的序列化。同样的文本在不同平台上表示成不一样的字符串,正如同样的字符串在不同编码下表示成不同二进制。text描述的是一段自然语言文字,string是为了传输或存储这个text而用来表示这一段文字的字符序列。比如abc这个text,在主流终端传输时,用字符串可以表示为"abc",也可以表示为"abb\bc",即先多打一个b再打一个退格符删掉。你可以想想为什么http传输json的mime是application/json而不是text/json。因为json官网http://json.org明确规定了json的换行符具体是哪个unicode字符,因此json是对js object的string表示,而不是对js object的text表示。同理,为什么http传输html的类型是text/html而不是application/html。因为html是hyper text而不是string。所以http协议会将html这个text转换成string,再转换成binary发出去,对方收到之后会将binary转为string再转为对方平台里的text。此时换行符可能变了,trailing spaces可能删了,ending newline可能删了,甚至tab变成了4个空格。不过没关系,虽然string和原来不一样了,但text和原来一样。回答2:这个问题,让我们认识到文件是一个操作系统抽象,离开操作系统谈文件会发现这个抽象有很多问题。我们并没有一个跨操作系统的文件,我们无论下载,上传,还是通过文件共享,其实都经过了一种通信协议,在我们的操作系统上重建了文件,这本来就应该由通信协议完成本地化转换。大部分遇到这个问题的人要么有意忽视了这个问题(强行原样复制文件并在不同系统中打开,比如通过打包,传输,再解包的方式),要么就是协议不支持,比如windows的scp。FTP协议中区分了文本和非文本,git中支持修改或不修改换行符,都是这个原因。见过不少同事在window下强行用"b"模式打开文本,再强迫自己用"\r\n"写行结束,实在太辛苦。windows和unix下都通用的作法是用不加"b"的模式打开文本,用"\n"写行结束。异种系统传递文件内容时,记得区分文本和非文本,按需重建文件。文件确实是操作系统上的一个抽象概念,很多传输工具其实就有意区分了文本/非文本,在xftp/winscp等传输工具都提供了两种传输方式:其中ASCII就是考虑到了操作系统的差异,二进制就是字节传输(默认)如果使用ASCII传输,那么将文件从windows->linux,则会在传输期间就将\r\n替换为\n,即8->7字节,反之同理,7->8。这也印证了文件确实本来就应该由通信协议完成本地化转换。其实在最开始我提到了回车CR只是回到行首, 换行只是指LF向下移动一行,但是我们在编写C语言等代码时除了某些特殊情况比如网络协议(SMTP等)的数据报文使用了\r\n分行,其他情况似乎也没有使用到\r ,使用printf('\n') 就可以正常输出。按照换行(LF)的定义来说,printf("hello\nworld")的输出结果应该是hello

world 但实际上无论是windows还是linux输出结果都是hello

world其实这个问题很好解释,换行(LF)\n的含义一开始确实是向下移动一行,但unix操作系统就是使用\n一个字符来表示回车+换行,而C语言发明之初就与UNIX密切相关,故而其中\n就是下移一行并且光标移至行首,\r为光标移至行首,而后期诸多高级语言也都沿袭了unix的这个设定,认为没有必要特意区分为两个字符,回车+换行也都可以用一个字符\n来实现 ,如python/java等。C语言历史,C语言与UNIX系统的关系最后聊一下文本模式和二进制模式。C语言读取文件中文本模式和二进制模式的区别_张Da夫-CSDN博客从内存和硬盘的存储角度来看,任何文件都是0 1组成的序列,但是我们可以有不同的模式去访问文本。以下程序皆运行在windows系统中使用文本模式打开文件 fopen("output.txt", "r") | fopen("output.txt", "w") 使用二进制模式打开文件 fopen("output.txt", "rb") | fopen("output.txt", "wb") 使用如下代码向文件中写入内容,分别使用两种模式的文件打开方式#include

#define MAX_LENGTH 10

int main()

{

int flag;

char ch;

FILE *fp1 = fopen("output.txt", "w"); // 创建文件指针及打开文本文件

//FILE *fp1 = fopen("output.txt", "wb");

char context[MAX_LENGTH] = {'1','2','\n','3','4','\0'};

for(int i=0;i

if (context[i]=='\0')break;

fprintf(fp1,"%c",context[i]);

}

fclose(fp1);

return 0;

}输出结果都是12

34不同的是使用文本模式写入的文件为6字节,使用二进制模式写入的文件为5字节当使用文本模式打开一个文件并向其写入内容时,输入换行符\n时为了与windows模式匹配会在其之前自动添加\r,相当于程序写入\n<==>文件写入\r\n。而二进制模式则是直接写入数据,没有做任何的数据转换。接着我们使用两种方式读取通过文本模式写入的文件,分别以文本模式(r),二进制模式(rb)打开,并输出文件内容二进制模式写入5个字节没有\r,两种读方式得到的结果相同/*

程序功能:分别按照字符,行标识读取文本文件

*/

// 一、按照字符读取文本文件

#include

int main()

{

char ch;

FILE *fp1 = fopen("output.txt", "r"); // 创建文件指针及打开文本文件

//FILE *fp1 = fopen("output.txt", "rb");

int len = 0;

while((ch=fgetc(fp1)) != EOF){

++len;

printf("%02x ",ch);

}

printf("\nthe number of byte is %d",len);

// fileHang(fp1);

fclose(fp1);

return 0;

}文本模式31 32 0a 33 34

the number of byte is 5二进制模式31 32 0d 0a 33 34

the number of byte is 6文本模式写入换行符\n,windows系统会自动添加一个\r, 导致最终文件大小会比写入的字符多出一个字节,而读取的时候也会自动忽略这个系统写入的\r,读取到的结果和输入结果相同 二进制模式写入了什么数据就是什么数据,读到了什么数据就是什么数据,完全不做任何的数据转换这也就是为什么之前使用vim -b a.txt,以二进制模式打开能观察到^M,因为显示全数据,\r不可见特殊字符被转换为其输入方式ctrl+v+m。而文本模式vim b.txt没有看到异常就是因为vim检测到行尾以CRLF结尾,于是以dos模式预览,dos的文本模式自动忽略了这个\r,也就看不到^M了。linux系统不存在这个问题,因为换行符都是\n,不需要添加也不需要忽略,两个模式效果相同。 一些补充:继机械打字机之后出现了电传打字机,不需要手动的回车换行,改为两个按键(P右侧隐约可见文字)LF和CR1.为什么CRLF是正统而不是LF LFCR CR呢?这是电传打字机的设计细节。一是因为最早CR有延迟,LF没有(后来有了高速机型就都没有了——准确说延迟都在字符时隙以下了),同时CR和LF完全是两套机械系统控制,一套横向拉回,一套纵向滚动/移动。另外就是隔行打印需要CR-LF-LF…。先CR可利用等待的时间完成LF,同时连续多个LF可以优化机械实现。于是先执行CR就顺理成章成为标准了CRLF正统2.为什么不把CR LF设计成一个键而不是两个键呢? 因为CR和LF分开是必要的,因为用户时常需要加粗部分文字。打印头得先归位CR,再向右移动到需要加粗的单词位置,然后再喷一遍墨水。如果打错了,就要把打错的地方拿涂改液涂掉,按CR重打参考文章回车、换行、回车换行、硬回车以及软回车_zohn的学习笔记-CSDN博客_硬回车和软回车的区别3.为什么UNIX和windows采用不同的换行方式呢?网络协议使用的都是CRLF呢? 其实是一个历史问题1968年,13岁的比尔盖茨和15岁的保罗艾伦(windows)。他们当时使用的,就是上面那种Teletype Model 33电传打字机。根据历史资料,他们的学校当时有一台PDP-10,PDP是Digital Equipment Corporation,也就是Digital(DEC)公司的小型机系列,当时PDP系列小型机在商用和教育市场占有统治地位,它使用的TOPS-10系统就是使用CRLF作为【回车】的1969年, 肯·汤普逊和丹尼斯·里奇两位大神开始(在PDP-11上)开发Unix操作系统,Unix沿用了MIT,通用电气和贝尔实验室联合开发的Multics的设计,当年Unix的前身Multics,保留的CR按钮用做重复打印来实现删除线和加粗的效果,所以只采用的单LF作为换行符。1969年, ARPANET开始建设1971年,RFC158标准确立;同年,贝尔实验室向外界公开了UnixRFC158标准RFC编者与换行符的故事1972年,C语言被用来重写Unix1975年,微软成立,同年出现了RFC681标准,dos/windows遵循了网络协议(RFC)的换行标准(CRLF)windows对于RFC的遵守1970年代,大多数的Internet相关的协议都已经诞生,包括电子邮件(SMTP)和FTP协议。这些协议都是受到RFC标准的影响,也沿袭了使用CRLF作为换行符,这导致后期所有的网络协议也都沿袭了这一换行标准可以说,CRLF的使用很大程度取决于当时的电传打字机的设计(见问题1),之后早期电脑的设计沿袭了该换行方式,在设计HTTP,windows的年代CRLF就是正统,unix使用 LF 才是不遵循正统另辟蹊径的一方。历史参考计算机历史总结:回车与换行在windows系统与*nix系统换行符存在差异,这导致了一系列问题。好在一款优秀的代码编辑器,文本编辑器,编译器都已经对不同操作系统文件换行符的差异做出了优雅的处理,使得大部分人在接触双系统时甚至没有意识到其存在的差异以及差异所能带来的影响,这是一件非常伟大的事。 也大可不必去争论windows与*nix的换行符选择谁对谁错,历史已成定局,我们了解背后的故事即可。在浏览资料的过程中也让我深刻的体验和接触到了一些被我忽视掉的东西,也让我明白其实文本和和字符本身就是不同的,跨越操作系统,跨越传输协议去讨论文件也是不合理的。2022.3.15编辑于 2022-03-17 03:04换行Microsoft WindowsLinux​赞同 65​​7 条评论​分享​喜欢​收藏​申请

关于double和float和int以及%f,%lf,%llf,%Lf以及printf和scanf的总结-CSDN博客

>

关于double和float和int以及%f,%lf,%llf,%Lf以及printf和scanf的总结-CSDN博客

关于double和float和int以及%f,%lf,%llf,%Lf以及printf和scanf的总结

QWQ___qwq

已于 2023-02-28 21:25:56 修改

阅读量1.7w

收藏

150

点赞数

40

分类专栏:

C++

C语言

文章标签:

编程语言

c++

c语言

java

eclipse

于 2021-07-23 21:32:22 首次发布

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/weixin_46585199/article/details/119044763

版权

C++

同时被 2 个专栏收录

59 篇文章

8 订阅

订阅专栏

C语言

22 篇文章

6 订阅

订阅专栏

如图:

注解:

建议不使用float变量,而使用double变量: float有效数字6-7位,还不如int类型表示的数据有效性高,而double 有效数字15-16位。另外,float占四个字节,double占8字节,在表示浮点数时double精度要高的很多。对于float类型的变量,printf()中的说明符可以用%f或%lf,而scanf()中的说明符则只能用%f;对于double类型的变量,printf()中的说明符可以用%f或%lf,而scanf()中的说明符则只能用%lf;对于long double类型的变量,printf()中的说明符可以用%Lf,而scanf()中的说明符则只能用%Lf。

关注博主即可阅读全文

优惠劵

QWQ___qwq

关注

关注

40

点赞

150

收藏

觉得还不错?

一键收藏

知道了

1

评论

关于double和float和int以及%f,%lf,%llf,%Lf以及printf和scanf的总结

另外,float占四个字节,double占8字节,在表示浮点数(小数)时double精度要高的很多。对于long double类型的变量,printf()中的说明符可以用%Lf,而scanf()中的说明符则只能用%Lf。对于double类型的变量,printf()中的说明符可以用%f或%lf,而scanf()中的说明符则只能用%lf;对于float类型的变量,printf()中的说明符可以用%f或%lf,而scanf()中的说明符则只能用%f;建议不使用float变量,而使用double。

复制链接

扫一扫

专栏目录

scanf输入输出

m0_61360607的博客

05-29

45

scanf输入输出

线性变分去噪matlab代码-LLF:使用深度学习先验和局部线性拟合的惩罚性PET重建

05-22

线性变分去噪声matlab代码使用深度学习先验和局部线性拟合的惩罚性PET重建

你好,

我是金敬尚。

(kssigari(at)gmail.com,kkim24(at)mgh.harvard.edu)

该代码用于以下论文:Kyungsang

Kim等。

“使用深度学习先验和局部线性拟合对PET进行重建”,IEEE

Transactions

on

Medical

Imaging。

()

由于数据文件带有链接,因此请仔细阅读以下内容。

抽象的

受深度学习在医学成像中巨大潜力的推动,我们提出了一种基于深度学习的先验迭代正电子发射断层扫描(PET)重建框架。

我们利用去噪卷积神经网络(DnCNN)方法,并使用全剂量图像作为地面真实情况和通过泊松细化从下采样数据重构的低剂量图像作为输入来训练网络。

由于大多数公开的深度网络都是在预定的噪声水平下进行训练的,因此训练和测试数据的噪声水平差异是它们作为通用先验技术的适用性的主要问题。

特别是,噪声水平在每次迭代中都会发生显着变化,这可能会降低迭代重建的总体性能。

由于现有研究不足,我们进行了仿真并评估了各种噪声条件下性能的下降。

我们的发现表明,Dn

1 条评论

您还未登录,请先

登录

后发表或查看评论

【C语言】你真的懂基本数据类型吗?

我的主页

10-15

1728

本期讲解:什么是数据类型?1.1数据类型的分类1.2基本数据类型有哪些?1.3整型1.4浮点型2、变量与常量2.1、变量与常量是什么?2.2、怎样定义一个常量2.3、变量的命名规范3、变量的分类3.1、局部变量3.2、全局变量3、常量的使用3.1、常量分类3.2、#define宏定义3.3、const修饰的常变量

老汤回味——C语言基本数据类型及printf打印

我的天空 我的梦

05-19

8643

C语言是一种强类型语言,也就是说,C语言的变量使用要严格符合定义,所有变量都必须先定义后使用。另外,printf必须使用对应的转换说明符才能打印对应的数据类型数据,下面我们整体了解一下。有符号整型有符号整型可以用来定义正整数和负整数,有下面几种类型:int:最常使用的类型,是系统的基本类型,C语言标准规定,int类型至少16位长。printf中使用%d进行打印。short或short int:C语...

c语言输出double用什么意思,C语言中想输出double和long double型用%什么?

weixin_35688354的博客

05-20

8053

1、%f是输出float型变量;%f 是输出double型变量;%Lf 是输出longdouble型变量。2、在C语言中,对于数值类型只有通过printf类函数输出这一种方式,比如printf, sprintf, fprintf等。这类函数输出时要求有格式符号,其中long double的格式符号为%Lf。以下是一个简单的参考代码,输出到标准输出设备。#includeintma...

double与long输入输出格式还有没有其他的隐含条件?

m0_72002663的博客

08-17

2535

double型输入输出格式均为“%lf”,long输入输出格式均为“%ld”;但是实际操作过程中只有double的输入必须写为“%lf”,其他的不加“l”也能编译成功,这是什么原因?

c语言用long类型时 scanf,C语言怎么输出或输入long类型的?

weixin_39932947的博客

05-19

6229

满意答案pizi0010推荐于 2017.09.22采纳率:47%等级:8已帮助:713人在c语言中,对于数值类型只有通过printf类函数输出这一种方式,比如printf,sprintf,fprintf等。这类函数输出时要求有格式符号,其中longdouble的格式符号为%llf以下是一个简单的参考代码,输出到标准输出设备。#includeint main(){long double v...

用c语言实现llf算法,C语言复习

weixin_34404599的博客

05-23

741

1 编辑、编译、链接2 printf scanf用于显示器fprintf fscanf用于文件sprintf sscanf用于字符串3 面试的时候必须注释,否则人家当你没有工作经验4 全局变量有声明和定义的区别,局部变量不区分声明和定义,都是定义5 声明可以有多个,定义只能有一个6printf不会进行数据类型转换7 自动转换和与强制转换,赋值的时候会自动转换,int num=3.5;int是3,+...

C语言中float的输入和输出,C语言 如果使用float 之后输出都必须改成%f??

weixin_39864591的博客

05-19

4221

定义某个类型后,输出的时候也要输出相应的类型,否则可能会出错或者造成输出的数值不精确。针对你这个问题:%f和%lf分别是float类型和double类型用于格式化输入输出时对应的格式符号。在用于输出时:float类型可以使用%lf格式,但不会有任何好处。double类型如果使用了%f格式可能会导致输出错误。在用于输入时:double 类型使用了%f格式,会导致输入值错误。float类型使用doub...

python %f格式化输出float的三种用法

weixin_47378963的博客

03-22

5566

f是python内置的格式化输出符号,主要用于输出浮点数,一般需要跟print()内置函数进行搭配使用。下面的内容将介绍三种%f的用法。二、%f输出指定小数点后位数的用法。三、%m.nf输出指定位数的用法。一、%f输出浮点数的基本用法。python %f三种用法。

C语言实现外卖管理系统

01-20

本文为大家分享了C语言外卖管理系统的具体代码,供大家参考,具体内容如下

内容

说明(废话):上学期写的课程设计,主题是外卖管理系统,希望可以模拟网上订餐,店家工作,专人管理的过程。并实现注册与登录以及基本信息的输出,因为个人比较懒,一直没有整理上去,今天得空,要是得到大家的宝贵意见的话,会不胜荣幸。

重点内容

  三端登录 :分别为管理员,用户以及店主;两端注册,分别为用户以及店铺,其中店铺的注册成功需要得到管理员的审核。

  管理员端可以查看店铺信息,店铺信息修改(分为增删改查),处理申请店铺,和修改本人信息。

  用户端分为用户相关(为用户本人对自己信息的操作),查看订单,查看

去耦和旁路电路的能量储存

01-20

因为电容器的基本功能是储存电荷,所以理想的去耦电容器可以提供逻辑装置进行状态变换时所需的所有电流。

  其中,ΔI为转换电流;ΔV为允许供电电压的改变(波动);ΔT为切换时间。

  例:如果设计中允许供电电压的波动为100mV;切换时间为10ns;转换电流为20mA;请问需要选用多大的去耦电容?由下式:

  可知,选用0.002llF或2000 pF的去耦电容即可。

  去耦电容的频率响应依赖于对电流突变的需要。在慢速转换时,电源和接地层间的低频阻抗决定了电压变化的多少;在快速转换时,响应是电压波动的时间平均值。高频阻抗决定了在电压快速转变时该电路板初能提供多少电流。在低阻抗下

牛顿法和迭代法求解方程组的近似解

12-05

# include

# include

double picard(double x);

int main()

{

double epsilon,x0,x1;

long i,maxi;

printf("\n请输入 x 的精度要求:");

scanf("%lf",&epsilon);

printf("\n请输入迭代初值:");

scanf("%lf",&x1);

printf("\n请输入最大迭代次数:");

scanf("%ld",&maxi);

for(i=0;i

{

llf算法程序

11-10

llf算法程序

#include

#include

using namespace std;

class Process

{public:

Process();

Process(string n,float ct,float rt,int num):name(n),cycletime(ct),runtime(rt),number(num){}

string getName();

float getCycletime();

float getRuntime();

int getNumber();

void setName();

void setCycletime();

void setRuntime();

void setNumber();

private:

string name;

float cycletime;

float runtime;

int number;//执行次数

};

PCB技术中的去耦和旁路电路的能量储存

11-16

因为电容器的基本功能是储存电荷,所以理想的去耦电容器可以提供逻辑装置进行状态变换时所需的所有电流。

  其中,ΔI为转换电流;ΔV为允许供电电压的改变(波动);ΔT为切换时间。

  例:如果设计中允许供电电压的波动为100mV;切换时间为10ns;转换电流为20mA;请问需要选用多大的去耦电容?由下式:

  可知,选用0.002llF或2000 pF的去耦电容即可。

  去耦电容的频率响应依赖于对电流突变的需要。在慢速转换时,电源和接地层间的低频阻抗决定了电压变化的多少;在快速转换时,响应是电压波动的时间平均值。高频阻抗决定了在电压快速转变时该电路板最初能提供多少电流。在低阻抗

论文研究-基于LLF和RBD检测的红外和可见光图像融合.pdf

09-10

提出一种基于LLF和RBD检测的红外和可见光图像融合方法。运用局部拉普拉斯滤波对红外图像平滑处理和对可见光增强处理,以充分利用红外图像的目标信息和可见光图像的细节信息。在此基础上,采用增强背景检测的RBD显著...

人力资源部工作总结llf.doc

09-30

人力资源部工作总结llf.doc

C++类的成员函数(在类外定义成员函数)

热门推荐

QWQ___qwq的博客

04-25

1万+

类的成员函数(简称类函数)是函数的一种,它的用法和作用和前面介绍过的函数基本上是一样的,它也有返回值和函数类型,它与一般函数的区别只是:它是属于一个类的成员,出现在类体中。它可以被指定为private(私有的)、public (公用的)或protected(受保护的)。

在使用类函数时,要注意调用它的权限(它能否被调用)以及它的作用域(函数能使用什么范围中的数据和函数)。例如私有的成员函数只能被本类中的其它成员函数所调用,而不能被类外调用。成员函数可以访问本类中任何成员(包括私有的和公用的),可以引用在本作

float用%6.2f打印可以吗

最新发布

06-07

可以的。%6.2f 是指输出的浮点数总宽度为6,其中小数部分占2位,整数部分占4位。如果实际输出的浮点数总宽度不足6位,将在左侧填充空格。如果超过6位,则按照实际宽度输出。例如:

```c

float num = 3.14159;

printf("%6.2f", num);

```

输出结果为:

```

3.14

```

其中,浮点数总宽度为6,小数部分占2位,整数部分占4位,因此在左侧填充了一个空格。

“相关推荐”对你有帮助么?

非常没帮助

没帮助

一般

有帮助

非常有帮助

提交

QWQ___qwq

CSDN认证博客专家

CSDN认证企业博客

码龄4年

暂无认证

328

原创

1万+

周排名

7237

总排名

37万+

访问

等级

4099

积分

4219

粉丝

419

获赞

100

评论

1113

收藏

私信

关注

热门文章

一定能解决“糟糕无法安装SQLServer(setup.exe)”问题

32599

关于double和float和int以及%f,%lf,%llf,%Lf以及printf和scanf的总结

17805

LaTeX中数学公式居中左对齐的方法

17672

C++类的成员函数(在类外定义成员函数)

13306

vector的insert函数用法

12722

分类专栏

计算机组成原理

1篇

JavaFX

2篇

XML

4篇

文字识别

商务

替换的任务

文件替换

1篇

正则表达式

1篇

Java

39篇

Servlet

3篇

面试题

1篇

MySQL

4篇

JavaScript

8篇

计算机网络

5篇

C++

59篇

软件工程

1篇

数据结构

11篇

PAT甲级

PAT乙级

106篇

C语言

22篇

Linux

6篇

Vim

3篇

算法分析与设计

6篇

LeetCode

11篇

C#

1篇

LaTex以及Markdown

10篇

微机原理与汇编语言

2篇

开发中的问题及解决方法

9篇

数学

37篇

CS人文

3篇

英语

5篇

最新评论

finalshell连接linux(CentOS)一直弹出输入密码

m0_74279861:

真的感谢!!一小写就弄好了!!!

一定能解决“糟糕无法安装SQLServer(setup.exe)”问题

ZuanWu:

最后一步安装数据库引擎失败怎么解决啊

关于double和float和int以及%f,%lf,%llf,%Lf以及printf和scanf的总结

DBWG:

所以没有%llf long long double 嘛哈哈

【一定能解决】虚拟机安装mac系统报错:客户机操作系统已禁用 CPU,请关闭或重置虚拟机

RayBreslin:

有帮助,谢谢~

float和double在使用scanf和printf的时候用%f还是%lf

快让我离开:

double型输出用%lf时,其实会转为%f输出,所以double型输出用%f和%lf都行,大概是这样的吗?

最新文章

【无标题】

特殊IP地址说明

定点整数的表示范围

2024年7篇

2023年61篇

2022年30篇

2021年256篇

2020年7篇

目录

目录

分类专栏

计算机组成原理

1篇

JavaFX

2篇

XML

4篇

文字识别

商务

替换的任务

文件替换

1篇

正则表达式

1篇

Java

39篇

Servlet

3篇

面试题

1篇

MySQL

4篇

JavaScript

8篇

计算机网络

5篇

C++

59篇

软件工程

1篇

数据结构

11篇

PAT甲级

PAT乙级

106篇

C语言

22篇

Linux

6篇

Vim

3篇

算法分析与设计

6篇

LeetCode

11篇

C#

1篇

LaTex以及Markdown

10篇

微机原理与汇编语言

2篇

开发中的问题及解决方法

9篇

数学

37篇

CS人文

3篇

英语

5篇

目录

评论 1

被折叠的  条评论

为什么被折叠?

到【灌水乐园】发言

查看更多评论

添加红包

祝福语

请填写红包祝福语或标题

红包数量

红包个数最小为10个

红包总金额

红包金额最低5元

余额支付

当前余额3.43元

前往充值 >

需支付:10.00元

取消

确定

下一步

知道了

成就一亿技术人!

领取后你会自动成为博主和红包主的粉丝

规则

hope_wisdom 发出的红包

实付元

使用余额支付

点击重新获取

扫码支付

钱包余额

0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。 2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值

lf是什么意思_lf的翻译_音标_读音_用法_例句_爱词霸在线词典

么意思_lf的翻译_音标_读音_用法_例句_爱词霸在线词典首页翻译背单词写作校对词霸下载用户反馈专栏平台登录lf是什么意思_lf用英语怎么说_lf的翻译_lf翻译成_lf的中文意思_lf怎么读,lf的读音,lf的用法,lf的例句翻译人工翻译试试人工翻译翻译全文lf释义abbr.light face 细体铅字大小写变形:LFLf点击 人工翻译,了解更多 人工释义实用场景例句全部As a high - tech enterprise, Lefu produces LF - 6000 multi - parameter patient monitor series.本公司是一家民营高科技公司.生产LF -6000 系列彩色 多参数 监护仪.互联网The level two control system of 210 t LF is developed.本文以210吨LF炉 为研究对象,开发LF炉二级控制系统.互联网With XML, a new line is always stored as LF.在XML中, 新的一行会作为LF储存起来.互联网Frequency domain: total frequency components ( TF ), low frequency components ( LF ), high frequency components ( HF ).频域分析: 总频谱成分 ( TF ), 低频成分 ( LF ), 高频成分 ( HF ).互联网Frequency domain: total frequency components ( TF ), low frequency components ( LF ), frequency components ( HF ).频域分析: 总频谱成分 ( TF ), 低频成分 ( LF ), 高频成分 ( HF ).互联网LF can be a buffer for a speed continuous casting by proper control of refining process.通过控制合理的精炼工艺,使在连铸快节奏情况下,LF起 到缓冲调节作用.互联网The LF - A concept car is undoubtedly a rising star at the Auto Shanghai 2005.lf-a概念 车无疑是本届上海国际车展上一颗璀璨耀眼的明星.互联网Are we masochlsts or optlmlsts, lf we contlnue to walk that flne llne?若我们继续走在那条线上我们是被虐狂或只是乐观?电影对白Happy, the ball has lts own energy or llfe force, lf you wlll.海皮, 球也有自己的能量或者生命力, 如果你能给它.电影对白A digital aircraft anti - skid braking controller based on embedded DSP - TMS 320 LF 2407 was introduced.介绍了一种基于嵌入式DSP芯片TMS320LF2407的数字化飞机防滑刹车控制器.互联网I sent him away because I was tired lf his idle chatter.我把他迁走了,因为他那无聊的闲扯使我厌烦.互联网Everybody thinks of changing humanity and nobody thinks lf changing himself.人人都想改变人性,但谁都没想到要改变自己.互联网Each additional skill level increases the amount lf health gained by 25 %.每一次技能级别的提升可以增加25%的生命值.互联网MF LF communication is one of our armys important communication methods.中长波通信是我军重要通信手段之一.互联网A brushless DC motor servo - control system based on TMS 320 LF 2407 was designed.应用TMS320LF2407芯片设计了一套无刷直流电动机伺服控制系统.互联网收起实用场景例句英英释义Noun1. 30 to 300 kilohertz收起英英释义释义实用场景例句英

LF电子竞技俱乐部_百度百科

竞技俱乐部_百度百科 网页新闻贴吧知道网盘图片视频地图文库资讯采购百科百度首页登录注册进入词条全站搜索帮助首页秒懂百科特色百科知识专题加入百科百科团队权威合作下载百科APP个人中心收藏查看我的收藏0有用+10LF电子竞技俱乐部播报讨论上传视频电子竞技俱乐部LF电子竞技俱乐部是一家中国电子竞技俱乐部,旗下主要拥有《决战!平安京》等电竞分部。 [1]中文名LF电子竞技俱乐部外文名LuckyFuture创办时间2017年3月创办地点中国运动项目电子竞技目录1团队历史▪2017年▪2018年▪2019年▪2020年▪2021年▪2022年▪2023年2队员列表3数据统计4团队荣誉▪赛事获奖▪俱乐部获奖团队历史播报编辑2017年旗下守望先锋分部LF战队在守望先锋时空杯春季赛成功晋级淘汰赛,在淘汰赛首轮以1:2败于X6战队进入败者组,随后在败者组上败于MY战队遭到淘汰。 [2]接下来在斗鱼NGACUP第三赛季上LF战队成功晋级淘汰赛,在淘汰赛上接连战胜BA战队及MY战队晋级半决赛,随后败于WE.W战队止步四强。 [3]同年6月在OWPS春季赛上LF战队成功晋级淘汰赛,在半决赛上败于1246战队遭到淘汰,随后在季军赛上以3:0战胜OMG战队取得季军。 [4]2017年12月,LF电子竞技俱乐部正式成立决战平安京分部。2018年2018年LF电子竞技俱乐部成立LF战队及LFZ战队2支守望先锋战队,LFZ战队在2018中国区《守望先锋挑战者系列赛》(以下简称OWC 中国赛区)第一赛季上成功晋级季后赛,在季后赛上接连战胜LF战队、T1w战队及LGD战队成功取得冠军。 [5]同年6月在LanStory Cup成都站上LFZ战队战胜LGD战队取得冠军。 [20]接下来在OWC 中国赛区第二赛季是上LFZ战队再次取得冠军。 [6]接下来在OWC 中国赛琪第三赛季LF战队成功晋级季后赛,在季后赛首轮败于T1w战队遭到淘汰。 [7]旗下决战平安京分部LF战队在《决战!平安京》春和御赏大赛上成功晋级总决赛,在总决赛上败于ToT战队止步亚军。 [8]同年9月在CBEL商业电竞超级联赛《决战!平安京》项目总决赛上LF战队战胜VTG战队取得冠军。 [9]旗下炉石传说分部在2018年HTS战队联赛取得冠军。同年6月在2018黄金公开赛苏州站专业组月影杀手取得冠军。 [21]同年12月在第二届中国电子竞技创新大赛《炉石传说》项目选手白皓月取得冠军。 [23]随后在2018《炉石传说》黄金公开赛三亚站上XiaoT取得专业组冠军。 [22]2019年旗下决战平安京分部LF战队在OPL春季赛上成功晋级季后赛,在季后赛首轮战胜FTG战队晋级半决赛,随后在半决赛上以3:4败于OG战队止步四强。同年OPL秋季赛上LF战队成功晋级总决赛,在总决赛上战胜OMG战队取得冠军。 [10]旗下炉石传说分部LF战队在《炉石传说》黄金战队联赛春季赛上取得冠军。 [19]2019年5月,LF电子竞技俱乐部成立使命召唤手游分部。 [18]2020年旗下决战平安京分部LF战队在OPL春季赛上成功晋级季后赛并最终晋级决赛,在决赛上以4:1战胜OMG战队取得冠军。 [11]同年6月在2020《决战!平安京》季中邀请赛上LF战队取得冠军。 [13]同年8月在2020年暑期赛上LF战队再次取得冠军。 [12]接下来在OPL秋季上LF战队成功晋级季后赛,在季后赛败者组决赛上败于ESG战队止步季军。 [14]2021年旗下决战平安京分部LF战队在OPL春季赛成功晋级季后赛,在季后赛接连战胜BLG.M战队、ODG战队晋级总决赛,在总决赛再次战胜ODG战队取得冠军。同年在OPL暑期赛上LF战队取得冠军。接下来在OPL秋季上LF战队在总决赛上击败ASTER战队取得冠军。 [15]2022年旗下决战平安京分部LF战队在OPL春季赛成功晋级季后赛,在季后赛接连战胜BLG.M战队、ASTER战队晋级总决赛,在总决赛上击败OMG战队取得冠军。同年在OPL暑期赛上LF战队取得冠军。接下来在OPL秋季赛上LF战队成功晋级季后赛并最终晋级总决赛,在总决赛上战胜TK战队取得冠军。 [16]2023年旗下决战平安京分部LF战队在OPL春季赛成功晋级季后赛,在季后赛上接连战胜ASTER战队、OMG战队晋级总决赛,随后在总决赛上击败LNG.M战队取得冠军。同年OPL秋季赛上LF战队以18胜0负的战绩晋级季后赛,在季后赛首轮战胜ESG战队晋级胜者组半决赛,随后败于LNG.M战队进入败者组,在败者组上再次战胜ESG战队晋级决赛,在决赛上成功击败LNG.M战队取得冠军。 [17]队员列表播报编辑决战!平安京分部比赛ID姓名图片xiaowei上路团队定妆照cold打野hades中路Yelan射手MMT辅助(以上名单截止于2023年OPL秋季赛 [24])数据统计播报编辑《决战!平安京赛事数据》赛季出场局数胜/负胜率总击杀总死亡总助攻 场均视野占有率场均金钱场均大蛇场均石距2023秋季赛季后赛2213/959.1%19514146655.2%452990.60.42023秋季赛常规赛7454/2073.0%818475201451.2%496060.80.52023春季赛常规赛6743/2464.2%751462201053.5%493920.80.42022秋季赛常规赛3127/487.1%443216120851.5%549501.10.72022暑期赛常规赛1412/285.7%19110750748.8%490381.00.62022春季赛季后赛1510/566.7%1529641952.5%467590.71.12022春季赛常规赛3126/583.9%384188100648.7%468370.90.52021秋季赛季后赛76/185.7%833420741.1%441711.11.92021秋季赛常规赛2927/293.1%450193117447.4%491201.21.72021暑期赛常规赛1612/475.0%19610848744.2%488500.91.82021春季赛季后赛117/463.6%12610628148.7%435170.81.62021春季赛常规赛3227/584.4%469290104346.8%468810.91.82020秋季赛季后赛84/450.0%696819849.6%455200.90.92020秋季赛常规赛7744/3357.1%854647203150.8%466570.71.42020暑期赛季后赛104/640.0%11911024853.7%528101.01.62020暑期赛常规赛7046/2465.7%1033697231448.4%564151.11.22020春季赛季后赛2818/1064.3%31126877950.3%506341.11.52020春季赛常规赛3826/1268.4%484384108049.7%525700.91.42019秋季赛季后赛1813/572.2%23520855450.6%574930.91.12019秋季赛常规赛5542/1376.4%836507197655.6%495221.11.52019春季赛常规赛6546/1970.8%874594205153.9%492810.91.4(以上数据来自决战平安京赛事中心 [24])团队荣誉播报编辑赛事获奖决战!平安京分部(不完全统计)奖项图片2018年《决战!平安京》春和御赏大赛亚军 [8]CBEL商业电竞超级联赛《决战!平安京》项目夺冠2019年OPL秋季赛夺冠2023年OPL秋季赛夺冠CBEL商业电竞超级联赛《决战!平安京》项目冠军 [9]2019年OPL春季赛四强 [10]2019年OPL秋季赛冠军 [10]2020年OPL春季赛冠军 [11]2020年《决战!平安京》季中邀请赛冠军 [13]2020年OPL暑期赛冠军 [12]2020年OPL秋季赛季军 [14]2021年OPL春季赛冠军 [15]2021年OPL暑期赛冠军 [15]2021年OPL秋季赛冠军 [15]2022年OPL春季赛冠军 [16]2022年OPL暑期赛冠军 [16]2022年OPL秋季赛冠军 [16]2023年OPL春季赛冠军 [17]2023年OPL秋季赛冠军 [17]守望先锋项目(不完全统计)奖项图片2017年斗鱼NGACUP第三赛季四强 [3]2018年OWC 中国赛区第一赛季夺冠2017年OWPS春季赛季军 [4]2018中国区《守望先锋挑战者系列赛》(以下简称OWC 中国赛区)第一赛季冠军 [5]2018年LanStory Cup成都站冠军 [20]OWC 中国赛区第二赛季冠军 [6]炉石传说项目(不完全统计)奖项照片2018年HTS战队联赛取得冠军2019年《炉石传说》黄金战队联赛春季赛夺冠2018黄金公开赛苏州站专业组冠军 [21]第二届中国电子竞技创新大赛《炉石传说》项目冠军 [23]2018《炉石传说》黄金公开赛三亚站冠军 [22]2019年《炉石传说》黄金战队联赛春季赛冠军 [19]俱乐部获奖年份奖项2017年守望先锋年度最佳人气战队 [25]2020年《炉石传说》年度最佳俱乐部(提名) [26]新手上路成长任务编辑入门编辑规则本人编辑我有疑问内容质疑在线客服官方贴吧意见反馈投诉建议举报不良信息未通过词条申诉投诉侵权信息封禁查询与解封©2024 Baidu 使用百度前必读 | 百科协议 | 隐私政策 | 百度百科合作平台 | 京ICP证030173号 京公网安备110000020000