虫虫首页| 资源下载| 资源专辑| 精品软件
登录| 注册

对象关系

  • 太阳能蓄电池与光照时间的关系

      太阳能蓄电池与光照时间的关系   例如:有一块单晶硅电池的组件,最大的输出功率Pm(额定功率)为25W,峰值电压(额定电压)Ump为17.2V,峰值电流(额定电流)为1.45A,开路电压为21V,短路电流为Isc为1.5A,某地区有效光照时间为12小时,求太阳能电池一天的发电量和所需的蓄电池的容量。   已知:Pm=25w ,h=12h ,U=17.2V ,太阳能电池的发电效率为:u=0.7,蓄电池的补偿值为n=1.4   太阳能电池的发电量:M=Pm×h×u=25×12×0.7=210W   按上诉公式:C=Ph/U=25×12/17.2=17.44Ah   那么实际的蓄电池的有效容量要在C=17.44/1.40=12.46Ah以上   所以在实际中我们可以选择14Ah左右容量的蓄电池。

    标签: 太阳能 光照 蓄电池

    上传时间: 2013-11-08

    上传用户:life840315

  • 单片机音符与频率的关系

    单片机音符与频率的关系

    标签: 单片机 频率

    上传时间: 2013-10-20

    上传用户:blans

  • c#入门经典第4版全书pdf

    《C#入门经典(第4版)》通过C#可以很容易地学习.NET Framework 3.5的强大功能,所以C#是开始您编程生涯的绝佳方式。《C#入门经典(第4版)》全面阐述了C#编程的所有方面,包括C#语言本身、Windows编程、Web编程及数据源的使用等内容。学习了新的编程技巧后,《C#入门经典(第4版)》介绍了如何高效地部署应用程序和服务,论述了许多高级技术,如图形化编程。另外,还探讨了如何使用Visual C# Express 2008、Visual Web Developer Express 2008和Visual Studio 2008的功能。所有这些内容都已更新,以反映.NET Framework 3.5和Visual Studio 2008的变化。各章的样例代码和示例还可以用于创建强大且安全的应用程序。 c#入门经典第4版目录   第Ⅰ部分 C# 语 言   第1章 C#简介 3   1.1 什么是.NET Framework 3   1.1.1 NET Framework的内容 4   1.1.2 用.NET Framework编写应用程序 4   1.2 什么是C# 7   1.2.1 用C#能编写什么样的应用程序 7   1.2.2 本书中的C# 8   1.3 Visual Studio 2008 8   1.3.1 Visual Studio 2008 Express 产品 9   1.3.2 解决方案 9   1.4 小结 9   第2章 编写C#程序 10   2.1 开发环境 10   2.1.1 Visual Studio 2008 11   2.1.2 Visual C# 2008 ExpressEdition 13   2.2 控制台应用程序 13   2.2.1 Solution Explorer 16   2.2.2 Properties窗口 17   2.2.3 Error List窗口 17   2.3 Windows Forms应用程序 18   2.4 小结 22   第3章 变量和表达式 23   3.1 C#的基本语法 23   3.2 C#控制台应用程序的基本结构 25   3.3 变量 27   3.3.1 简单类型 27   3.3.2 变量的命名 31   3.3.3 字面值 32   3.3.4 变量的声明和赋值 33   3.4 表达式 34   3.4.1 数学运算符 34   3.4.2 赋值运算符 38   3.4.3 运算符的优先级 39   3.4.4 名称空间 39   3.5 小结 42   3.6 练习 43   第4章 流程控制 44   4.1 布尔逻辑 44   4.1.1 位运算符 46   4.1.2 布尔赋值运算符 50   4.1.3 运算符的优先级更新 51   4.2 goto语句 52   4.3 分支 53   4.3.1 三元运算符 53   4.3.2 if语句 54   4.3.3 switch语句 57   4.4 循环 60   4.4.1 do循环 61   4.4.2 while循环 63   4.4.3 for循环 65   4.4.4 循环的中断 69   4.4.5 无限循环 70   4.5 小结 70   4.6 练习 71   第5章 变量的更多内容 72   5.1 类型转换 72   5.1.1 隐式转换 72   5.1.2 显式转换 74   5.1.3 使用Convert命令进行 显式转换 76   5.2 复杂的变量类型 79   5.2.1 枚举 79   5.2.2 结构 83   5.2.3 数组 86   5.3 字符串的处理 91   5.4 小结 95   5.5 练习 96   第6章 函数 97   6.1 定义和使用函数 98   6.1.1 返回值 99   6.1.2 参数 101   6.2 变量的作用域 107   6.2.1 其他结构中变量的作用域 110   6.2.2 参数和返回值与全局数据 111   6.3 Main()函数 113   6.4 结构函数 114   6.5 函数的重载 115   6.6 委托 117   6.7 小结 119   6.8 练习 120   第7章 调试和错误处理 121   7.1 VS和VCE中的调试 121   7.1.1 非中断(正常)模式下的调试 122   7.1.2 中断模式下的调试 131   7.2 错误处理 139   7.2.1 try...catch...finally 140   7.2.2 列出和配置异常 144   7.2.3 异常处理的注意事项 145   7.3 小结 146   7.4 练习 146   第8章 面向对象编程简介 147   8.1 什么是面向对象编程 147   8.1.1 什么是对象 148   8.1.2 所有的东西都是对象 151   8.1.3 对象的生命周期 151   8.1.4 静态和实例类成员 152   8.2 OOP技术 153   8.2.1 接口 153   8.2.2 继承 155   8.2.3 多态性 156   8.2.4 对象之间的关系 157   8.2.5 运算符重载 159   8.2.6 事件 159   8.2.7 引用类型和值类型 160   8.3 Windows应用程序中的OOP 160   8.4 小结 162   8.5 练习 163   第9章 定义类 164   9.1 C#中的类定义 164   9.2 System.Object 169   9.3 构造函数和析构函数 170   9.4 VS和VCE中的OOP工具 174   9.4.1 Class View窗口 174   9.4.2 对象浏览器 176   9.4.3 添加类 177   9.4.4 类图 177   9.5 类库项目 179   9.6 接口和抽象类 182   9.7 结构类型 184   9.8 小结 186   9.9 练习 186   第10章 定义类成员 187   10.1 成员定义 187   10.1.1 定义字段 187   10.1.2 定义方法 188   10.1.3 定义属性 189   10.1.4 在类图中添加成员 194   10.1.5 重制成员 196   10.1.6 自动属性 197   10.2 类成员的其他议题 197   10.2.1 隐藏基类方法 198   10.2.2 调用重写或隐藏的基类方法 199   10.2.3 嵌套的类型定义 200   10.3 接口的实现 201   10.4 部分类定义 204   10.5 部分方法定义 206   10.6 示例应用程序 207   10.6.1 规划应用程序 207   10.6.2 编写类库 208   10.6.3 类库的客户应用程序 214   10.7 小结 215   10.8 练习 216   第11章 集合、比较和转换 217   11.1 集合 217   11.1.1 使用集合 218   11.1.2 定义集合 224   11.1.3 索引符 225   11.1.4 给CardLib添加Cards集合 227   11.1.5 关键字值集合和IDictionary 229   11.1.6 迭代器 231   11.1.7 深度复制 236   11.1.8 给CardLib添加深度复制 238   11.2 比较 239   11.2.1 类型比较 240   11.2.2 值比较 244   11.3 转换 259   11.3.1 重载转换运算符 259   11.3.2 as运算符 260   11.4 小结 261   11.5 练习 262   第12章 泛型 263   12.1 泛型的概念 263   12.2 使用泛型 264   12.2.1 可空类型 264   12.2.2 System.Collections.Generic 名称空间 271   12.3 定义泛型 279   12.3.1 定义泛型类 280   12.3.2 定义泛型接口 291   12.3.3 定义泛型方法 291   12.3.4 定义泛型委托 293   12.4 小结 293   12.5 练习 293   第13章 其他OOP技术 295   13.1 ::运算符和全局名称空间   13.2 定制异常 296   13.2.1 异常基类 297   13.2.2 给CardLib添加定制异常 297   13.3 事件 298   13.3.1 什么是事件 298   13.3.2 使用事件 300   13.3.3 定义事件 302   13.4 扩展和使用CardLib 309   13.5 小结 317   13.6 练习 317   第14章 C# 3.0语言的改进 318   14.1 初始化器 318   14.1.1 对象初始化器 319   14.1.2 集合初始化器 320   14.2 类型推断 323   14.3 匿名类型 325   14.4 扩展方法 328   14.5 ?表达式 333   14.5.1 复习匿名方法 333   14.5.2 把?表达式用于匿名方法 334   14.5.3 ?表达式的参数 337   14.5.4 ?表达式的语句体 337   14.5.5 ?表达式用作委托和表达式树 338   14.5.6 ?表达式和集合 339   14.6 小结 342   14.7 练习 342   第Ⅱ部分 Windows 编 程   第15章 Windows编程基础 347   15.1 控件 347   15.1.1 属性 348   15.1.2 控件的定位、停靠和对齐 349   15.1.3 事件 350   15.2 Button控件 352   15.2.1 Button控件的属性 352   15.2.2 Button控件的事件 353   15.3 Label和LinkLabel控件 354   15.4 TextBox控件 355   15.4.1 TextBox控件的属性 355   15.4.2 TextBox控件的事件 356   15.5 RadioButton和CheckBox控件 363   15.5.1 RadioButton控件的属性 364   15.5.2 RadioButton控件的事件 364   15.5.3 CheckBox控件的属性 364   15.5.4 CheckBox控件的事件 364   15.5.5 GroupBox控件 365   15.6 RichTextBox控件 368   15.6.1 RichTextBox控件的属性 368   15.6.2 RichTextBox控件的事件 369   15.7 ListBox和CheckedListBox控件 374   15.7.1 ListBox控件的属性 375   15.7.2 ListBox控件的方法 376   15.7.3 ListBox控件的事件 376   15.8 ListView控件 378   15.8.1 ListView控件的属性 378   15.8.2 ListView控件的方法 380   15.8.3 ListView控件的事件 381   15.8.4 ListViewItem 381   15.8.5 ColumnHeader 381   15.8.6 ImageList控件 381   15.9 TabControl控件 388   15.9.1 TabControl控件的属性 389   15.9.2 使用TabControl控件 389   15.10 小结 392   15.11 练习 392   第16章 Windows Forms的高级功能 393   16.1 菜单和工具栏 393   16.1.1 两个实质一样的控件 393   16.1.2 使用MenuStrip控件 394   16.1.3 手工创建菜单 394   16.1.4 ToolStripMenuItem控件的其他属性 397   16.1.5 给菜单添加功能 397   16.2 工具栏 399   16.2.1 ToolStrip控件的属性 399   16.2.2 ToolStrip的项 400   16.2.3 StatusStrip控件 405   16.2.4 StatusStripStatusLabel的属性 405   16.3 SDI和MDI应用程序 407   16.4 创建控件 415   16.4.1 LabelTextbox控件 417   16.4.2 调试用户控件 420   16.4.3 扩展LabelTextbox控件 421   16.5 小结 424   16.6 练习 424   第17章 使用通用对话框 425   17.1 通用对话框 425   17.2 如何使用对话框 426   17.3 文件对话框 427   17.3.1 OpenFileDialog 427   17.3.2 SaveFileDialog 438   17.4 打印 442   17.4.1 打印结构 442   17.4.2 打印多个页面 447   17.4.3 PageSetupDialog 449   17.4.4 PrintDialog 451   17.5 打印预览 455   17.5.1 PrintPreviewDialog 455   17.5.2 PrintPreviewControl 456   17.6 FontDialog和ColorDialog 457   17.6.1 FontDialog 457   17.6.2 ColorDialog 459   17.6.3 FolderBrowserDialog 460   17.7 小结 461   17.8 练习 461   第18章 部署Windows应用程序 463   18.1 部署概述 463   18.2 ClickOnce部署 464   18.3 Visual Studio安装和部署项目类型 473   18.4 Microsoft Windows安装程序结构 474   18.4.1 Windows Installer术语 474   18.4.2 Windows Installer的优点 476   18.5 为SimpleEditor创建安装软件包 476   18.5.1 规划安装内容 476   18.5.2 创建项目 477   18.5.3 项目属性 478   18.5.4 安装编辑器 480   18.5.5 File System编辑器 481   18.5.6 File Types编辑器 483   18.5.7 Launch Condition编辑器 485   18.5.8 User Interface编辑器 485   18.6 构建项目 488   18.7 安装 489   18.7.1 Welcome 489   18.7.2 Read Me 489   18.7.3 License Agreement 490   18.7.4 Optional Files 490   18.7.5 选择安装文件夹 491   18.7.6 确认安装 492   18.7.7 进度 492   18.7.8 结束安装 493   18.7.9 运行应用程序 493   18.7.10 卸载 493   18.8 小结 493   18.9 练习 494   第Ⅲ部分 Web 编 程   第19章 Web编程基础 497   19.1 概述 497   19.2 ASP .NET运行库 498   19.3 创建简单的Web页面 498   19.4 服务器控件 504   19.5 事件处理程序 505   19.6 输入的有效性验证 509   19.7 状态管理 512   19.7.1 客户端的状态管理 513   19.7.2 服务器端的状态管理 515   19.8 身份验证和授权 517   19.8.1 身份验证的配置 518   19.8.2 使用安全控件 522   19.9 读写SQL Server数据库 524   19.10 小结 530   19.11 练习 531   第20章 Web高级编程 532   20.1 母版页 532   20.2 站点导航 537   20.3 用户控件 539   20.4 个性化配置 541   20.4.1 个性化配置组 543   20.4.2 组件的个性化配置 543   20.4.3 定制数据类型中的个性化配置 543   20.4.4匿名用户的个性化配置 544   20.5 Web Parts 545   20.5.1 WebPartManager控件 546   20.5.2 WebPartZone控件 546   20.5.3 EditorZone控件 548   20.5.4 CatalogZone控件 550   20.5.5 ConnectionsZone控件 551   20.6 JavaScript 554   20.6.1 Script元素 555   20.6.2 变量的声明 555   20.6.3 定义函数 555   20.6.4 语句 556   20.6.5 对象 556   20.7 小结 560   20.8 练习 560   第21章 Web服务 561   21.1 Web服务推出之前 561   21.1.1 远程过程调用(RPC) 562   21.1.2 SOAP 563   21.2 使用Web服务的场合 563   21.2.1 宾馆旅行社代理应用程序 564   21.2.2 图书发布应用程序 564   21.2.3 客户应用程序的类型 564   21.2.4 应用程序的体系结构 564   21.3 Web服务的体系结构 565   21.3.1 可以调用的方法 565   21.3.2 调用方法 566   21.3.3 SOAP和防火墙 567   21.3.4 WS-I基本个性化配置 568   21.4 Web服务和.NET Framework 568   21.4.1 创建Web服务 568   21.4.2 客户程序 570   21.5 创建简单的ASP .NET Web服务 571   21.6 测试Web服务 572   21.7 执行Windows客户程序 574   21.8 异步调用服务 577   21.9 执行ASP .NET客户程序 580   21.10 传送数据 581   21.11 小结 584   21.12 练习 584   第22章 Ajax编程 586   22.1 Ajax概述 586   22.2 UpdatePanel控件 587   22.3 Timer控件 591   22.4 UpdateProgress控件 592   22.5 Web服务 594   22.6 扩展控件 598   22.7 小结 600   22.8 练习 600   第23章 部署Web应用程序 601   23.1 Internet Information Services 601   23.2 IIS配置 602   23.3 复制Web站点 604   23.4 发布Web站点 606   23.5 Windows安装程序 607   23.5.1 创建安装程序 607   23.5.2 安装Web 应用程序 609   23.6 小结 610   23.7 练习 610   第Ⅳ部分 数 据 访 问   第24章 文件系统数据 613   24.1 流 613   24.2 用于输入和输出的类 614   24.2.1 File类和Directory类 615   24.2.2 FileInfo类 616   24.2.3 DirectoryInfo类 617   24.2.4 路径名和相对路径 618   24.2.5 FileStream对象 618   24.2.6 StreamWriter对象 624   24.2.7 StreamReader对象 626   24.2.8 读写压缩文件 632   24.3 序列化对象 635   24.4 监控文件结构 639   24.5 小结 645   24.6 练习 646   第25章 XML 647   25.1 XML文档 647   25.1.1 XML元素 647   25.1.2 属性 648   25.1.3 XML声明 649   25.1.4 XML文档的结构 649   25.1.5 XML名称空间 650   25.1.6 格式良好并有效的XML 651   25.1.7 验证XML文档 651   25.2 在应用程序中使用XML 654   25.2.1 XML文档对象模型 655   25.2.2 选择节点 663   25.3 小结 670   25.4 练习 671   第26章 LINQ简介 672   26.1 LINQ的变体 673   26.2 第一个LINQ查询 673   26.2.1 用var关键字声明结果变量 675   26.2.2 指定数据源:from子句 675   26.2.3 指定条件:where子句 675   26.2.4 指定元素:select子句 676   26.2.5 完成:使用foreach循环 676   26.2.6 延迟执行的查询 676   26.3使用LINQ方法语法和?表达式 676   26.3.1 LINQ扩展方法 676   26.3.2 查询语法和方法语法 677   26.3.3 ?表达式 677   26.4 排序查询结果 679   26.5 orderby子句 680   26.6 用方法语法排序 681   26.7 查询大型数据集 682   26.8 合计运算符 685   26.9 查询复杂的对象 688   26.10 投射:在查询中创建新对象 691   26.11 投射:方法语法 693   26.12 单值选择查询 693   26.13 Any和All 694   26.14 多级排序 696   26.15 多级排序方法语法:ThenBy 698   26.16 组合查询 698   26.17 Take和Skip 700   26.18 First和FirstOrDefault 702   26.19 集运算符 703   26.20 Join查询 706   26.21 资源和进一步阅读 707   26.22 小结 707   26.23 练习 707   第27章 LINQ to SQL 709   27.1 对象相关映射 709   27.2 安装SQL Server和Northwind示例数据 710   27.2.1 安装SQL Server Express2005 710   27.2.2 安装Northwind示例数据库 711   27.3 第一个LINQ to SQL查询 712   27.4 浏览LINQ to SQL关系 717   27.5 进一步探讨LINQ to SQL 720   27.6 LINQ to SQL中的组合、排序和其他高级查询 723   27.7 显示生成的SQL 725   27.8 用LINQ to SQL绑定数据 729   27.9 用LINQ to SQL更新绑定数据 733   27.10 小结 734   27.11 练习 735   第28章 ADO .NET和LINQ over DataSet 736   28.1 ADO .NET概述 736   28.1.1 ADO .NET名称的来源 737   28.1.2 ADO .NET的设计目标 738   28.2 ADO .NET类和对象概述 739   28.2.1 提供者对象 739   28.2.2 用户对象 740   28.2.3 使用System.Data名称空间 741   28.3 用DataReader读取数据 742   28.4 用DataSet读取数据 749   28.4.1 用数据填充DataSet 749   28.4.2 访问DataSet中的表、行和列 749   28.5 更新数据库 752   28.5.1 给数据库添加行 755   28.5.2 删除行 761   28.6 在DataSet中访问多个表 762   28.6.1 ADO .NET中的关系 762   28.6.2 用关系导航 763   28.7 XML和ADO .NET 770   28.8 ADO .NET中的SQL支持 773   28.8.1 DataAdapter对象中的 SQL命令 773   28.8.2 直接执行SQL命令 776   28.8.3 调用SQL存储过程 778   28.9 使用LINQ over DataSet和ADO .NET 780   28.10 小结 784   28.11 练习 784   第29章 LINQ to XML 785   29.1 LINQ to XML函数构造方法 785   29.2 保存和加载XML文档 789   29.2.1 从字符串中加载XML 791   29.2.2 已保存的XML文档内容 792   29.3 处理XML片段 792   29.4 通过LINQ to XML生成 XML 794   29.5 查询XML文档 798   29.6 小结 804   29.7 练习 804   第Ⅴ部分 其 他 技 术   第30章 属性 809   30.1 什么是属性 809   30.2 反射 812   30.3 内置属性 815   30.3.1 System.Diagnostics.ConditionalAttribute 815   30.3.2 System.Obsolete Attribute 817   30.3.3 System.Serializable   Attribute 818   30.3.4 System.Reflection.AssemblyDelaySignAttribute 821   30.4 定制属性 824   30.4.1 BugFixAttribute 824   30.4.2 System.AttributeUsageAttribute 826   30.5 小结 830   第31章 XML文档说明 831   31.1 添加XML文档说明 831   31.1.1 XML文档说明的注释 833   31.1.2 使用类图添加XML文档说明 839   31.1.3 生成XML文档说明文件 842   31.1.4 带有XML文档说明的应用程序示例 844   31.2 使用XML文档说明 846   31.2.1 编程处理XML文档说明 846   31.2.2 用XSLT格式化XML文档说明 848   31.2.3 文档说明工具 849   31.3 小结 850   31.4 练习 851   第32章 网络 852   32.1 联网概述 852   32.1.1 名称的解析 855   32.1.2 统一资源标识符 856   32.1.3 TCP和UDP 857   32.1.4 应用协议 857   32.2 网络编程选项 859   32.3 WebClient 859   32.4 WebRequest和WebResponse 861   32.5 TcpListener和TcpClient 868   32.6 小结 876   32.7 练习 876   第33章 GDI+简介 877   33.1 图形绘制概述 877   33.1.1 Graphics类 878   33.1.2 对象的删除 878   33.1.3 坐标系统 879   33.1.4 颜色 884   33.2 使用Pen类绘制线条 885   33.3 使用Brush类绘制图形 887   33.4 使用Font 类绘制文本 890   33.5 使用图像进行绘制 893   33.5.1 使用纹理画笔绘图 895   33.5.2 使用钢笔绘制图像 897   33.5.3 双倍缓冲 898   33.6 GDI+的高级功能 900   33.6.1 剪切 900   33.6.2 System.Drawing.Drawing2D 901   33.6.3 System.Drawing.Imaging 901   33.7 小结 901   33.8 练习 902   第 34 章 Windows Presentation Foundation 903   34.1 WPF的概念 904   34.1.1 WPF给设计人员带来的好处 904   34.1.2 WPF给C#开发人员带来的好处 906   34.2 基本WPF应用程序的组成 906   34.3 WPF基础 916   34.3.1 XAML语法 917   34.3.2 桌面和Web应用程序 919   34.3.3 Application对象 920   34.3.4 控件基 920   34.3.5 控件的布局 928   34.3.6 控件的样式 936   34.3.7 触发器 941   34.3.8 动画 942   34.3.9 静态和动态资源 944   34.4 用WPF编程 949   34.4.1 WPF用户控件 950   34.4.2 实现依赖属性 950   34.5 小结 959   34.6 练习 960   第35 章 Windows Communication Foundation 961   35.1 WCF是什么 961   35.2 WCF概念 962   35.2.1 WCF通信协议 962   35.2.2 地址、端点和绑定 963   35.2.3 合同 964   35.2.4 消息模式 965   35.2.5 行为 965   35.2.6 主机 965   35.3 WCF编程 966   35.3.1 定义WCF服务合同 973   35.3.2 自存储的WCF服务 979   35.4 小结 985   35.5 练习 986   第36章 Windows Workflow Foundation 987   36.1 活动 990   36.1.1 DelayActivity 990   36.1.2 SuspendActivity 991   36.1.3 WhileActivity 992   36.1.4 SequenceActivity 994   36.1.5 定制活动 997   36.2 工作流运行库 1002   36.3 数据绑 1007   36.4 小结 1010 序言

    标签:

    上传时间: 2013-11-16

    上传用户:xinyuzhiqiwuwu

  • 来电解码器及其在客户关系管理中的应用

    介绍了一种基于单片机AT89C2051和FSK解码芯片HT9032C实现的来电解码器,说明了设计的原理和解码器的结构。该解码器可应用于客户关系管理系统中,将以FSK方式传送的电话主叫信息通过串行口传入计算机,结合数据库的查询功能,在接听客户来电前实现对客户的识别和详细信息的显示。

    标签: 电解 中的应用 码器

    上传时间: 2013-10-14

    上传用户:天诚24

  • CPU周期与微指令周期的关系

    CPU周期与微指令周期的关系 在串行方式的微程序控制器中:       微指令周期 = 读出微指令的时间 + 执行该条微指令的时间     为了保证整个机器控制信号的同步,可以将一个微指令周期时间设计得恰好和CPU周期时间相等.下图示出了某小型机中CPU周期与微指令周期的时间关系:

    标签: CPU 周期 指令周期

    上传时间: 2013-11-14

    上传用户:baba

  • 单片机入门基础知识大全免费下载

    单片机入门基础知识大全免费下载 单片机第八课(寻址方式与指令系统) 通过前面的学习,我们已经了解了单片机内部的结构,并且也已经知道,要控制单片机,让它为我们干学,要用指令,我们已学了几条指令,但很零散,从现在开始,我们将要系统地学习8051的指令部份。 一、概述 1、指令的格式 我们已知,要让计算机做事,就得给计算机以指令,并且我们已知,计算机很“笨”,只能懂得数字,如前面我们写进机器的75H,90H,00H等等,所以指令的第一种格式就是机器码格式,也说是数字的形式。但这种形式实在是为难我们人了,太难记了,于是有另一种格式,助记符格式,如MOV P1,#0FFH,这样就好记了。 这两种格式之间的关系呢,我们不难理解,本质上它们完全等价,只是形式不一样而已。 2、汇编 我们写指令使用汇编格式,而计算机只懂机器码格式,所以要将我们写的汇编格式的指令转换为机器码格式,这种转换有两种方法:手工汇编和机器汇编。手工汇编实际上就是查表,因为这两种格式纯粹是格式不同,所以是一一对应的,查一张表格就行了。不过手工查表总是嫌麻烦,所以就有了计算机软件,用计算机软件来替代手工查表,这就是机器汇编。 二、寻址 让我们先来复习一下我们学过的一些指令:MOV P1,#0FFH,MOV R7,#0FFH这些指令都是将一些数据送到相应的位置中去,为什么要送数据呢?第一个因为送入的数可以让灯全灭掉,第二个是为了要实现延时,从这里我们可以看出来,在用单片机的编程语言编程时,经常要用到数据的传递,事实上数据传递是单片机编程时的一项重要工作,一共有28条指令(单片机共111条指令)。下面我们就从数据传递类指令开始吧。 分析一下MOV P1,#0FFH这条指令,我们不难得出结论,第一个词MOV是命令动词,也就是决定做什么事情的,MOV是MOVE少写了一个E,所以就是“传递”,这就是指令,规定做什么事情,后面还有一些参数,分析一下,数据传递必须要有一个“源”也就是你要送什么数,必须要有一个“目的”,也就是你这个数要送到什么地方去,显然在上面那条指令中,要送的数(源)就是0FFH,而要送达的地方(目的地)就是P1这个寄存器。在数据传递类指令中,均将目的地写在指令的后面,而将源写在最后。 这条指令中,送给P1是这个数本身,换言之,做完这条指令后,我们可以明确地知道,P1中的值是0FFH,但是并不是任何时候都可以直接给出数本身的。例如,在我们前面给出的延时程序例是这样写的: MAIN: SETB P1.0     ;(1)    LCALL DELAY ;(2)     CLR P1.0      ;(3)    LCALL DELAY   ;(4)     AJMP MAIN    ;(5) ;以下子程序 DELAY: MOV R7,#250   ;(6) D1: MOV R6,#250   ;(7) D2: DJNZ R6,D2    ;(8)    DJNZ R7,D1   ;(9)    RET        ;(10)    END        ;(11)     表1  MAIN: SETB P1.0     ;(1)    MOV 30H,#255     LCALL DELAY ;     CLR P1.0      ;(3)     MOV 30H,#200     LCALL DELAY   ;(4)     AJMP MAIN    ;(5) ;以下子程序 DELAY: MOV R7,30H   ;(6) D1: MOV R6,#250   ;(7) D2: DJNZ R6,D2    ;(8)    DJNZ R7,D1   ;(9)    RET        ;(10)    END        ;(11) 表2    这样一来,我每次调用延时程序延时的时间都是相同的(大致都是0.13S),如果我提出这样的要求:灯亮后延时时间为0.13S灯灭,灯灭后延时0.1秒灯亮,如此循环,这样的程序还能满足要求吗?不能,怎么办?我们可以把延时程序改成这样(见表2):调用则见表2中的主程,也就是先把一个数送入30H,在子程序中R7中的值并不固定,而是根据30H单元中传过来的数确定。这样就可以满足要求。 从这里我们可以得出结论,在数据传递中要找到被传递的数,很多时候,这个数并不能直接给出,需要变化,这就引出了一个概念:如何寻找操作数,我们把寻找操作数所在单元的地址称之为寻址。在这里我们直接使用数所在单元的地址找到了操作数,所以称这种方法为直接寻址。除了这种方法之外,还有一种,如果我们把数放在工作寄存器中,从工作寄存器中寻找数据,则称之为寄存器寻址。例:MOV A,R0就是将R0工作寄存器中的数据送到累加器A中去。提一个问题:我们知道,工作寄存器就是内存单元的一部份,如果我们选择工作寄存器组0,则R0就是RAM的00H单元,那么这样一来,MOV A,00H,和MOV A,R0不就没什么区别了吗?为什么要加以区分呢?的确,这两条指令执行的结果是完全相同的,都是将00H单元中的内容送到A中去,但是执行的过程不同,执行第一条指令需要2个周期,而第二条则只需要1个周期,第一条指令变成最终的目标码要两个字节(E5H 00H),而第二条则只要一个字节(E8h)就可以了。 这么斤斤计较!不就差了一个周期吗,如果是12M的晶振的话,也就1个微秒时间了,一个字节又能有多少? 不对,如果这条指令只执行一次,也许无所谓,但一条指令如果执行上1000次,就是1毫秒,如果要执行1000000万次,就是1S的误差,这就很可观了,单片机做的是实时控制的事,所以必须如此“斤斤计较”。字节数同样如此。 再来提一个问题,现在我们已知,寻找操作数可以通过直接给的方式(立即寻址)和直接给出数所在单元地址的方式(直接寻址),这就够了吗? 看这个问题,要求从30H单元开始,取20个数,分别送入A累加器。 就我们目前掌握的办法而言,要从30H单元取数,就用MOV A,30H,那么下一个数呢?是31H单元的,怎么取呢?还是只能用MOV A,31H,那么20个数,不是得20条指令才能写完吗?这里只有20个数,如果要送200个或2000个数,那岂不要写上200条或2000条命令?这未免太笨了吧。为什么会出现这样的状况?是因为我们只会把地址写在指令中,所以就没办法了,如果我们不是把地址直接写在指令中,而是把地址放在另外一个寄存器单元中,根据这个寄存器单元中的数值决定该到哪个单元中取数据,比如,当前这个寄存器中的值是30H,那么就到30H单元中去取,如果是31H就到31H单元中去取,就可以解决这个问题了。怎么个解决法呢?既然是看的寄存器中的值,那么我们就可以通过一定的方法让这里面的值发生变化,比如取完一个数后,将这个寄存器单元中的值加1,还是执行同一条指令,可是取数的对象却不一样了,不是吗。通过例子来说明吧。    MOV R7,#20    MOV R0,#30H LOOP:MOV A,@R0    INC R0    DJNZ R7,LOOP 这个例子中大部份指令我们是能看懂的,第一句,是将立即数20送到R7中,执行完后R7中的值应当是20。第二句是将立即数30H送入R0工作寄存器中,所以执行完后,R0单元中的值是30H,第三句,这是看一下R0单元中是什么值,把这个值作为地址,取这个地址单元的内容送入A中,此时,执行这条指令的结果就相当于MOV A,30H。第四句,没学过,就是把R0中的值加1,因此执行完后,R0中的值就是31H,第五句,学过,将R7中的值减1,看是否等于0,不等于0,则转到标号LOOP处继续执行,因此,执行完这句后,将转去执行MOV A,@R0这句话,此时相当于执行了MOV A,31H(因为此时的R0中的值已是31H了),如此,直到R7中的值逐次相减等于0,也就是循环20次为止,就实现了我们的要求:从30H单元开始将20个数据送入A中。 这也是一种寻找数据的方法,由于数据是间接地被找到的,所以就称之为间址寻址。注意,在间址寻址中,只能用R0或R1存放等寻找的数据。 二、指令 数据传递类指令 1) 以累加器为目的操作数的指令 MOV A,Rn MOV A,direct MOV A,@Ri MOV A,#data 第一条指令中,Rn代表的是R0-R7。第二条指令中,direct就是指的直接地址,而第三条指令中,就是我们刚才讲过的。第四条指令是将立即数data送到A中。 下面我们通过一些例子加以说明: MOV A,R1 ;将工作寄存器R1中的值送入A,R1中的值保持不变。 MOV A,30H ;将内存30H单元中的值送入A,30H单元中的值保持不变。 MOV A,@R1 ;先看R1中是什么值,把这个值作为地址,并将这个地址单元中的值送入A中。如执行命令前R1中的值为20H,则是将20H单元中的值送入A中。 MOV A,#34H ;将立即数34H送入A中,执行完本条指令后,A中的值是34H。 2)以寄存器Rn为目的操作的指令 MOV Rn,A   MOV Rn,direct   MOV Rn,#data 这组指令功能是把源地址单元中的内容送入工作寄存器,源操作数不变。

    标签: 单片机 免费下载 基础知识

    上传时间: 2013-10-13

    上传用户:3294322651

  • CAN通信实验报文对象的FIFO缓冲器应用

    关键词 CAN报文对象的FIFO模式应用摘 要 CAN通信实验

    标签: FIFO CAN 通信 实验

    上传时间: 2013-11-03

    上传用户:kernor

  • 驱动程序与应用程序的接口

    有两种方式可以让设备和应用程序之间联系:1. 通过为设备创建的一个符号链;2. 通过输出到一个接口WDM驱动程序建议使用输出到一个接口而不推荐使用创建符号链的方法。这个接口保证PDO的安全,也保证安全地创建一个惟一的、独立于语言的访问设备的方法。一个应用程序使用Win32APIs来调用设备。在某个Win32 APIs和设备对象的分发函数之间存在一个映射关系。获得对设备对象访问的第一步就是打开一个设备对象的句柄。 用符号链打开一个设备的句柄为了打开一个设备,应用程序需要使用CreateFile。如果该设备有一个符号链出口,应用程序可以用下面这个例子的形式打开句柄:hDevice = CreateFile("\\\\.\\OMNIPORT3",  GENERIC_READ | GENERIC_WRITE,FILE_SHARE_READ,  NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL ,NULL);文件路径名的前缀“\\.\”告诉系统本调用希望打开一个设备。这个设备必须有一个符号链,以便应用程序能够打开它。有关细节查看有关Kdevice和CreateLink的内容。在上述调用中第一个参数中前缀后的部分就是这个符号链的名字。注意:CreatFile中的第一个参数不是Windows 98/2000中驱动程序(.sys文件)的路径。是到设备对象的符号链。如果使用DriverWizard产生驱动程序,它通常使用类KunitizedName来构成设备的符号链。这意味着符号链名有一个附加的数字,通常是0。例如:如果链接名称的主干是L“TestDevice”那么在CreateFile中的串就该是“\\\\.\\TestDevice0”。如果应用程序需要被覆盖的I/O,第六个参数(Flags)必须或上FILE_FLAG_OVERLAPPED。 使用一个输出接口打开句柄用这种方式打开一个句柄会稍微麻烦一些。DriverWorks库提供两个助手类来使获得对该接口的访问容易一些,这两个类是CDeviceInterface, 和 CdeviceInterfaceClass。CdeviceInterfaceClass类封装了一个设备信息集,该信息集包含了特殊类中的所有设备接口信息。应用程序能有用CdeviceInterfaceClass类的一个实例来获得一个或更多的CdeviceInterface类的实例。CdeviceInterface类是一个单一设备接口的抽象。它的成员函数DevicePath()返回一个路径名的指针,该指针可以在CreateFile中使用来打开设备。下面用一个小例子来显示这些类最基本的使用方法:extern GUID TestGuid;HANDLE OpenByInterface(  GUID* pClassGuid,  DWORD instance,  PDWORD pError){  CDeviceInterfaceClass DevClass(pClassGuid, pError);  if (*pError != ERROR_SUCCESS)    return INVALID_HANDLE_VALUE;  CDeviceInterface DevInterface(&DevClass, instance, pError);  if (*pError != ERROR_SUCCESS)    return INVALID_HANDLE_VALUE;  cout << "The device path is "    << DevInterface.DevicePath()    << endl;   HANDLE hDev;  hDev = CreateFile(   DevInterface.DevicePath(),    GENERIC_READ | GENERIC_WRITE,    FILE_SHARE_READ | FILE_SHARE_WRITE,    NULL,    OPEN_EXISTING,    FILE_ATTRIBUTE_NORMAL,    NULL  );  if (hDev == INVALID_HANDLE_VALUE)    *pError = GetLastError();  return hDev;} 在设备中执行I/O操作一旦应用程序获得一个有效的设备句柄,它就能使用Win32 APIs来产生到设备对象的IRPs。下面的表显示了这种对应关系。Win32 API  DRIVER_FUNCTION_xxxIRP_MJ_xxx  KDevice subclass member function CreateFile  CREATE  Create ReadFile  READ  Read WriteFile  WRITE  Write DeviceIoControl  DEVICE_CONTROL  DeviceControl CloseHandle  CLOSECLEANUP  CloseCleanUp 需要解释一下设备类成员的Close和CleanUp:CreateFile使内核为设备创建一个新的文件对象。这使得多个句柄可以映射同一个文件对象。当这个文件对象的最后一个用户级句柄被撤销后,I/O管理器调用CleanUp。当没有任何用户级和核心级的对文件对象的访问的时候,I/O管理器调用Close。如果被打开的设备不支持指定的功能,则调用相应的Win32将引起错误(无效功能)。以前为Windows95编写的VxD的应用程序代码中可能会在打开设备的时候使用FILE_FLAG_DELETE_ON_CLOSE属性。在Windows NT/2000中,建议不要使用这个属性,因为它将导致没有特权的用户企图打开这个设备,这是不可能成功的。I/O管理器将ReadFile和WriteFile的buff参数转换成IRP域的方法依赖于设备对象的属性。当设备设置DO_DIRECT_IO标志,I/O管理器将buff锁住在存储器中,并且创建了一个存储在IRP中的MDL域。一个设备可以通过调用Kirp::Mdl来存取MDL。当设备设置DO_BUFFERED_IO标志,设备对象分别通过KIrp::BufferedReadDest或 KIrp::BufferedWriteSource为读或写操作获得buff地址。当设备不设置DO_BUFFERED_IO标志也不设置DO_DIRECT_IO,内核设置IRP 的UserBuffer域来对应ReadFile或WriteFile中的buff参数。然而,存储区并没有被锁住而且地址只对调用进程有效。驱动程序可以使用KIrp::UserBuffer来存取IRP域。对于DeviceIoControl调用,buffer参数的转换依赖于特殊的I/O控制代码,它不在设备对象的特性中。宏CTL_CODE(在winioctl.h中定义)用来构造控制代码。这个宏的其中一个参数指明缓冲方法是METHOD_BUFFERED, METHOD_IN_DIRECT, METHOD_OUT_DIRECT, 或METHOD_NEITHER。下面的表显示了这些方法和与之对应的能获得输入缓冲与输出缓冲的KIrp中的成员函数:Method  Input Buffer Parameter  Output Buffer Parameter METHOD_BUFFERED  KIrp::IoctlBuffer KIrp::IoctlBuffer METHOD_IN_DIRECT  KIrp::IoctlBuffer KIrp::Mdl METHOD_OUT_DIRECT  KIrp::IoctlBuffer KIrp::Mdl METHOD_NEITHER  KIrp::IoctlType3InputBuffer KIrp::UserBuffer 如果控制代码指明METHOD_BUFFERED,系统分配一个单一的缓冲来作为输入与输出。驱动程序必须在向输出缓冲放数据之前拷贝输入数据。驱动程序通过调用KIrp::IoctlBuffer获得缓冲地址。在完成时,I/O管理器从系统缓冲拷贝数据到提供给Ring 3级调用者使用的缓冲中。驱动程序必须在结束前存储拷贝到IRP的Information成员中的数据个数。如果控制代码不指明METHOD_IN_DIRECT或METHOD_OUT_DIRECT,则DeviceIoControl的参数呈现不同的含义。参数InputBuffer被拷贝到一个系统缓冲,这个缓冲驱动程序可以通过调用KIrp::IoctlBuffer。参数OutputBuffer被映射到KMemory对象,驱动程序对这个对象的访问通过调用KIrp::Mdl来实现。对于METHOD_OUT_DIRECT,调用者必须有对缓冲的写访问权限。注意,对METHOD_NEITHER,内核只提供虚拟地址;它不会做映射来配置缓冲。虚拟地址只对调用进程有效。这里是一个用METHOD_BUFFERED的例子:首先,使用宏CTL_CODE来定义一个IOCTL代码:#define IOCTL_MYDEV_GET_FIRMWARE_REV \CTL_CODE (FILE_DEVICE_UNKNOWN,0,METHOD_BUFFERED,FILE_ANY_ACCESS)现在使用一个DeviceIoControl调用:BOOLEAN b;CHAR FirmwareRev[60];ULONG FirmwareRevSize;b = DeviceIoControl(hDevice, IOCTL_MYDEV_GET_VERSION_STRING,  NULL, // no input  注意,这里放的是包含有执行操作命令的字符串指针  0, FirmwareRev,      //这里是output串指针,存放从驱动程序中返回的字符串。sizeof(FirmwareRev),& FirmwareRevSize,  NULL // not overlapped I/O );如果输出缓冲足够大,设备拷贝串到里面并将拷贝的资结束设置到FirmwareRevSize中。在驱动程序中,代码看起来如下所示:const char* FIRMWARE_REV = "FW 16.33 v5";NTSTATUS MyDevice::DeviceControl( KIrp I ){  ULONG fwLength=0;  switch ( I.IoctlCode() )  {    case IOCTL_MYDEV_GET_FIRMWARE_REV:      fwLength = strlen(FIRMWARE_REV)+1;      if (I.IoctlOutputBufferSize() >= fwLength)      {        strcpy((PCHAR)I.IoctlBuffer(),FIRMWARE_REV);        I.Information() = fwLength;         return I.Complete(STATUS_SUCCESS);      }      else      {              }    case . . .   } }

    标签: 驱动程序 应用程序 接口

    上传时间: 2013-10-17

    上传用户:gai928943

  • 微机原理与接口课件

    微处理器及微型计算机的发展概况  第一代微处理器是以Intel公司1971年推出的4004,4040为代表的四位微处理机。      第二代微处理机(1973年~1977年),典型代表有:Intel 公司的8080、8085;Motorola公司的M6800以及Zlog公司的Z80。     第三代微处理机 第三代微机是以16位机为代表,基本上是在第二代微机的基础上发展起来的。其中Intel公司的8088。8086是在8085的基础发展起来的;M68000是Motorola公司在M6800 的基础发展起来的;     第四代微处理机 以Intel公司1984年10月推出的80386CPU和1989年4月推出的80486CPU为代表,     第五代微处理机的发展更加迅猛,1993年3月被命名为PENTIUM的微处理机面世,98年PENTIUM 2又被推向市场。 INTEL CPU 发展历史Intel第一块CPU 4004,4位主理器,主频108kHz,运算速度0.06MIPs(Million Instructions Per Second, 每秒百万条指令),集成晶体管2,300个,10微米制造工艺,最大寻址内存640 bytes,生产曰期1971年11月. 8085,8位主理器,主频5M,运算速度0.37MIPs,集成晶体管6,500个,3微米制造工艺,最大寻址内存64KB,生产曰期1976年 8086,16位主理器,主频4.77/8/10MHZ,运算速度0.75MIPs,集成晶体管29,000个,3微米制造工艺,最大寻址内存1MB,生产曰期1978年6月. 80486DX,DX2,DX4,32位主理器,主频25/33/50/66/75/100MHZ,总线频率33/50/66MHZ,运算速度20~60MIPs,集成晶体管1.2M个,1微米制造工艺,168针PGA,最大寻址内存4GB,缓存8/16/32/64KB,生产曰期1989年4月 Celeron一代, 主频266/300MHZ(266/300MHz w/o L2 cache, Covington芯心 (Klamath based),300A/333/366/400/433/466/500/533MHz w/128kB L2 cache, Mendocino核心 (Deschutes-based), 总线频率66MHz,0.25微米制造工艺,生产曰期1998年4月) Pentium 4 (478针),至今分为三种核心:Willamette核心(主频1.5G起,FSB400MHZ,0.18微米制造工艺),Northwood核心(主频1.6G~3.0G,FSB533MHZ,0.13微米制造工艺, 二级缓存512K),Prescott核心(主频2.8G起,FSB800MHZ,0.09微米制造工艺,1M二级缓存,13条全新指令集SSE3),生产曰期2001年7月. 更大的缓存、更高的频率、 超级流水线、分支预测、乱序执行超线程技术 微型计算机组成结构单片机简介单片机即单片机微型计算机,是将计算机主机(CPU、    内存和I/O接口)集成在一小块硅片上的微型机。 三、计算机编程语言的发展概况 机器语言  机器语言就是0,1码语言,是计算机唯一能理解并直接执行的语言。汇编语言  用一些助记符号代替用0,1码描述的某种机器的指令系统,汇编语言就是在此基础上完善起来的。高级语言  BASIC,PASCAL,C语言等等。用高级语言编写的程序称源程序,它们必须通过编译或解释,连接等步骤才能被计算机处理。 面向对象语言  C++,Java等编程语言是面向对象的语言。 1.3 微型计算机中信息的表示及运算基础(一) 十进制ND有十个数码:0~9,逢十进一。 例 1234.5=1×103 +2×102 +3×101 +4×100 +5×10-1加权展开式以10称为基数,各位系数为0~9,10i为权。 一般表达式:ND= dn-1×10n-1+dn-2×10n-2 +…+d0×100 +d-1×10-1+… (二) 二进制NB两个数码:0、1, 逢二进一。 例 1101.101=1×23+1×22+0×21+1×20+1×2-1+1×2-3 加权展开式以2为基数,各位系数为0、1, 2i为权。 一般表达式:  NB = bn-1×2n-1 + bn-2×2n-2 +…+b0×20 +b-1×2-1+… (三)十六进制NH十六个数码0~9、A~F,逢十六进一。 例:DFC.8=13×162 +15×161 +12×160 +8×16-1 展开式以十六为基数,各位系数为0~9,A~F,16i为权。 一般表达式: NH= hn-1×16n-1+ hn-2×16n-2+…+ h0×160+ h-1×16-1+… 二、不同进位计数制之间的转换 (二)二进制与十六进制数之间的转换  24=16 ,四位二进制数对应一位十六进制数。举例:(三)十进制数转换成二、十六进制数整数、小数分别转换   1.整数转换法“除基取余”:十进制整数不断除以转换进制基数,直至商为0。每除一次取一个余数,从低位排向高位。举例: 2. 小数转换法“乘基取整”:用转换进制的基数乘以小数部分,直至小数为0或达到转换精度要求的位数。每乘一次取一次整数,从最高位排到最低位。举例:  三、带符号数的表示方法 机器数:机器中数的表示形式。真值: 机器数所代表的实际数值。举例:一个8位机器数与它的真值对应关系如下:  真值: X1=+84=+1010100B     X2=-84= -1010100B   机器数:[X1]机= 01010100    [X2]机= 11010100(二)原码、反码、补码最高位为符号位,0表示 “+”,1表示“-”。 数值位与真值数值位相同。 例  8位原码机器数:  真值:   x1  = +1010100B     x2    =- 1010100B      机器数: [x1]原  = 01010100  [x2]原 = 11010100原码表示简单直观,但0的表示不唯一,加减运算复杂。 正数的反码与原码表示相同。       负数反码符号位为 1,数值位为原码数值各位取反。 例 8位反码机器数:          x= +4: [x]原= 00000100 [x]反= 00000100     x= -4: [x]原= 10000100  [x]反= 111110113、补码(Two’s Complement)正数的补码表示与原码相同。       负数补码等于2n-abs(x)8位机器数表示的真值四、 二进制编码例:求十进制数876的BCD码 876= 1000 0111 0110 BCD  876= 36CH = 1101101100B 2、字符编码    美国标准信息交换码ASCII码,用于计算      机与计算机、计算机与外设之间传递信息。 3、汉字编码 “国家标准信息交换用汉字编码”(GB2312-80标准),简称国标码。 用两个七位二进制数编码表示一个汉字 例如“巧”字的代码是39H、41H汉字内码例如“巧”字的代码是0B9H、0C1H1·4  运算基础 一、二进制数的运算加法规则:“逢2进1”       减法规则:“借1当2”       乘法规则:“逢0出0,全1出1”二、二—十进制数的加、减运算        BCD数的运算规则 循十进制数的运算规则“逢10进1”。但计算机在进行这种运算时会出现潜在的错误。为了解决BCD数的运算问题,采取调整运算结果的措施:即“加六修正”和“减六修正”例:10001000(BCD)+01101001(BCD)        =000101010111(BCD)                1 0 0 0 1 0 0 0       +  0 1 1 0 1 0 0 1           1 1 1 1 0 0 0 1        +  0 1 1 0 0 1 1 0     ……调整          1 0 1 0 1 0 1 1 1                                        进位  例:  10001000(BCD)- 01101001(BCD)= 00011001(BCD)                   1 0 0 0 1 0 0 0            -   0 1 1 0 1 0 0 1             0 0 0 1 1 1 1 1         -                    0 1 1 0   ……调整             0 0 0 1 1 0 0 1  三、 带符号二进制数的运算 1.5 几个重要的数字逻辑电路编码器译码器计数器微机自动工作的条件程序指令顺序存放自动跟踪指令执行1.6 微机基本结构微机结构各部分组成连接方式1、以CPU为中心的双总线结构;2、以内存为中心的双总线结构;3、单总线结构CPU结构管脚特点  1、多功能;2、分时复用内部结构  1、控制; 2、运算; 3、寄存器; 4、地址程序计数器堆栈定义 1、定义;2、管理;3、堆栈形式

    标签: 微机原理 接口

    上传时间: 2013-10-17

    上传用户:erkuizhang

  • powerbuilder 教程下载

    powerbuilder 教程 PowerBuilder(Power Builder,PB)是著名的数据库应用开发工具生产厂商PowerSoft公司推出的产品(PowerSoft现已被数据库厂商Sybase所收购),它完全按照客户机/服务器体系结构研制设计,在客户机/服务器结构中,它使用在客户机中,作为数据库应用程序的开发工具而存在。由于PowerBuilder采用了面向对象和可视化技术,提供可视化的应用开发环境,使得我们利用PowerBuilder,可以方便快捷地开发出利用后台服务器中的数据和数据库管理系统的数据库应用程序。       在当前,网络技术迅速发展,随之发展的还有OLE,OCX,跨平台等技术,而在PowerBuilder的最新版中提供了对这些技术的全面支持。在数据库开发工具领域,PowerBuilder是其中非常优秀的一个,利用它我们可以开发出功能强大的数据库应用程序。     PowerBuilder提供了对目前流行的大多数关系数据库管理系统的支持,由于在PowerBuilder的应用程序中对数据库访问的部分一般采用国际化标准数据库查询语言SQL,使得用PowerBuilder开发的应用程序可以不做修改或者只做少量的修改就可以在不同的后台数据库管理系统上使用。也就是说用PowerBuilder开发的应用程序是独立于服务器上的数据库。  

    标签: powerbuilder 教程下载

    上传时间: 2013-11-12

    上传用户:lgd57115700