版权声明:本文为CSDN博主(天才2012)原创文章,未经博主同意不得转载。

https://blog.csdn.net/gzzaigcn/article/details/27113957

寥寥数笔,记录我的C语言盲点笔记,仅仅为曾经经历过,亦有误,可交流。

1.implict declartion of function 指的是在预处理时没有函数的申明,但该函数在别的函数中进行了编译与调用。编译能够完毕链接可是会给出warning。须要提前申明
2. sizeof是一个operand操作符,不能直接对其进行&取地址操作。

是一个编译器自己主动算大小的函数,在预处理时。和宏定义有所相似。

sizeof当然不是函数。它是编译的时候处理的
编译时,编译器判断出sizeof參数的类型,sizeof依据这个类型确定一个整数,所以它能够当常量使用
函数肯定不能当常量使用,函数仅仅能执行时求值
3.
1.C语言中,对结构体指针赋值为NULL时,在未对其进行再次改动前,不同意对该结构体取值。由于NULL=0,取0处的内容,程序执行时会出现段错误Segmentation fault。不要对NULL地址取值。这个错误使得在调用须要指针的函数的最好不要传入指针变量,除非自带获取过一个地址如malloc,calloc等。不然这个地址默认是0,一旦在函数内部发生取值赋值时,就会出现段错误。

段错误往往是有对内存的不正当操作引起。使的程序在执行是侵占内存,系统检測到后强制终止程序执行,以防止系统死机。

2.在使用malloc使要确定是否分配所需的内存大小。不然程序訪问超出的那些内存时往往不在是你原本想象的数值,系统已经将这些内存自我实现了回收机制,仅仅留下你申请的那部分。

或许你能再次訪问到这块内存,可是终于的结果肯定是内存已经回收清空,系统这样做的优点就是看不是堆内存链表中的区域。自行回收,使系统更高效。

4.C语言中优良的编程习惯
#ifndef _H_FINGER_API_H_
#define _H_FINGER_API_H_
#ifdef __cplusplus
extern "C" {
#endif
#ifdef __cplusplus
extern "C" }
#endif

这种优点在于定义的头文件在一个c源文件里出现多次时,也不会出现反复的函数申明,同一时候这个也能够将c非常方便的移植到c++去中去。

5 C语言中,对结构体指针赋值为NULL时。在未对其进行再次改动前,不同意对该结构体取值,由于NULL=0,取0处的内容。程序执行时会出现段错误Segmentation fault。
不要对NULL地址取值。

6,for(n = 0 ; n < nLen ; n++)和for(int n = 0 ; n < nLen ; n++)
这两个的差别在与后者的n仅仅能在for这个区域中生效,前者在整个函数域内有效。后者的n不能在for外部使用。c中前者的使用较为理想。

C99的标准

7,函数间数据的传递也能够考虑使用memcpy来对暂时缓存进行拷贝。

可是要记得不能在函数内部把一个暂时缓存区的地址覆给一个传入的指针变量。

由于结束后这部发内容被清空,无意义(除非用malloc申请的内容)

8.全局变量可不能够定义在可被多个.C文件包含的.,h头文件里?为什么?
恩,不能够在多个.c文件使用含有全局变量(已经定义即初始化)的.h文件,由于每一个文件域都有了这个全局变量后。在编译连接时,编译器识别到两个全局变量而且都要分配地址,这种话在放入全局变量区之前就出现连接报错。
解决方法:
1.在.h中申明为extern int a 或者在其它。

c文件文件里声明extern int a。这样这个全局变量编译时就不会报错

可是这个假设仅仅有在一个.c文件里出现定义define或者初始化时。而其它.c仅仅是申明的话,那么这个全局变量就不会报错。

一般假设变量定义了就会分配内存的。出现多个申明,默认找已经定义的那个作为全局数值。

2.对两个相同的变量都加static,就能够。由于仅仅在自己的文件域内有效,在函数的使用方法也相似
关键是不同意在.h中定义的全局变量两赋初值(即定义)!

