太阳能蓄电池与光照时间的关系 例如:有一块单晶硅电池的组件,最大的输出功率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版)》通过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周期与微指令周期的时间关系:
上传时间: 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通信实验
上传时间: 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(Power Builder,PB)是著名的数据库应用开发工具生产厂商PowerSoft公司推出的产品(PowerSoft现已被数据库厂商Sybase所收购),它完全按照客户机/服务器体系结构研制设计,在客户机/服务器结构中,它使用在客户机中,作为数据库应用程序的开发工具而存在。由于PowerBuilder采用了面向对象和可视化技术,提供可视化的应用开发环境,使得我们利用PowerBuilder,可以方便快捷地开发出利用后台服务器中的数据和数据库管理系统的数据库应用程序。 在当前,网络技术迅速发展,随之发展的还有OLE,OCX,跨平台等技术,而在PowerBuilder的最新版中提供了对这些技术的全面支持。在数据库开发工具领域,PowerBuilder是其中非常优秀的一个,利用它我们可以开发出功能强大的数据库应用程序。 PowerBuilder提供了对目前流行的大多数关系数据库管理系统的支持,由于在PowerBuilder的应用程序中对数据库访问的部分一般采用国际化标准数据库查询语言SQL,使得用PowerBuilder开发的应用程序可以不做修改或者只做少量的修改就可以在不同的后台数据库管理系统上使用。也就是说用PowerBuilder开发的应用程序是独立于服务器上的数据库。
标签: powerbuilder 教程下载
上传时间: 2013-11-12
上传用户:lgd57115700