热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C语言中extern的简易编译方法及预编译、static和extern的综合应用解析

本文详细探讨了C语言中`extern`关键字的简易编译方法,并深入解析了预编译、`static`和`extern`的综合应用。通过具体的代码示例,介绍了如何在不同的文件之间共享变量和函数声明,以及这些关键字在编译过程中的作用和影响。文章还讨论了预编译过程中宏定义的使用,为开发者提供了实用的编程技巧和最佳实践。

//

// main.c

// c预编译

//

// Created by stevenchang on 9/6/15.

// Copyright (c) 2015 cz. All rights reserved.

//

#include

/**

宏定义:

1> 不带参数的宏

2> 带参数的宏

*/

//不带参数的宏定义

#define LENGTH 5 //这里定义一个宏,宏的值是不变的,不可以对其进行++

//带参数的宏定义

#define sum(a,b) ((a)+(b)) //带参数的宏,使用时要将参数都要用小括号括住,不然会出现问题

#define Max(a,b) ((a)>(b)?(a):(b)) //求两个参数的最大值

/**

对于文件包含,我们使用的是#include

<> 包含的是系统自带的文件

"" 包含的是自定义的文件

*/

/**

条件编译&#xff1a;

#ifndef &#xff1a;如果未定义

#ifdef &#xff1a;如果定义

#elif

#elif

#endif &#xff1a; 必须以它结尾&#xff0c;不然程序会出错

*/

/**

typedef定义别名

*/

typedef struct Student { //定义了一个类型为结构体的变量stu

int age ;

double weight;

char *name;

} STU;

/**

上面的方式也可以写成&#xff1a;

struct Student {

int age;

double weight;

char *name;

};

typedef struct Student STU;

*/

typedef char * String; //定义一个指针为String,用于指向字符串

#define String1 char *; //这样定义也是可以的&#xff0c;但是使用这种是定义的宏&#xff0c;再编译的时候只会将String1进行替换&#xff0c;因此如果String1 s3, s4; 这种情况下&#xff0c;s4不是指针类型。实际为&#xff1a;char * s3, s4;

/**

static 作用于函数&#xff1a; static function_name();用于声明和定义一个内部函数&#xff0c;作用范围在当前文件有效&#xff1b;

extern 作用于函数&#xff1a; 用于声明和定义一个外部函数&#xff1b;默认情况下都是外部函数&#xff0c;因此可以省略。

extern 作用于变量 &#xff1a; 用于声明一个外部变量&#xff0c;默认情况下都是外部变量&#xff0c;因此可以省略&#xff1b;

static 作用于变量 &#xff1a; 用于声明一个内部变量&#xff0c;作用范围是&#xff1a;从当前定义开始&#xff0c;知道文件结束。

我们使用static作用变量的时候&#xff0c;static只分配一次内存空间&#xff0c;以后不会再次分配。

*/

void initArray(int array[]); //声明一个初始化数组的函数

void test();

int main(int argc, const char * argv[]) {

// insert code here...

// printf("Hello, World!\n");

int a[LENGTH]; //定义一个数组变量

initArray(a);

printf("&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;\n");

int b &#61; 10;

int c &#61; 20;

int result &#61; sum(b, c);

printf("%d\n",result);

printf("&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;\n");

double d &#61; 34.5;

double e &#61; 35.4;

double res &#61; Max(d, e);

printf("%.2f\n",res);

printf("&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;\n");

STU stu &#61; {13,23.4,"adfafa"};

printf("age&#61;%d,weight&#61;%f,name&#61;%s\n",stu.age,stu.weight,stu.name);

printf("&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;\n");

String str &#61; "steven";

printf("%s\n",str);

printf("&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;\n");

test();

test();

//可以发现num 最终值为12&#xff0c;说明num的声明周期不是在方法结束的时候就释放的

return 0;

}

/**

初始化数组函数&#xff1a;int array[]&#xff1a;数组变量&#xff1b; LENGTH&#xff1a;数组长度

*/

void initArray(int array[]) {

for (int i &#61; 0; i

array[i] &#61; i &#43; 1;

}

}

void test() {

static int num &#61; 10;

num&#43;&#43;;

printf("%d\n",num);

}



推荐阅读
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 异常要理解Java异常处理是如何工作的,需要掌握一下三种异常类型:检查性异常:最具代表性的检查性异常是用户错误或问题引起的异常ÿ ... [详细]
  • 本文详细介绍了C++中map容器的多种删除和交换操作,包括clear、erase、swap、extract和merge方法,并提供了完整的代码示例。 ... [详细]
  • 本文深入探讨了SQL数据库中常见的面试问题,包括如何获取自增字段的当前值、防止SQL注入的方法、游标的作用与使用、索引的形式及其优缺点,以及事务和存储过程的概念。通过详细的解答和示例,帮助读者更好地理解和应对这些技术问题。 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • 本问题探讨了在特定条件下排列儿童队伍的方法数量。题目要求计算满足条件的队伍排列总数,并使用递推算法和大数处理技术来解决这一问题。 ... [详细]
  • 深入理解Lucene搜索机制
    本文旨在帮助读者全面掌握Lucene搜索的编写步骤、核心API及其应用。通过详细解析Lucene的基本查询和查询解析器的使用方法,结合架构图和代码示例,带领读者深入了解Lucene搜索的工作流程。 ... [详细]
  • 深入解析for与foreach遍历集合时的性能差异
    本文将详细探讨for循环和foreach(迭代器)在遍历集合时的性能差异,并通过实际代码示例和源码分析,帮助读者理解这两种遍历方式的不同之处。文章内容丰富且专业,旨在为编程爱好者提供有价值的参考。 ... [详细]
  • JSOI2010 蔬菜庆典:树结构中的无限大权值问题
    本文探讨了 JSOI2010 的蔬菜庆典问题,主要关注如何处理非根非叶子节点的无限大权值情况。通过分析根节点及其子树的特性,提出了有效的解决方案,并详细解释了算法的实现过程。 ... [详细]
  • 题目描述:给定一个N*M的网格,初始时网格中有k个芯片,每个芯片的位置已知。玩家可以在每一步操作中将所有芯片沿同一方向移动一格。如果芯片到达边界,则保持不动。目标是通过一系列操作,使每个芯片依次访问指定的目标位置。 ... [详细]
  • 本题要求实现一个函数,用于检查给定的字符串是否为回文。回文是指正向和反向读取都相同的字符串。例如,“XYZYX”和“xyzzyx”都是回文。 ... [详细]
  • ------------------------------————————————————————————————1.定义一个类,实现与被增强对象相同的接口2.在类中定义一个对象,记住被增强 ... [详细]
  • PHP 实现多级树形结构:构建无限层级分类系统
    在众多管理系统中,如菜单、分类和部门等模块,通常需要处理层级结构。为了高效管理和展示这些层级数据,本文将介绍如何使用 PHP 实现多级树形结构,并提供代码示例以帮助开发者轻松实现无限分级。 ... [详细]
  • 本文探讨了如何通过预处理器开关选择不同的类实现,并解决在特定情况下遇到的链接器错误。 ... [详细]
author-avatar
你我她啊
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有