,由于.h中赋值后,多个文件一旦使用,就相当与反复了两次变量的初始化赋值。这个不同意。

9.在编码中。在.h的头文件里养成仅仅做函数和变量的申明。在.c文件里来详细实现,以及全局变量的定义等等。
10全部未加static前缀的全局变量和函数都具有全局可见性。其它的源文件也能訪问
11
Linux以下的文件换行符为\n(0x0a),差别于window以下的\n\r(两个字节)
Linux以下EOF 为-1二进制文件为0xff.(-1补码)
EOF是文本文件结束的标志。window下在文本文件里。数据是以字符的ASCⅡ代码值的形式存放。普通字符的ASCⅡ代码的范围是32到127(十进制)。EOF的16进制代码为0x1A(十进制为26),因此能够用EOF作为文件结束标志
文本方式 和 二进制方式 的不同在于。

 
1. 文本方式仅仅能读取不包含控制字符(换行除外)的文件 (<32)
2. 文本方式会对换行执行翻译。比方windows下,把文件里的/r/n翻译为/n,把写入文件的/n翻译为/r/n;unix下,把文件里的/n翻译为/n,把写入文件的/n翻译为/n。

12.传入函数的指针假设是须要使用的有必要对其进行NULL检測。

13.C语言中的申明不一定仅仅是申明,int a;系统会给默认的定义值。可是定义int a=1。一定是定义。
还有extern int a;则一定是申明。定义在其它地方,这里仅仅是引用而已。

加externkeyword的声明不是定义而且不分配内存(实际上声明是不分配内存的)。实际上,它仅仅是宣称了已经在其它文件里定义的变量的名称和类型。一个变量能够声明多次,可是仅仅能定义一次。声明仅仅有在他相同是定义时才干初始化,由于仅仅有定义才会分配内存
14。在使用数组或者某些结构体前。最好完毕对其的初始化{0}.memset或者bzero等,由于在局部函数内部,编译器分配的栈空间。初始数值并非为0.须要先初始化为须要的默认值,不然有可能对你兴许程序有影响,而造成比方Segmentation fault(经常是对内存操作出现的错误比較操作的内容块小于分配的大小等等)

15missing braces around initialize
该问题是在结构提中有多个数组在初始化时。没有对每一个进行初始化,从而会出现这个错误如
typedef struct Usr_Info{
    unsigned char ID[ID_LEN];
    unsigned char Finger[FMD_LEN];
    unsigned int  finsih_flag;// 1:one usr info get finsihed
}USR_INFO;
初始化USR_INFO one = {0},会出现警告,须要对每一部分的数组进行初始化。就这样{{0}.{0}.0}。C99的特点
16
ANSI C说明了三个用于存储空间动态分配的函数
(1) malloc   分配指定字节数的存储区。此存储区中的初始值不确定
(2) calloc   为指定长度的对象,分配能容纳其指定个数的存储空间。

该空间中的每一位(bit)都初始化为0
(3) realloc  更改曾经分配区的长度(添加或降低)。当添加长度时,可能需将曾经分配区的内容移到还有一个足够大的区域,而新增区域内的初始值则不确定

17 a[]用作函数參数。会退化成指针。即和*a一样。这样写看上去上更明白一点
18,static申明的函数被同一文件内的函数调用后。这个非static的函数照样能够被其它文件的函数调用,从而能够说是间接的进行了调用static函数。
lld打印64位数据类型。

unsigned long long :lld,64位
long unsigned int: ld = unsigned long int一样
以上是C99中新加的
20。fread(以r读的方式打开),fwrite(以a追加的方式打开)假设是操作2进制文件则加为rb,ab
21.
參数入栈时。不足int的,扩展为int后入栈
比方char(-127)扩展成int(-127)
也就是由 10000001 扩展成 11111111 11111111 11111111 10000001
然后你使用%u,也就是将 11111111 11111111 11111111 10000001 当成 unsigned int 来看。那它当然就是 4294967169 了
22
关于类型提升。有符号扩展, 我看了下《Linux C一站式编程》 的15章的3.5节 “编译器如何处理类型转换”的最后一段。 里面最后一段说:
“最后一个样例,把short型转换成int型。相应表中的“signed integer to signed integer”。转换之后应该值不变。那怎么维持值不变呢?是不是在高位补16个0即可了呢?假设原值是-1,十六进制表示就是ffff,要转成int 型的-1须要变成ffffffff,因此须要在高位补16个1而不是16个0。换句话说。要维持值不变,在高位补1还是补0取决于原来的符号位,这称为符号扩展(Sign Extension)。


   
这是signed integer to signed integer, 为何signed char转为unsigned int时 。也运用了符号扩展??

