学C51的基础 9 《 指针、结构、联合和枚举 》

发布者:chuyifei最新更新时间:2015-03-10 来源: laogu关键字:C51  指针  结构  联合  枚举 手机看文章 扫描二维码
随时随地手机看文章
指针、结构、联合和枚举
    本节专门对第二节曾讲述过的指针作一详述。并介绍Turbo C新的数据类型: 结构、联合和枚举, 其中结构和联合是以前讲过的
五种基本数据类型(整型、浮点型、字符型、指针型和无值型)的组合。枚举是一个被命名为整型常数的集合。最后对类型说明
(typedef)和预处理指令作一阐述。

                                     指       针(point)

    学习Turbo C语言, 如果你不能用指针编写有效、正确和灵活的程序, 可以认为你没有学好C语言。指针、地址、数组及其相互
关系是C语言中最有特色的部分。规范地使用指针,可以使程序达到简单明了, 因此, 我们不但要学会如何正确地使用指针, 而且要
学会在各种情况下正确地使用指针变量。

    1. 指针和地址
    1.1 指针基本概念及其指针变量的定义
    1.1.1 指针变量的定义
    我们知道变量在计算机内是占有一块存贮区域的, 变量的值就存放在这块区域之中, 在计算机内部, 通过访问或修改这块区域
的内容来访问或修改相应的变量。Turbo C语言中, 对于变量的访问形式之一, 就是先求出变量的地址, 然后再通过地址对它进行
访问, 这就是这里所要论述的指针及其指针变量。
    所谓变量的指针, 实际上指变量的地址。变量的地址虽然在形式上好象类似于整数, 但在概念上不同于以前介绍过的整数, 它
属于一种新的数据类型, 即指针类型。Turbo C中, 一般用"指针"来指明这样一个表达式&x的类型, 而用 "地址" 作为它的值, 也就
是说, 若x为一整型变量, 则表达式&x的类型是指向整数的指针, 而它的值是变量x的地址。同样, 若
     double d;

则&d的类型是指向以精度数d的指针, 而&d的值是双精度变量d的地址。所以, 指针和地址是用来叙述一个对象的两个方面。虽然
&x、&d的值分别是整型变量x 和双精度变量d的地址,但&x、&d的类型是不同的, 一个是指向整型变量x的指针, 而另一个则是指向
双精度变量d的指针。在习惯上,  很多情况下指针和地址这两个术语混用了。
    我们可以用下述方法来定义一个指针类型的变量。
     int *ip;
首先说明了它是一指针类型的变量, 注意在定义中不要漏写符号"*",否则它为一般的整型变量了。另外, 在定义中的int 表示该指
针变量为指向整型数的指针类型的变量, 有时也可称ip为指向整数的指针。ip是一个变量, 它专门存放整型变量的地址。
    指针变量的一般定义为:
       类型标识符  *标识符;
    其中标识符是指针变量的名字, 标识符前加了"*"号, 表示该变量是指针变量, 而最前面的"类型标识符"表示该指针变量所指向
的变量的类型。一个指针变量只能指向同一种类型的变量, 也就是讲, 我们不能定义一个指针变量, 既能指向一整型变量又能指向
双精度变量。
    指针变量在定义中允许带初始化项。如:
        int i, *ip=&i;
注意, 这里是用&i对ip初始化, 而不是对*ip初始化。和一般变量一样, 对于外部或静态指针变量在定义中若不带初始化项, 指针
变量被初始化为NULL, 它的值为0。Turbo C中规定, 当指针值为零时,指针不指向任何有效数据, 有时也称指针为空指针。因此,
当调用一个要返回指针的函数(第五节中介绍)时, 常使用返回值为NULL来指示函数调用中某些错误情况的发生。
    1.1.2 指针变量的引用
    既然在指针变量中只能存放地址, 因此, 在使用中不要将一个整数赋给一指针变量。下面的赋值是不合法的:
     int *ip;
     ip=100;
假设
     int i=200, x;
     int *ip;
