C语言在线运行

版本:
运行结果
教程手册
代码仓库
极速运行
终端运行
图形+终端

                        
以下是用户最新保存的代码
2. 线性计数排序的设计、分析与实现: 发布于:2023-12-04 15:39 时空权衡 1.计数排序的设计、分析与实现 发布于:2023-12-04 15:36 线性计数排序的设计、分析与实现 发布于:2023-12-04 08:53 线性排序测试 发布于:2023-12-04 08:51 计数排序的设计、分析与实现 发布于:2023-12-04 08:51 计数排序测试 发布于:2023-12-04 08:44 计数排序实现 发布于:2023-12-04 08:31 线性计数排序 发布于:2023-12-04 07:47 线性计数排序--可重复数据 发布于:2023-12-04 00:52 简单的ringbuffer 发布于:2023-12-03 23:42 线性排序代码 发布于:2023-12-03 23:33 计数排序的实现 发布于:2023-12-03 23:30 线性计数排序实验 发布于:2023-12-03 23:10 计数排序实验 发布于:2023-12-03 23:08 线性计数排序 发布于:2023-12-03 22:57 计数排序实现 发布于:2023-12-03 22:57 线性计数排序实现 发布于:2023-12-03 22:49 计数排序实现 发布于:2023-12-03 22:47 线性的基数排序 发布于:2023-12-03 22:47 计数排序实现 发布于:2023-12-03 22:47 实现计数排序以及线性计数排序 发布于:2023-12-03 22:30 线性记数排序 发布于:2023-12-03 22:22 计数字排序 发布于:2023-12-03 22:19 计数排序,时空权衡 发布于:2023-12-03 22:17 计数排序实现 发布于:2023-12-03 19:42 2. 线性计数排序 发布于:2023-12-03 19:39 线性计数排序 发布于:2023-12-03 19:39 Hello, RSA! 发布于:2023-12-03 17:15 线性计数排序 发布于:2023-12-03 17:11 计数排序。 发布于:2023-12-03 17:03 计数排序线性技术排序 发布于:2023-12-03 16:24 线性计数排序 发布于:2023-12-03 15:43 线性计数排序 发布于:2023-12-03 14:58 时空权衡实验 发布于:2023-12-02 21:59 2021年程序设计题4 发布于:2023-12-01 22:12 计数排序算法 发布于:2023-12-01 17:34 DGUSII 校验码 发布于:2023-12-01 15:44 数组添加头部字节 发布于:2023-12-01 14:00 创建函数调用 发布于:2023-11-30 17:33 一个数各位数字之和 发布于:2023-11-30 00:40 计数排序实现 发布于:2023-11-29 21:25 计数排序(基于比较) 发布于:2023-11-29 19:58 计数排序算法 发布于:2023-11-29 19:58 计数排序额 发布于:2023-11-29 20:28 计算日期 的程序 发布于:2023-12-01 16:35 堆排序实验 发布于:2023-11-29 17:58 这个是堆排序算法 发布于:2023-11-29 16:51 堆排序实现 发布于:2023-11-29 14:07 线性计数排序 发布于:2023-11-29 10:06 统计排序(非线性) 发布于:2023-11-29 09:28 [更多]
显示目录

储存类



C 存储类

存储类定义 C 程序中变量/函数的范围(可见性)和生命周期。这些说明符放置在它们所修饰的类型之前。

C 程序中可用的存储类:auto、register、static、extern

auto 存储类

auto 存储类是所有局部变量默认的存储类。

{
   int mount;
   auto int month;
}

上面的实例定义了两个带有相同存储类的变量,auto 只能用在函数内,即 auto 只能修饰局部变量。

register 存储类

register 存储类用于定义存储在寄存器中而不是 RAM 中的局部变量。这意味着变量的最大尺寸等于寄存器的大小(通常是一个词),且不能对它应用一元的 '&' 运算符(因为它没有内存位置)。

{
   register int  miles;
}

寄存器只用于需要快速访问的变量,比如计数器。还应注意的是,定义 'register' 并不意味着变量将被存储在寄存器中,它意味着变量可能存储在寄存器中,这取决于硬件和实现的限制。

static 存储类

static 存储类指示编译器在程序的生命周期内保持局部变量的存在,而不需要在每次它进入和离开作用域时进行创建和销毁。因此,使用 static 修饰局部变量可以在函数调用之间保持局部变量的值。

static 修饰符也可以应用于全局变量。当 static 修饰全局变量时,会使变量的作用域限制在声明它的文件内。

在 C 编程中,当 static 用在类数据成员上时,会导致仅有一个该成员的副本被类的所有对象共享。

    #include <stdio.h>

    /* 函数声明 */
    void func(void);

    static int count = 5; /* 全局变量 */

    main()
    {
       while(count--)
       {
          func();
       }
       return 0;
    }
    /* 函数定义 */
    void func( void )
    {
       static int i = 5; /* 局部静态变量 */
       i++;

       printf("i is %d and count is %d\n", i, count);
    }

运行上述实例

可能您现在还无法理解这个实例,因为我已经使用了函数和全局变量,这两个概念目前为止还没进行讲解。即使您现在不能完全理解,也没有关系,后续的章节我们会详细讲解。当上面的代码被编译和执行时,它会产生下列结果:

i is 6 and count is 4
i is 7 and count is 3
i is 8 and count is 2
i is 9 and count is 1
i is 10 and count is 0

extern 存储类

extern 存储类用于提供一个全局变量的引用,全局变量对所有的程序文件都是可见的。当您使用 'extern' 时,对于无法初始化的变量,会把变量名指向一个之前定义过的存储位置。

当您有多个文件且定义了一个可以在其他文件中使用的全局变量或函数时,可以在其他文件中使用 extern 来得到已定义的变量或函数的引用。可以这么理解,extern 是用来在另一个文件中声明一个全局变量或函数。

extern 修饰符通常用于当有两个或多个文件共享相同的全局变量或函数的时候,如下所示:

第一个文件:main.c

    #include <stdio.h>

    int count ;
    extern void write_extern();

    main()
    {
       count = 5;
       write_extern();
    }

第二个文件:support.c

    #include <stdio.h>

    extern int count;

    void write_extern(void)
    {
       printf("count is %d\n", count);
    }

在这里,第二个文件中的 extern 关键字用于声明已经在第一个文件 main.c 中定义的 count。现在 ,编译这两个文件,如下所示:

 $gcc main.c support.c

这会产生 a.out 可执行程序,当程序被执行时,它会产生下列结果:

count is 5
由JSRUN为你提供的C语言在线运行、在线编译工具
        JSRUN提供的C语言 在线运行,C语言 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。