23宏定义中使用\来屏蔽换行符,这样后面的内容都能够是该宏定义块的内容,直到出现换行符后就意味着该宏内容结束。
24. 指针与静态数组的sizeof操作
      指针均可看为变量类型的一种。全部指针变量的sizeof 操作结果均为4。

注意:int *p; sizeof(p)=4;
                  但sizeof(*p)相当于sizeof(int);      
      对于静态数组。sizeof可直接计算数组大小。
      例:int a[10];char b[]="hello";
              sizeof(a)等于4*10=40;
              sizeof(b)等于6;
 注意:数组做型參时。数组名称当作指针使用!


               void  fun(char p[])
               {sizeof(p)等于4}   

25.C语言复合执行:原则是从右向左依次赋值。能够节省内存开销
a*=a;a=-a;a+=a;a/=a。a|=a;a&=a,a^=a;a=~a(取反)。
负数的取反和变号不一样。取反对每一位包含符号位做取反操作,取负就是原值变换符合后的补码,原数是正,则是负数的补码存在,原数是负。则以正数的原码存在(正数原码和补码一样)
26. C语言中的volatile告知编译器。这个变量不要被编译器优化成寄存器间接訪问变量。不管什么情况下都要使用直接訪问(防止特殊的改变,经常指的是硬件引起的变换),volatile易失的,不稳定的
1. volatile变量可变同意除了程序之外的比方硬件来改动他的内容   
2. 訪问该数据不论什么时候都会直接訪问该地址处内容。即通过cache提高訪问速度的优化被取消。

27 int bit0:1什么意思
位域是指信息在存储时,并不须要占用一个完整的字节, 而仅仅需占几个或一个二进制位。为了节省存储空间,并使处理简便。C语言提供了一种数据结构,称为“位域”或“位段”。所谓“位域”是把一个字节中的二进位划分为几个不同的区域。并说明每一个区域的位数。每一个域有一个域名,同意在程序中按域名进行操作。

这样就能够把几个不同的对象用一个字节的二进制位域来表示
typedef union{
unsigned char value;
struct
{
unsigned int bit0:1;
unsigned int bit1:1;
unsigned int bit2:1;
unsigned int bit3:1;
unsigned int bit4:1;
unsigned int bit5:1;
unsigned int bit6:1;
unsigned int bit7:1;
} bit_field;
} PORT;
28 fstat获取文件的大小等基础信息。ftruncate改变文件大小
ftruncate(fd,length),改为length的长度