我们定义了两个整型变量i, x, 还定义了一个指向整型数的指针变量ip。i, x中可存放整数, 而ip中只能存放整型变量的地址。
我们可以把i的地址赋给ip:
     ip=&i;
此时指针变量ip指向整型变量i, 假设变量i的地址为1800, 这个赋值可形象理解为下图所示的联系。
            ip               i
        ┏━━━┓       ┏━━━┓
        ┃ 1800 ╂──→ ┃ 200  ┃
        ┗━━━┛       ┗━━━┛
            图1. 给指针变量赋值
以后我们便可以通过指针变量ip间接访问变量i, 例如:
     x=*ip;
运算符*访问以ip为地址的存贮区域, 而ip中存放的是变量i的地址, 因此, *ip访问的是地址为1800的存贮区域(因为是整数, 实
际上是从1800开始的两个字节), 它就是i所占用的存贮区域, 所以上面的赋值表达式等价于
     x=i;
    另外, 指针变量和一般变量一样, 存放在它们之中的值是可以改变的, 也就是说可以改变它们的指向, 假设
     int i, j, *p1, *p2;
     i='a';
     j='b';
     p1=&i;
     p2=&j;
则建立如下图所示的联系:
            p1               i
        ┏━━━┓       ┏━━━┓
        ┃      ╂──→ ┃ 'a'  ┃
        ┗━━━┛       ┗━━━┛
            p2               i
        ┏━━━┓       ┏━━━┓
        ┃      ╂──→ ┃ 'b'  ┃
        ┗━━━┛       ┗━━━┛
             图2. 赋值运算结果
这时赋值表达式:
     p2=p1
就使p2与p1指向同一对象i, 此时*p2就等价于i, 而不是j, 图2.就变成图3.所示:
            p1               i
        ┏━━━┓       ┏━━━┓
        ┃      ╂──→ ┃ 'a'  ┃
        ┗━━━┛  ┌→ ┗━━━┛
            p2      │       j
        ┏━━━┓  │   ┏━━━┓
        ┃      ╂─┘   ┃ 'b'  ┃
        ┗━━━┛       ┗━━━┛
            图3. p2=p1时的情形
如果执行如下表达式:
     *p2=*p1;
则表示把p1指向的内容赋给p2所指的区域, 此时图2.就变成图4.所示
            p1               i
        ┏━━━┓       ┏━━━┓
        ┃      ╂──→ ┃ 'a'  ┃
        ┗━━━┛       ┗━━━┛
            p2               j
        ┏━━━┓       ┏━━━┓
        ┃      ╂──→ ┃ 'a'  ┃
        ┗━━━┛       ┗━━━┛
            图4. *p2=*p1时的情形
    通过指针访问它所指向的一个变量是以间接访问的形式进行的, 所以比直接访问一个变量要费时间, 而且不直观, 因为通过指
针要访问哪一个变量, 取决于指针的值(即指向), 例如"*p2=*p1;"实际上就是"j=i;", 前者不仅速度慢而且目的不明。但由于指针
是变量, 我们可以通过改变它们的指向, 以间接访问不同的变量, 这给程序员带来灵活性, 也使程序代码编写得更为简洁和有效。
    指针变量可出现在表达式中, 设
     int x, y *px=&x;
指针变量px指向整数x, 则*px可出现在x能出现的任何地方。例如:
     y=*px+5;  /*表示把x的内容加5并赋给y*/
     y=++*px;  /*px的内容加上1之后赋给y  [++*px相当于++(px)]*/
     y=*px++;  /*相当于y=*px; px++*/

    1.2. 地址运算
    指针允许的运算方式有:
    (1). 指针在一定条件下, 可进行比较, 这里所说的一定条件, 是指两个指针指向同一个对象才有意义, 例如两个指针变量p,
q指向同一数组, 则<, >, >=, <=, ==等关系运算符都能正常进行。若p==q为真, 则表示p, q指向数组的同一元素; 若p < q为真,
则表示p所指向的数组元素在q所指向的数组元素之前(对于指向数组元素的指针在下面将作详细讨论)。
    (2). 指针和整数可进行加、减运算。设p是指向某一数组元素的指针,开始时指向数组的第0号元素, 设n为一整数, 则

     p+n

