c语言之SQLite数据库开发

一、数据库的安装 // 准备软件包 libsqlite3-0_3.7.2-1ubuntu0.1_i386.deb libsqlite3-dev_3.7.2-1ubuntu0.1_i386.deb sqlite3_3.7.2-1ubuntu0.1_i386.deb // 安装 sudo dpkg -i *.deb 二、 数据库命令 (一)系统命令(以.开头) .exit .quit .table //查看表 .schema //查看表的结构 (二)sql语句(以‘;’结尾) // 1-- 创建一张表 create table stuinfo(id integer, name text, age integer, score float); // 2-- 插入一条记录 insert into stuinfo values(1001, 'zhangsan', 18, 80); insert into stuinfo (id, name, score) values(1002, 'lisi', 90); // 3-- 查看数据库记录 select * from stuinfo; select * from stuinfo where score = 80; select * from stuinfo where score = 80 and name= 'zhangsan'; select * from stuinfo where score = 80 or name='wangwu'; select name,score from stuinfo; //查询指定的字段 select * from stuinfo where score >= 85 and score < 90; // 4-- 删除一条记录 delete from stuinfo where id=1003 and name='zhangsan'; // 5-- 更新一条记录 ...

c语言之变量

一、变量内容

  • 变量基础
  • 变量说明
  • 变量存储类型

二、变量基础

变量在程序中用变量名表示。变量名由用户根据其用途任意命名。

变量名由字母、数字、下划线组成,不能以数字开头,不能和C的关键字重名。

在程序运行时,变量占据存储空间的大小由其数据类型决定。

变量在内存空间中的首地址,称为变量的地址。

三、变量说明

变量在程序中使用时,必须预先说明它们的存储类型和数据类型。

变量说明的一般形式是:

<存储类型> <数据类型 > <变量名> ;

  • <存储类型>是关键词auto、register、static和extern
  • <数据类型>可以是基本数据类型,也可以是自定义的数据类型

如:

#include <stdio.h>

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

    register int a = 10;
    printf("a=%d\n", a);

    return 0;

}

四、变量存储类型

1、auto & register

  • auto

auto说明的变量只能在某个程序范围内使用,通常在函数体内或函数中的复合语句里。(默认是随机值)

在函数体的某程序段内说明auto存储类型的变量时可以省略关键字auto,如下:

 auto int  k ;

 int  j ;

 double x;
  • register

register称为寄存器型,register变量是想将变量放入CPU的寄存器中,这样可以加快程序的运行速度。

如申请不到就使用一般内存,同auto ;

标识常量

注意

  • register变量必须是能被CPU所接受的类型。这通常意味着register变量必须是一个单个的值,并且长度应该小于或者等于整型的长度。
  • 不能用“&”来获取register变量的地址。

由于寄存器的数量有限,真正起作用的register修饰符的数目和类型都依赖于运行程序的机器。

在某些情况下,把变量保存在寄存器中反而会降低程序的运行速度。因为被占用的寄存器不能再用于其它目的;或者变量被使用的次数不够多,不足以装入和存储变量所带来的额外开销。

2、static & extern

  • static

static变量称为静态存储类型的变量,既可以在函数体内,也可在函数体外说明。(默认是0)

局部变量使用static修饰,有以下特点:

  • 在内存中以固定地址存放的,而不是以堆栈方式存放
  • 只要程序没结束,就不会随着说明它的程序段的结束而消失,它下次再调用该函数,该存储类型的变量不再重新说明,而且还保留上次调用存入的数值
#include <stdio.h>

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

    int i = 1;

    while (i < 5) {
        //int a = 0;  每次循环a被重新赋值为o,所以a=1
        //static int a = 0; 每次循环a上次的值都在,所以a=1,2,3,4,类似全局变量
        a++;
        printf("a=%d\n", a);
        i++;
    }

}
  • extern

当变量在一个文件中的函数体外说明,所有其他文件中的函数或程序段都可引用这个变量。

extern称为外部参照引用型,使用extern说明的变量是想引用在其它文件中函数体外部说明的变量。

static修饰的全部变量,其它文件无法使用

  • extern_static1.c
// static int global_a = 100; 这样声明其它文件无法使用

int global_a = 100;
  • extern_static2.c
#include <stdio.h>

extern int global_a; //外部文件的引用

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

    printf("global_a=%d\n", global_a);

    return 0;
}

通过命令gcc extern_static1.c extern_static2.c -Wall进行编译。

此博客中的热门博文

玩转虚拟机系列之如何搭建虚拟机

玩转虚拟机系列之远程工具

玩转虚拟机系列之如何高效创建虚拟机