C语言编程积累2的更多相关文章

  1. Linux基础与Linux下C语言编程基础

    Linux基础 1 Linux命令 如果使用GUI,Linux和Windows没有什么区别.Linux学习应用的一个特点是通过命令行进行使用. 登录Linux后,我们就可以在#或$符后面去输入命令,有 ...

  2. Linux C语言编程学习笔记 (1)进程控制入门

    想进行Linux系统开发已经很久了,一直没有付诸实践.今日终于开始学习Linux下的C语言编程,研究一天,终于大概弄明白了Linux系统进程管理的一些基本概念和编程方法,总结下来以方便大家学习和自己实 ...

  3. 【转】Linux基础与Linux下C语言编程基础

    原文:https://www.cnblogs.com/huyufeng/p/4841232.html ------------------------------------------------- ...

  4. linux下C语言编程,include的默认搜索路径

    C语言编程时,发现细节的魅力很大.较为详细了看了一下关于include的知识,发现了几点新知: 1.include<头文件名>和include"头文件名" 如:incl ...

  5. C 语言编程习惯总结

    笔者能力有限,如果文中出现错误的地方,还请各位朋友能够给我指出来,我将不胜感激,谢谢~ 引言 编程习惯的培养需要的是一个长期的过程,需要不断地总结,积累,并且我们需要从意识上认识其重要性,一个良好的编 ...

  6. C语言编程实现Linux命令——who

    C语言编程实现Linux命令--who 实践分析过程 who命令是查询当前登录的每个用户,它的输出包括用户名.终端类型.登录日期及远程主机,在Linux系统中输入who命令输出如下: 我们先man一下 ...

  7. 个人c语言编程风格总结

    总结一下我个人的编程风格及这样做的原因吧,其实是为了给实验室写一个统一的C语言编程规范才写的.首先声明,我下面提到的编程规范,是自己给自己定的,不是c语言里面规定的. 一件事情,做成和做好中间可能隔了 ...

  8. Linux下C语言编程实现spwd函数

    Linux下C语言编程实现spwd函数 介绍 spwd函数 功能:显示当前目录路径 实现:通过编译执行该代码,可在终端中输出当前路径 代码实现 代码链接 代码托管链接:spwd.c 所需结构体.函数. ...

  9. 混合语言编程:启用CLR(公共语言运行时编译)让C#调用C++

    前言 关于混合C#和C++的编程方式,本人之前写过一篇博客(参见混合语言编程:C#使用原生的Directx和OpenGL),在之前的博客中,介绍了在C#的Winform和WPF下使用原生的Direct ...

随机推荐

  1. apache 隐藏 index.php

    在根目录下添加文件 .htaccess <IfModule mod_rewrite.c> Options +FollowSymlinks RewriteEngine On RewriteC ...

  2. UML,构件图与部署图

    一.构件图概述 1.概念 用来显示一组构件之间的组织及其依赖关系 2.基本元素 (1)构件:定义了良好接口的物理实现单元. ● 配置构件:形成可执行文件的基础,如:动态链接库(DLL).ActiveX ...

  3. Java服务CPU飙到99%问题排查

    最近生产环境中出现了一起CPU突然飙升的事件,下面介绍一下 CPU飙升问题排查的过程和解决方法. 该方案参考自:https://www.jianshu.com/p/e96c74133be6,感谢路遥N ...

  4. Oracle总结之plsql编程(基础八)

    原创作品,转自请注明出处:https://www.cnblogs.com/sunshine5683/p/10328524.html 一.函数 1.函数是可以返回一个特定的数据,函数的创建中必须包含re ...

  5. Improving the GPA(hdu4968)dfs

    Improving the GPA Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) ...

  6. 1-初识java

    目录 java 历史 Java 平台 Java 开发环境 Java 运行原理[简] Java 历史 这里不详细记录java的历史,只是标记出时间点和事件. 时间点 事件 1991 Sun公司成立Gre ...

  7. Tomcat启动报错:org.apache.catalina.LifecycleException: Failed to start component...java.util.zip.ZipException: error in opening zip file

    1.项目环境 IntelliJ IDEA2018.1.6 apache-tomcat-8.0.53 基于springboot开发的项目 maven3.5.3 2.出现问题 从svn同步下项目 启动to ...

  8. PHP实现批量删除(封装)

    前台 <!DOCTYPE html> <html> <head> <title>批量删除</title> </head> < ...

  9. 记一次MySQL安装出现的坑爹问题。。。

    关键词:mysql安装 msvcr100.dll缺失  vc++2010 : win10系统首次安装mysql,图方便下载了图形界面的安装包(5.6.4),本以为小事一桩:装一半失败.卸载清注册表.重 ...

  10. SpringCloud 组件Eureka参数配置项详解

    Eureka涉及到的参数配置项数量众多,它的很多功能都是通过参数配置来实现的,了解这些参数的含义有助于我们更好的应用Eureka的各种功能,下面对Eureka的配置项做具体介绍,供大家参考. Eure ...