就表示指向数组的第n号元素(下标为n的元素)。
    不论指针变量指向何种数据类型, 指针和整数进行加、减运算时, 编译程序总根据所指对象的数据长度对n放大, 在一般微机
上, char放大因子为1, int、short放大因子为2, long和float放大因子为4, double放大因子为8。 对于下面讲述到的结构或联
合, 也仍然遵守这一原则。
    (3). 两个指针变量在一定条件下, 可进行减法运算。设p, q指向同一数组, 则p-q的绝对值表示p 所指对象与q所指对象之间
的元素个数。 其相减的结果遵守对象类型的字节长度进行缩小的规则。

    2. 指针和数组
    指针和数组有着密切的关系, 任何能由数组下标完成的操作也都可用指针来实现, 但程序中使用指针可使代码更紧凑、更灵活。

    2.1. 指向数组元素的指针
    我们定义一个整型数组和一个指向整型的指针变量:
          int a[10], *p;
和前面介绍过的方法相同, 可以使整型指针p指向数组中任何一个元素, 假定给出赋值运算:

          p=&a[0];

此时, p指向数组中的第0号元素, 即a[0], 指针变量p中包含了数组元素a[0] 的地址, 由于数组元素在内存中是连续存放的, 因
此, 我们就可以通过指针变量p及其有关运算间接访问数组中的任何一个元素。
    Turbo C中, 数组名是数组的第0号元素的地址, 因此下面两个语句是等价的
     p=&a[0];
     p=a;
根据地址运算规则, a+1为a[1]的地址, a+i就为a[i]的地址。
    下面我们用指针给出数组元素的地址和内容的几种表示形式。
    (1). p+i和a+i均表示a[i]的地址, 或者讲, 它们均指向数组第i号元素, 即指向a[i]。
    (2). *(p+i)和*(a+i)都表示p+i和a+i所指对象的内容, 即为a[i]。
    (3). 指向数组元素的指针, 也可以表示成数组的形式, 也就是说, 它允许指针变量带下标, 如p[i]与*(p+i)等价。
    假若:      p=a+5;
则p[2]就相当于*(p+2),由于p指向a[5], 所以p[2]就相当于a[7]。而p[-3]就相当于*(p-3),它表示a[2].[page]

    2.2. 指向二维数组的指针
    2.2.1. 二维数组元素的地址
    为了说明问题, 我们定义以下二维数组:

     int a[3][4]={{0,1,2,3}, {4,5,6,7}, {8,9,10,11}};

a为二维数组名, 此数组有3行4列, 共12个元素。但也可这样来理解, 数组a由三个元素组成:a[0],a[1],a[2]。而它匀中每个元素又
是一个一维数组, 且都含有4个元素 (相当于4列), 例如 a[0]所代表的一维数组所包含的 4 个元素为a[0][0], a[0][1], a[0][2],
a[0][3]。如图5.所示:
        ┏━━━━┓    ┏━┳━┳━┳━┓
  a─→ ┃  a[0]  ┃─→┃0 ┃1 ┃2 ┃3 ┃
        ┣━━━━┫    ┣━╋━╋━╋━┫
        ┃  a[1]  ┃─→┃4 ┃5 ┃6 ┃7 ┃
        ┣━━━━┫    ┣━╋━╋━╋━┫
        ┃  a[2]  ┃─→┃8 ┃9 ┃10┃11┃
        ┗━━━━┛    ┗━┻━┻━┻━┛
                    图5.
    但从二维数组的角度来看, a代表二维数组的首地址, 当然也可看成是二维数组第0行的首地址。a+1就代表第1行的首地址, a+2
就代表第2行的首地址。如果此二维数组的首地址为1000, 由于第0行有4个整型元素, 所以a+1为1008, a+2也就为1016。如图6.
所示
                            a[3][4]
                   a    ┏━┳━┳━┳━┓
              (1000)─→┃0 ┃1 ┃2 ┃3 ┃
                   a+1  ┣━╋━╋━╋━┫
              (1008)─→┃4 ┃5 ┃6 ┃7 ┃
                   a+2  ┣━╋━╋━╋━┫
              (1016)─→┃8 ┃9 ┃10┃11┃
                        ┗━┻━┻━┻━┛
                              图6.
    既然我们把a[0], a[1], a[2]看成是一维数组名, 可以认为它们分别代表它们所对应的数组的首地址, 也就是讲, a[0]代表第
0 行中第 0 列元素的地址, 即&a[0][0], a[1]是第1行中第0列元素的地址, 即&a[1][0], 根据地址运算规则, a[0]+1即代表第
0 行第1列元素的地址, 即&a[0][1], 一般而言,a[i]+j即代表第i行第j列元素的地址, 即&a[i][j]。
    另外, 在二维数组中, 我们还可用指针的形式来表示各元素的地址。如前所述, a[0]与*(a+0)等价, a[1]与*(a+1)等价, 因此
a[i]+j就与*(a+i)+j等价, 它表示数组元素a[i][j]的地址。
    因此, 二维数组元素a[i][j]可表示成*(a[i]+j)或*(*(a+i)+j),  它们都与a[i][j]等价, 或者还可写成(*(a+i))[j]。
    另外, 要补充说明一下, 如果你编写一个程序输出打印a和*a,  你可发现它们的值是相同的, 这是为什么呢? 我们可这样来理
解: 首先, 为了说明问题, 我们把二维数组人为地看成由三个数组元素a[0],a[1],a[2]组成, 将a[0],a[1],a[2]看成是数组名它们
又分别是由4个元素组成的一维数组。因此, a表示数组第0行的地址, 而*a 即为a[0], 它是数组名, 当然还是地址, 它就是数组第
0 行第0列元素的地址。

    2.2.2 指向一个由n个元素所组成的数组指针
    在Turbo C中, 可定义如下的指针变量:

      int (*p)[3];

    指针p为指向一个由3个元素所组成的整型数组指针。在定义中, 圆括号是不能少的, 否则它是指针数组, 这将在后面介绍。这
种数组的指针不同于前面介绍的整型指针, 当整型指针指向一个整型数组的元素时, 进行指针(地址)加1运算, 表示指向数组的下一
个元素, 此时地址值增加了2(因为放大因子为2), 而如上所定义的指向一个由3个元素组成的数组指针, 进行地址加1运算时, 其地
址值增加了6(放大因子为2x3=6), 这种数组指针在Turbo C中用得较少,  但在处理二维数组时, 还是很方便的。
例如:
          int a[3][4], (*p)[4];
          p=a;
    开始时p指向二维数组第0行, 当进行p+1运算时, 根据地址运算规则, 此时放大因子为4x2=8, 所以此时正好指向二维数组的第
1 行。和二维数组元素地址计算的规则一样, *p+1指向a[0][1],*(p+i)+j则指向数组元素a[i][j]。
     例1
     int a[3] [4]={
     {1,3,5,7},
     {9,11,13,15},
     {17,19,21,23}
    };
    main()
    {
         int i,(*b)[4];
           b=a+1;                  /* b指向二维数组的第1行, 此时*b[0]或**b是a[1][0] */
         for(i=1;i<=4;b=b[0]+2,i++)/* 修改b的指向, 每次增加2 */
           printf("%d ",*b[0]);
         printf(" ");
         for (i=0; i<2; i++) {
           b=a+i;                  /* 修改b的指向,  每次跳过二维数组的一行 */
           printf("%d ",*(b[i]+1));
        }
         printf (" ");
     }
    程序运行结果如下:
     9    13   17   21
     3    11   19

    3. 字符指针
    我们已经知道, 字符串常量是由双引号括起来的字符序列, 例如:
          "a string"
就是一个字符串常量, 该字符串中因为字符a后面还有一个空格字符, 所以它由8个字符序列组成。在程序中如出现字符串常量C 编
译程序就给字符串常量按排一存贮区域, 这个区域是静态的, 在整个程序运行的过程中始终占用, 平时所讲的字符串常量的长度是
指该字符串的字符个数, 但在按排存贮区域时, C 编译程序还自动给该字符串序列的末尾加上一个空字符'', 用来标志字符串的
结束, 因此一个字符串常量所占的存贮区域的字节数总比它的字符个数多一个字节。
    Turbo C中操作一个字符串常量的方法有:
    (1). 把字符串常量存放在一个字符数组之中, 例如:
          char s[]="a string";
数组s共有9个元素所组成, 其中s[8]中的内容是''。实际上, 在字符数组定义的过程中, 编译程序直接把字符串复写到数组中,
即对数组s初始化。
    (2). 用字符指针指向字符串, 然后通过字符指针来访问字符串存贮区域。当字符串常量在表达式中出现时, 根据数组的类型
转换规则, 它被转换成字符指针。因此, 若我们定义了一字符指针cp:
     char *cp;
于是可用:
     cp="a string";
使cp指向字符串常量中的第0号字符a, 如图7.所示。
            cp
        ┏━━━┓     ┏━┳━┳━┳━┳━┳━┳━┳━┳━┓
        ┃    ─╂─→ ┃a ┃  ┃s ┃t ┃r ┃i ┃n ┃g ┃┃
        ┗━━━┛     ┗━┻━┻━┻━┻━┻━┻━┻━┻━┛
                              图7.
以后我们可通过cp来访问这一存贮区域, 如*cp或cp[0]就是字符a, 而cp[i]或*(cp+i)就相当于字符串的第i号字符, 但企图通过指
针来修改字符串常量的行为是没有意义的。

    4. 指针数组
    因为指针是变量, 因此可设想用指向同一数据类型的指针来构成一个数组, 这就是指针数组。数组中的每个元素都是指针变量,
根据数组的定义, 指针数组中每个元素都为指向同一数据类型的指针。指针数组的定义格式为:

     类型标识 *数组名[整型常量表达式];

    例如:
       int *a[10];

定义了一个指针数组, 数组中的每个元素都是指向整型量的指针, 该数组由10个元素组成,即a[0], a[1], a[2], ..., a[9], 它们
均为指针变量。a为该指针数组名, 和数组一样, a是常量, 不能对它进行增量运算。a为指针数组元素a[0]的地址, a+i为a[i]的地
址, *a就是a[0], *(a+i)就是a[i]。
    为什么要定义和使用指针数组呢? 主要是由于指针数组对处理字符串提供了更大的方便和灵活, 使用二维数组对处理长度不等
的正文效率低, 而指针数组由于其中每个元素都为指针变量, 因此通过地址运算来操作正文行是十分方便的。
    指针数组和一般数组一样, 允许指针数组在定义时初始化, 但由于指针数组的每个元素是指针变量, 它只能存放地址, 所以对
指向字符串的指针数组在说明赋初值时, 是把存放字符串的首地址赋给指针数组的对应元素, 例如下面是一个书写函数
month_name(n), 此函数返回一个指向包含第n月名字的字符指针( 关于函数, 第6节将专门介绍 )。

    例2: 打印1月至12月的月名:

     char *month_name(int n)
     {
          static char *name[]={
               "Illegal month",
               "January",
               "February",
               "March",
               "April",
               "May",
               "June",
               "July",
               "August",
               "September",
               "October",
               "November",
               "December"
          };
          return((n<1 n>12)?name[0]:name[n]);
     }
     main()
     {
          int i;
          for(i=0; i<13; i++)
               printf("%s ", month_name(i));

     }

关键字:C51  指针  结构  联合  枚举 引用地址:学C51的基础 9 《 指针、结构、联合和枚举 》

上一篇:学C51的基础 10《 联 合(union) 》
下一篇:学C51的基础 8 《 控制流程语句 》

推荐阅读最新更新时间:2024-03-16 13:54

工业机器人结构原理图详解
一、工业机构名词解释: 1、关节(Joint): 即运动副,允许机器人手臂各零件之间发生相对运动的机构。 2、连杆(Link): 机器人手臂上被相邻两关节分开的部分。 3、刚度(Stfness): 机身或臂部在外力作用下抵抗变形的能力。它是用外力和在外力作用方向上的变形量(位移)之比来度量。 4、自由度(Degree of freedom) : 或者称坐标轴数,是指描述物体运动所需要的独立坐标数。手指的开、合,以及手指关节的自由度一般不包括在内。 5、定位精度(Positioning accuracy): 指机器人末端参考点实际到达的位置与
[机器人]
Oculus联合创始人看跌:VR游戏没有市场
Jack McCauley是Oculus的六位联合创始人之一,但他也是该公司最大的看跌方之一。他向CNBC表示,虚拟现实视频游戏不会有市场。 在以20亿美元收购Oculus五年后,Facebook仍在致力于将虚拟现实带进主流受众群。但公司的六位联合创始人之一现在怀疑Oculus是否能达到突破进展。McCauley告诉CNBC,VR游戏市场还不够大,如果Facebook将Oculus产品定位主打游戏方面,那么将难以取得突破性成功。在周三接受电话采访时,McCauley也同样表示,“如果我们要出售VR,我们早就开始了。” 2015年11月,McCauley离开Oculus时曾说过他负责的设备销售额并不多。 他回忆道,2013年
[嵌入式]
使用LabVIEW和PXI进行东海大桥结构健康监测
东海大桥是中国第一座跨海大桥,我们在上面使用了多个PXI机箱组成的系统,以获取追踪大桥结构完整性及当前状况的重要数据。 "借助于精确的GPS同步和时间标识、NI PXI动态信号采集硬件设备和LabVIEW软件,我们的团队成功地为东海大桥搭建了一个坚固的、模块化、可靠且低维护的高精度监测系统。" - Yonglin Zhan, JUST ONE Technology 挑战: 在可能出现台风、地震、海水腐蚀的环境中,对跨海大桥结构完整性和环境因素产生的影响进行同步实时监测,需要一个高可靠、低维护的操作系统。 解决方案: 部署一个坚固耐用的PXI系统来监测环境对大桥产生的影响,进行实时计算以确定大桥的即时结构健康状况,并将数
[测试测量]
使用LabVIEW和PXI进行东海大桥<font color='red'>结构</font>健康监测
超基础:指针万用表测量电容器方法分享
  方法1:找一个β≥250的晶体三极管(要求穿透电流要小),如一时找不到,可用两只同型号的三极管复合成达林顿形式,见图1。将被测电容并接在三极管的c-e结(若为有极性电容则电容正极接三极管c极),然后用万用表R 10k挡,黑表笔接c极,红笔接e极,见图2,观察表针瞬时摆动程度。照此法用几个已知容量的正常(高精确度)的电容反复测试,记录下表针每次的瞬时最大摆动幅值,l进行处理计算,算出表盘上每小格应代表的电容值,备日后参考之用。对电容进行测量时,通过对所测电容表针摆动幅度与参考幅度进行比较可判断电容的好坏。   方法2:找一个高精确度已知容量的电容(耐压250V以上)和一个自耦输出电压可调的变压器,见图3。Cn为已知电容,Cx
[测试测量]
超基础:<font color='red'>指针</font>万用表测量电容器方法分享
长征重工顺利完成储能系统箱体结构制造
  工商业储能系统是中国船舶重庆长征重工有限责任公司新产品开发的重点项目,是公司实现产业结构调整的新方向。   11月6日,轨道交通事业部接到生产任务后,迅速响应、科学谋划,积极联系相关部门推进生产进度。截至12月8日,该项目完成主要箱体结构的制作,并顺利交付科技产业部进行总装调试,将在公司内部联网试运行。   2024年,公司将以工商业储能应用为突破口,积极对储能系统项目进行市场推广,力争实现在重庆市示范应用,并进一步覆盖西南地区。
[新能源]
叠栅MOSFETs的结构设计与研究
摘要:通过分析设计,提出了一种新型结构的叠栅MOSFET,它的栅电容是由两个电容混联组成,所以它有较小的栅电容和显著的抑制短沟道效应的作用。模拟软件MEDICI仿真结果验证了理论分析的预言,从而表明该结构可用作射频领域。 关键词:叠栅MOSFET;阈值电压;栅氧化层电容;短沟道效应 0 引言     尽管微电子学在化合物和新元素半导体材料以及电路技术方面取得了很大的进展,但是其材料的元件和集成电路还远不具备成为主流技术的条件,到目前为止,还看不到能够替代硅基微电子技术的新技术出现,至少在21世纪的前半叶,硅基CMOS工艺技术仍将是微电子的主流,因此研究新结构、新工艺的硅基CMOS器件还是当前提高集成电路的主要努力方向。近十年来在这
[电源管理]
叠栅MOSFETs的<font color='red'>结构</font>设计与研究
电源设计之拓扑结构
单端反激变换器 1、电路拓扑图   2、电路原理 其变压器T1起隔离和传递储存能量的作用,即在开关管Q开通时Np储存能量,开关管Q关断时Np向Ns释放能量。在输出端要加由电感器Lo和两Co电容组成一个低通滤波器,变压器初级需有Cr、Rr和Dr组成的RCD漏感尖峰吸收电路。输出回路需有一个整流二极管D1。由于其变压器使用有气隙的磁芯,故其铜损较大,变压器温相对较高。并且其输出的纹波电压比较大。但其优点就是电路结构简单,适用于200W以下的电源且多路输出交调特性相对较好。 3、变压器计算 单端反激式变压器设计的方法较多,但对于反激式设计来说最难的也就是变压器的设计和调整。一般须视具体工作状态而定,这里我
[电源管理]
电源设计之拓扑<font color='red'>结构</font>
基于AT89C52的励磁调节器的设计与实现
1引言 励磁调节系统是同步发电机一个十分重要的组成部分 ,其主要任务是向同步发电机的励磁绕组提供一个可调的直流电流或电压,从而控制机端电压的恒定,以满足发电机正常发电的需要。近年来,微机励磁调节器 以其硬件结构简单、清晰、设备通用性好、标准化程度高、软件灵活、能够方便实现多种功能和满足各种控制规律的要求等优点,在许多电力工业得到了广泛的应用。但是,单微机励磁系统各环节可靠性再高,发生故障的可能仍然存在,为确保励磁系统的可靠运行,微机励磁调节器应提供网络化的可靠的通信接口,使远方的调度员或厂级工作人员能方便自如的开停机、升速升压、并网、调整功率(包括有功和无功)等操作。为此,本文采用一台工控机作为上位机,通过多个RS-485工业控
[应用]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
  • 学习ARM开发(16)
    ARM有很多东西要学习,那么中断,就肯定是需要学习的东西。自从CPU引入中断以来,才真正地进入多任务系统工作,并且大大提高了工作效率。采 ...
  • 学习ARM开发(17)
    因为嵌入式系统里全部要使用中断的,那么我的S3C44B0怎么样中断流程呢?那我就需要了解整个流程了。要深入了解,最好的方法,就是去写程序 ...
  • 学习ARM开发(18)
    上一次已经了解ARM的中断处理过程,并且可以设置中断函数,那么它这样就可以工作了吗?答案是否定的。因为S3C44B0还有好几个寄存器是控制中 ...
  • 嵌入式系统调试仿真工具
    嵌入式硬件系统设计出来后就要进行调试,不管是硬件调试还是软件调试或者程序固化,都需要用到调试仿真工具。 随着处理器新品种、新 ...
  • 最近困扰在心中的一个小疑问终于解惑了~~
    最近在驱动方面一直在概念上不能很好的理解 有时候结合别人写的一点usb的例子能有点感觉,但是因为arm体系里面没有像单片机那样直接讲解引脚 ...
  • 学习ARM开发(1)
  • 学习ARM开发(2)
  • 学习ARM开发(4)
  • 学习ARM开发(6)
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved