数位板压力测试


-
sdk LCS/Telegraphics Wintab* Interface Specification 1.1: 16- and 32-bit API Reference By Rick Poyner Revised February 11, 2012 This specification was developed in response to a perceived need for a standardized programming inter-face to digitizing tablets, three dimensional position sensors, and other pointing devices by a group of lead-ing digitizer manufacturers and applications developers. The availability of drivers that support the features of the specification will simplify the process of developing Windows appli¬cation programs that in-corporate absolute coordinate input, and enhance the acceptance of ad¬vanced pointing de¬vices among users. This specification is intended to be an open standard, and as such the text and information contained herein may be freely used, copied, or distributed without compensation or licensing restrictions. This document is copyright 1991-2012 by LCS/Telegraphics.* Address questions and comments to: LCS/Telegraphics 150 Rogers St. Cambridge, MA 02142 (617)225-7970 (617)225-7969 FAX Compuserve: 76506,1676 Internet: wintab@pointing.com Note: sections marked with the “(1.1)” are new sections added for specification version 1.1. Sec-tions bearing the “(1.1 modified)” notation contain updated information for specification version 1.1. Version 1.1 Update Notation Conventions 1 1. Background Information 1 1.1. Features of Digitizers 1 1.2. The Windows Environment 1 2. Design Goals 2 2.1. User Control 2 2.2. Ease of Programming 2 2.3. Tablet Sharing 3 2.4. Tablet Feature Support 3 3. Design Concepts 3 3.1. Device Conventions 3 3.2. Device Information 4 3.3. Tablet Contexts 4 3.4. Event Packets 4 3.5. Tablet Managers 5 3.6. Extensions 5 3.7. Persistent Binding of Interface Features (1.1) 6 4. Interface Implementations 6 4.1. File and Module Conventions 6 4.2. Feature Support Options 6 5. Function Reference 7 5.1. Basic Functions 7 5.1.1. WTInfo 8 5.1.2. WTOpen 9 5.1.3. WTClose 10 5.1.4. WTPacketsGet 10 5.1.5. WTPacket 11 5.2. Visi
9.24MB
测试培训教材
2014-04-01测试管理与QualityCenter培训手册 1、测试流程管理、测试度量方法 按照尽早进行测试的原则,测试人员应该在需求阶段就介入,并贯穿软件开发的全过程。就测试过程本身而言,应该包含以s下几个阶段。 -测试需求的分析和确定。 -测试计划。 -测试设计。 -测试执行。 -测试记录和缺陷跟踪。 -回归测试。 -测试总结和报告。 一个好的测试管理工具应该能把以上几个阶段都管理起来。 测试人员每时每刻都在度量别人的工作成果,而测试人员的工作成果又由谁来度量呢?度量的标准和依据是什么呢?软件测试的度量是测试管理必须仔细思考的问题。缺乏尺度会让测试失去平衡,缺乏标准会让测
9KB
电子设计.doc
2019-05-28(文件太大无法上传全部,下载的是网盘链接(内含全部文件)!!!)部分资料清单: 0001、PC 机与单片机通信(RS232 协议) 0002、C与VB语言联合在proteus上仿真 0003、IC卡读写仿真 0004、Integrate就医服务平台论文 0005、PC红外线遥控器上位机及电路图 0006、PLC电梯控制系统论文 0007、VB上位机程序控制DS1302时钟的proteus仿真 0008、VB上位机与18b20下位机 0009、八路扫描式抢答器设计论文 0010、比较全面的手机原理资料 0011、采用实时时钟芯片DS1302+AT89C2051的红外遥控LED电子钟 0012、51单片机超声波测距程序 0013、单片机C语言程序设计实训100例——基于8051+Proteus仿真 0014、电机转速测量系统论文 0015、多功能出租车计价器设计论文资料 0016、多功能数字时钟设计论文资料 0017、肺活量测量仪设计论文资料 0018、高保真音响设计制作论文资料 0019、高灵敏无线探听器电路资料 0020、给初学51单片机的40个实验汇编语言对应C语言加说明 0021、国旗升降系统程序及原理图资料 0022、基于51单片机的电子万年历的设计论文资料 0023、基于51单片机的数字频率计设计论文资料 0024、基于AVR及无线收发模块的脉搏监测系统设计论文资料 0025、基于CPLD的三相多波形函数发生器设计论文资料 0026、基于DDS的信号源设计论文资料 0027、基于FPGA多通道采样系统设计论文资料 0028、基于GSM短信模块的家庭防盗报警系统论文资料 0029、基于IGBT的变频电源设计论文资料 0030、基于PLL信号发生器的设计论文资料 0031、基于PSTN的家用电器远程控制系统设计论文资料 0032、基于USB的经络信号的检测系统与设计论文资料 0033、基于USB接口的温度控制器设计资料 0034、基于单片机的电集中抄表设计论文资料 0035、基于单片机的简易逻辑分析仪设计论文资料 0036、基于单片机的数字温度计设计论文资料 0037、基于单片机的数字钟设计论文资料 0038、基于单片机的水温控制系统PDF资料 0039、基于单片机的水温控制系统设计论文资料 0040、基于单片机的作息时间控制钟系统资料 0041、基于单片机的温度控制系统论文资料 0042、基于单片机控制的交通灯毕业设计资料 0043、基于单片机控制的开关电源论文资料 0044、基于网络的虚拟仪器测试系统论文资料 0045、家用音响设计制作论文资料 0046、具有定时功能的八路数显抢答器的设计论文 0047、开关电源论文资料 0048、自来水厂全自动恒压供水监控系统论文资料 0049、量程自动切换数字电压表proteus仿真+程序资料 0050、牧场智能挤奶与综合信息管理系统论文资料 0051、汽车实验台电路控制系统论文 0052、汽车尾灯控制电路设计论文资料 0053、抢答器论文及其proteus仿真资料 0054、全遥控数字音量控制的D 类功率放大器论文资料 0055、ATMEGA16单片机实现的数控频率计原理图及其程序论文 0056、数控云台proteus仿真+程序资料 0057、AT89S52单片机实现数控直流电流源论文资料 0058、AT89S52单片机数控直流电源原理图程序资料 0059、数控直流稳压电源完整论文资料 0060、数控直流稳压电源proteus仿真+程序资料 0061、数字示波器的制作 0062、数字式调频收音机设计论文资料 0063、数字式秒表文档论文资料 0064、数字万年历设计论文资料 0065、数字温度计设计论文资料 0066、水库控制系统设计论文资料 0067、同步电机模型的MATLAB仿真论文资料 0068、危险气体泄露报警器设计论文资料 0069、微型打印机控制电路的设计论文资料 0070、温度监控系统的设计论文资料 0071、温度控制系统设计论文资料 0072、无线调频发射器的设计论文资料 0073、无线视频监控系统设计毕业论文资料 0074、无线鼠标设计论文资料 0075、无线数据收发系统毕业论文资料 0076、无线遥控盆腔治疗仪论文资料 0077、无线遥控设计资料 0078、无线语音遥控智能车论文资料 0079、消防智能电动车设计与制作论文资料 0080、悬挂运动控制系统论文资料 0081、遥控系统的设计资料 0082、液体点滴速度监控装置资料 0083、一种智能频率计的设计与制作(AVR)proteus仿真+程序资料 0084、音频信号分析仪毕业设计论文资料 0085、应用电子、继电线路设计论文资料 0086、用单片机实现温度远程显示论文资料 0087、远程温度控制系统毕业
48.79MB
AIDA64 Extreme Edition v6.00.5134 Beta.zip
2019-07-14AIDA64 Extreme Edition是一款专业的测试软硬件系统信息的工具,软件采用32位的底层硬件扫描,可以支持3400多种主板,支持上千种显卡,支持对并口/串口/USB这些PNP设备的检测,支持对各式各样的处理器的侦测。用户使用软件可以详细的显示出PC每一个方面的信息。AIDA64不仅提供了诸如协助超频,硬件侦错,压力测试和传感器监测等多种功能,而且还可以对处理器,系统内存和磁盘驱动器的性能进行全面评估。目前支持所有的32位和64位Microsoft Windows操作系统,包括对Windows 7和Windows Server 2008 R2的兼容。是用户实现测试软硬件系统信息功能的好帮手。 AIDA64效能测试说明 CPU Queen 是测试CPU的分支预测能力,以及预测错误时所造成的效能影响。对于主频相同的CPU,更短的处理管线和更加准确的预测能力在此项得分上就更高。因此,可以看出并不是主频越高的CPU性能就越好,这项得分能反映CPU的真实性能,让大家在选择CPU时不再盲目追求高主频。 CPU PhotoWorxx 着重于CPU的整数运算能力、多核心运算能力并涉及到记忆体频宽的运算能力,利用模拟数位影像处理来进行CPU效能的评估。这项测试需要频繁及大量的记忆体存取操作,所以说这项测试不仅对处理器的要求很高,同时对记忆体速度也有较高的要求。对于在影片处理,如影片压缩、影片转档应用比较多的人,此项得分越高越好。 CPU ZLib 是另一项针对CPU整数运算的测试,利用Zlib这个压缩演算法,来计算CPU在处理压缩档案时的能力。如果你比较要求CPU的压缩和解压缩档案能力的话,就可以关心一下这项得分。 CPU AES 是一种加密演算测试,用来反映CPU在进行AES加密演算法时的效能。这项测试主要针对一些网路伺服器,比如指令伺服器,它们会进行频繁的加解密操作,那么这项得分的高低就特别重要了。 CPU Hash 是一种采用SHA1哈希算法的测试,用来反映CPU整数运算能力。 FPU VP8 是利用谷歌VP8视频编解码器,来测试处理器的视频压缩运算能力。 FPU Julia 是利用朱利亚碎形几何运算,来评估CPU的单精度(32bit)浮点运算能力。 FPU Mandel 则利用了Mandelbrot碎形几何运算,来评估CPU的双精度(64bit)运算能力。 FPU SinJulia 则是利用修改过的朱利亚碎形运算,来评估CPU的延伸精度(80bit)浮点运算能力。 FPU Julia、FPU Mandel、FPU SinJulia 这三项都是测试CPU的浮点运算能力,这几项测试可以测量CPU在游戏中的表现。 AIDA64 Extreme Edition软件截图
15.26MB
AIDA64 Extreme Edition 3.00.2500 至尊版
2013-09-20对于经常使用电脑的人来说,有时候难免需要知道相应的软硬件信息。曾经,为了下载合适的驱动程序,总得拆开机箱,甚至打着手电筒去辨别硬件规格和信息。现在好了,用 AIDA64 吧,有了它,再不用如此辛苦! AIDA64是一款测试软硬件系统信息的工具,它可以详细的显示出PC的每一个方面的信息。AIDA64不仅提供了诸如协助超频、硬件侦测、压力测试和传感器监测等多种功能,而且还可以对处理器、系统内存和磁盘驱动器的性能进行全面评估。 AIDA64的前身是:EVEREST。早在16位系统的时候 EVEREST 叫 AIDA16 ,后来随着32位技术来临改名为 AIDA32 ,随后再次更名才成了 EVEREST。现在它的开发商 Lavalys 公司已经被 FinalWire 所收购,自己也又一次改名,变成了 AIDA64,算是在回归传统的同时拥抱64位技术,程序图标都是个大大的“64”,但是原来的 EVEREST 却不会再更新了。AIDA64 支持数千种主板,支持数百种显卡,支持对并口/串口/USB这些PNP设备的检测,支持对各式各样的处理器的侦测。目前 AIDA64 已经能支持包括中文在内的30种语言,让你轻松使用。而且经过几次大的更新,现在的 AIDA64 已经具备了一定的硬件测试能力,让您对自己电脑的性能有个直观的认识。
519KB
PCB基础知识培训教程
2011-07-08PCB基础知识培训教程 1 培训对象 新员工 新员工了解印制板生产流程, 掌握相关工艺知识; 2 印制板生产工艺流程 光绘底片 内层课 层压课 钻孔课 孔化课 外层课 电镀;外层蚀刻课 阻焊课 字符课 表面处理课 成型课 检验课 3 下料 内层 线路 层压 钻孔 孔化 阻焊 外层 线路 二次 电镀 外层 干膜 电镀 表面 处理 字符 成型 包装 4 生产流程 裁板 前处理 压膜 蚀刻 显影 曝光 5 去膜 主要质量控制点: 底片质量:重合度、黑白反差和图形精度。 处理后的基材表面质量:粗造度均匀,表面无划痕和氧化。 贴膜质量:干膜附着力强,无皱褶、气泡和杂质。 曝光质量:严格控制曝光参数和真空度,图形边界平直。 显影质量:严格控制显像点,防止欠显和过显影现象。 蚀刻质量:严格控制溶液蚀刻能力和添加量,做好批量前的首件蚀 刻实验,保证蚀刻精度。 检修:坚持首板自检和互检制度,严防共同缺陷或批量报废。 6 裁板 依制设计要求,将基板材料裁切成工作所需尺寸。 主要原料:基材 基材由铜皮和绝缘层压合而成,依要求有不同板厚规格,依铜厚可分 为H/H;1oz/1oz;2oz/2oz等种类。 7 前处理 目的:去除铜面上的污 染物,增加铜面粗糙度,以利 于后续的压膜制程。 铜箔 绝缘层 前处理后 铜面状况 示意图 13 压膜 目的: 目的:经处理后基材铜 面透过热压方式贴上抗 蚀干膜。 干膜 压膜前 压膜后 9 光源 曝光 目的:经光源作用将原始底片 上的图像转移到感光底板上。 主要原料:底片 原图通过CAM处理完毕后的文件,可 以光绘输出,制作成为图形转移的 底片。该工序是制造印制电路板关 键技术之一。将CAM文件中的导电层, 阻焊层,字符层分别绘制在每张底 片。 内层所用底片为负片,即白色透光部 分发生光聚合反应, 黑色部分则因 不透光,不发生反应,外层所用底片 刚好与内层相反,底片为正片。 10 发生光聚合反应 曝光后 显影 目的: 用碱液作用将未发生化学反应 之干膜部分冲掉。 抗蚀保护膜 将未发生反应干膜冲掉,而发 生反应之干膜则保留在板面上 作为蚀刻时之抗蚀保护层。 11 显影前 显影后 蚀刻: 目的:利用药液将显影后 露出的铜蚀掉,形成内层线路 图形。 蚀刻前 铜箔蚀刻 蚀刻后 12 去膜 目的:利用强碱将保护铜 面抗蚀层剥掉,露出线路图 形。 去膜前 去膜后 13 流程介绍: AOI检测 目的: 确认 AOI检测系统的作用是检测PCB在制造过程中的缺陷,检测的项目主要 包括:焊盘缺陷,缺口,焊盘直径缩小,针孔,凹陷;线条缺陷,如 短路,开路,线宽/线间距,缺口,凹陷,铜渣,针孔等。当内层图形 制作完成后,所有的单片则交至AOI组进行如上的一些检测,如发现单 片在烂板过程中造成缺陷则到返修台进行修复,如果无法修复的,则 进行单片报废处理,重行进行补单片! AOI检验: 全称为自动光学检测 原理:通过光学反射原理将图像回馈至设备处理与原图做比较,找出 缺点位置。 确认 目的: 通过与AOI连线测试,由人工对AOI的测试缺点进行确认。 确认人员不光要对测试缺点进行确认,另外就是对一些可以直接修补 的确认缺点进行修补。 简介: 按照导电图形的层数来定义的,有4层导电图形即为多层板,它实际上是使用几 个双面板组成,并在每层板间放进一层绝缘层后压合而成。它的层数都是偶数。 多层板层压技术,利用半固化片将导电图形在高温、高压下粘合起来的技术称为 层压技术。鉴于多层板的高速发展,现在已是主流,所以层压技术显得愈来愈重要。 这里起到层间粘合的半固化片,他是多层板生产中的主要材料之一,其主要成分是 树脂和增强材料组成,现在常用的FR4,它所包含的玻璃布即为它的增强材料。它 也分不同的型号不同的规格,常用的7628(0.17-0.18),2116(0.1-0.12), 1080(0.05-0.06),106(0.038-0.04)等等。 流程介绍: 棕化 叠板 压合 后处理 目的: 将铜箔、胶片与氧化处理后的内层线路板压合成多层板。 棕化 目的: 目的: (1)粗化铜面,增加与树脂接触表面积. (2)增加铜面对流动树脂之湿润性. (3)使铜面钝化,避免发生不良反应. 叠板 目的: 目的:将预叠合好的板叠成待压多 层板形式. 主要原料:基材+半固化片. Layer 1 Layer 2 Layer 3 Layer 4 Layer 5 Layer 6 压合: 目的:通过热压方式将叠合板压成多层板。 主要原料:牛皮纸;钢板。 热板 压力 钢板 牛皮纸 承载盘 可叠很多层 后处理 目的:经打工具孔、磨边等工序对压合之多层板进行初步外形处理以便后 工序生产品质控制要求。 简介: 在印制板上钻孔有多种方式,常用的是机械
9KB
模拟量控制器 IO控制 比例阀控制 步进伺服控制型号JMDM-2038ADDA.txt
2019-09-19模拟量控制器 IO控制 比例阀控制 步进伺服控制型号JMDM-2038ADDAtxt,一、产品功能介绍1.1、模拟量控制器:JMDM-2038ADDA功能:1、控制12个I/O点,全光电隔离。6路输入:NPN 输入形式,输入电流为10mA即可,默认12V--24V的开关量输入检测,5V开关量输入检测需定做。6路输入可以作为行程限位开关、红外传感器、接近开关、按钮等的检测。6路晶体管输出:最大每路输出能承受4A电流。输出低电平有效。可驱动5---30V之间工作的负载。可以用来控制电磁阀、电磁继电器、固态继电器、气缸等负载。2、4路光电隔离PWM输出。PWM输出工作电压为(5~12V)。PWM输出精度是13位的,可用于控制比例阀、IGBT等。占空比可以编程设定,占空比范围为(0.000~1.000)。可用于控制频率器、激光发射器、电机调速、调光等应用场合。4路PWM输出可通过程序精密控制占空比,也可当作模拟量输出使用。3、 8路模拟量控制:4入4出。输入:4路高速高精度AD模拟量检测通道。检测电压范围是0--5V。可以定做成0--10V检测量程。AD位数可以通过软件来修改,可改位数为12位、14位、16位和18位。检测速度分别为4ms、20ms、60ms和245ms。IIC总线读取数据方式。可用于模拟量的检测控制,如电压,电流,温度,湿度,压力等模拟量信号的检测控制。1.2、运动控制器:JMDM-2038M功能:1、控制18个I/O点,全光电隔离。12路输入:NPN 输入形式,输入电流为10mA即可,默认12V--24V的开关量输入检测,5V开关量输入检测需定做。12路输入可以作为行程限位开关、红外传感器、接近开关、按钮等的检测。6路晶体管输出:最大每路输出能承受4A电流。输出低电平有效。可驱动5---30V之间工作的负载。可以用来控制电磁阀、电磁继电器、固态继电器、气缸等负载。2、两路脉冲信号输出、两路方向信号输出,可同时控制两路步进或伺服电机联动。3、一路可程控频率信号输出,用于一些调速等控制场合。1.3、共性: JMDM-2038ADDA和JMDM-2038M均具备以下功能:1、有一个128*64液晶显示屏,亮度可调。可显示4行6列标准汉字。背光灯可以通过软件开启和关闭。2、带有RS485通信端子和RS232通信端口,RS232和RS485可以通过两个跳线帽来进行切换。3、RS232接口直接在线通过串口线下载程序。4、有一个蜂鸣器输出,可以用于报警提醒。5、拥有10个按钮面板可以设置参数。二、技术参数1、8位高性能单片机作为主控制芯片,程序空间为64K;2、32K字节的数据存储器,可以用来保存参数等数据,断电数据不丢失;3、预留IIC总线接口,可以焊接24C02等系列的存储芯片;4、控制器工作电源:标配24V直流1A开关电源。12V-30V直流(或9V-20V交流)之间均可以正常运行;5、有1 路标准的RS232 串行通信接口,可以与电脑等上位软件通信,也可与多个控制器之间联机工作。可以通过条线帽切换成RS485进行通信,可用于多机组网;6、可直接通过RS232接口下载程序,无需烧录器,方便程序修改、升级;7、系统采用光电隔离和启用内部看门狗及严格的高频滤除特性,并有专业的电源监控电路使系统工作稳定可靠,无死机现象;8、128*64液晶蓝屏显示,一屏可显示6列*4行=24个汉字;也可显示图形数字符号等;9、有10个轻触按键,可在线设置参数;10、外形尺寸:紧凑型机壳,控制器机壳尺寸:150mm*145mm*55mm,安装尺寸:145mm*140mm,可用配套的铜卡安装;11、用Keil C编程,用户编程有困难的可把工艺流程发给我司,我司可代为开发程序。三、应用场合1、可用于各数字量输入输出的控制系统,可控制气缸、电磁阀、继电器等;可外接各种光电传感器、红外开关。2、可控制温度、压力、激光能量、变频器等模拟量信号输入输出。3、可控制步进电机和伺服电机。4、也可用于替代PLC用于各种控制场合(如各种机器控制),功能上比PLC加文本显示器更为强大、灵活。性能稳定,性价比高。目前已广泛应用于气缸、电磁阀、继电器、压力测试仪、液压控制器、激光控制器、步进伺服控制、多段多路温度控制器等要求高精度、高速度的工业环境和设备上,运行稳定可靠,成功地经受了恶劣工业环境场合的强电磁、高频干扰的考验,以高性价比赢得了广大客户的信赖,并远销海内外。
1.23MB
程控交换实验、用户模块电路 主要完成BORSCHT七种功能,它由下列电路组成:
2008-12-24实验一 程控交换原理实验系统及控制单元实验 一、 实验目的 1、熟悉该程控交换原理实验系统的电路组成与主要部件的作用。 2、体会程控交换原理实验系统进行电话通信时的工作过程。 3、了解CPU中央集中控制处理器电路组成及工作过程。 二、 预习要求 预习《程控交换原理》与《MCS-51单片计算机原理与应用》中的有关内容。 三、 实验仪器仪表 1、主机实验箱 一台 2、三用表 一台 3、电话单机 四台 四、 实验系统电路组成 (一)电路组成 图1-1是该实验系统的原理框图 图1-1 实验系统的原理框图 图1—2是该实验系统的方框图,其电路的组成及主要作用如下: 1、用户模块电路 主要完成BORSCHT七种功能,它由下列电路组成: A、 用户线接口电路 B、 二\四线变换器 C、 PCM编译码电路 用户线接口电路 二/ 四线变换器 二/四线变换器 用户线接口电路 用户1 PCM CODEC电路 PCM CODEC电路 用户3 用户线接口电路 二/ 四线变换器 二/ 四线变换器 用户线接口电路 用户2 PCM CODEC电路 PCM CODEC电路 用户4 时钟信号电路 控制、检测电路 输出显示电路 二次稳压电路 多种信号音电路 CPU中央处理器 键盘输入电路 直流电源 图1-2 实验系统方框图 2、交换网络系统 主要完成空分交换与时隙交换两大功能,它由下列电路组成: A、空分交换网络系统 B、时隙交换网络系统 3、多种信号音电路 主要完成各种信号音的产生与发送,它由下列电路组成: A、450Hz拨号音电路 B、忙音发生电路 C、回铃音发生电路 D、25Hz振铃信号电路 4、CPU中央集中控制处理器电路 主要完成对系统电路的各种控制,信号检测,号码识别,键盘输入信息,输出显示信息等各种功能。 5、系统工作电源 主要完成系统所需要的各种电源,本实验系统中有+5V,-5V,+12V,-12V,-48V等5组电源,由下列电路组成: A、内置工作电源:+5V,+12V,-12V,-48V B、稳压电源: -8V,-5V 控制部分就是由CPU中央处理系统、输入电路(键盘)、输出电路(数码管)、双音多频DTMF检测电路、用户环路状态检测电路、自动交换网络驱动电路与交换网络转换电路、扩展电路、信号音控制电路等电路组成。 下面简要说明各部分电路的作用与要求: 1、键盘输入电路: 主要把实验过程中的一些功能通过键盘设置到系统中。 2、显示电路: 显示主叫与被叫电路的电话号码,同时显示通话时间。 3、输入输出扩展电路: 显示电路与键盘输入电路主要通过该电路进行工作。主要芯片是D8155A,SN74LS240,MC1413。 4、双音多频DTMF接收检测电路: 把MT8870DC输出的DTMF四位二进制信号,接收存贮后再送给CPU中央集中控制处理系统。 5、用户状态检测电路: 主要识别主、被叫用户的摘挂机状态,送给CPU进行处理。 6、自动交换网络驱动电路: 主要实现电话交换通信时,CPU发出命令信息,由此电路实现驱动自动交换网络系统,其核心集成电路为SN74LS374,D8255A,GD74LS373等芯片。 7、信号音控制电路: 它完全按照CPU发出的指令进行操作,使各种信号音按照系统程序进行工作。 8、振铃控制电路: 它也是按照CPU发出的指令进行工作,具体如下: (A)不振铃时,要求振铃支路与供电系统分开。 (B)振铃时,铃流送向话机,并且供电系统通过振铃支路向用户馈电,用户状态检测电路同时能检测用户的忙闲工作状态。 (C)当振铃时,用户一摘机就要求迅速断开振铃支路。 (D)振铃时要求有1秒钟振、4秒钟停的通断比。 以上是CPU中央集中控制处理系统的主要工作过程,要全面具体实现上述工作过程,则要有软件支持,该软件程序流程图见图1—4。 图1-3 键盘功能框图 对图1-3所示的键盘功能作如下介绍: “时间”: 该键可设置系统的延时时间。如久不拔号、久不应答、位间不拔号的延时,缺省值为10秒,可选择的时间值有10秒、30秒、1分钟。按一次该键则显示下一个时间值,三个值循环显示,当按下“确认”键时,就选定当前显示值供系统使用,按“复位”键则清除该次时间的设定。 “会议电话”: 该键为召开电话会议的按键。电话会议设置用户1为主叫方,其他三路为被叫方,只能由主叫方主持召开会议,向其他三路发出呼叫。电路完全接通或者接通两路后,主叫方能和任一被叫方互相通话。除“复位”键外,其他键均推失去功能。会议结束后,可按“复位”键重启系统。 “中继”: 该键为局内交换切向中继交换的功能按键,按下此键,再按“确认”键进行确认,则工作模式由局内交换切换为中继交换,显示器循环显示“d”,此时方可通过中继拨打“长途”电话。按“复位”键重启系统,进入正常局内交换模式。 “确认”: 该键完成对其他功能键的确认,防止误按键,在键盘中除“复位”键外,其他功能键都必须加“确认”键才能完成所定义的功能。 “复位”: 该键为重启系统按键。在任何时候或者系统出现不正常状态时都可按下此键重启系统(有用户通话时,会中断通话),所有设置均为默认值。 图1-5是显示电路工作示意说明图。 主叫号码显示 计时显示 被叫号码显示 图1-5 显示电路 开 始 NO 有用户呼叫吗? 呼叫••••••••••••••••••••••••••••••••••••••••••• YES 去 话 接 续 向主叫送拨号音 NO 第一位号码来了吗? 拨号开始•••••••••••••••••••••••••••••••• YES 停送拨号音,收存号码 内 部 处 理 拨号完毕•••••••••••••••••••••••••••••••• 被叫闲吗? NO YES 来 话 接 续 向主叫送忙音 向被叫送铃流,向主叫送回铃音 被叫应答否? NO 主叫挂机否? 应答•••••••••••••••••••••••••••••••••••• YES 停送铃流,回铃音,接通电路 YES 话终挂机否? 挂机•••••••••••••••••••••••••••••••••••••• YES 拆线(释放复原) 结 束 图1-4 程序工作流程示意图 五、实验内容 1、测量实验系统电路板中的TP91~TP95各测量点电压值,并记录。 2、从总体上初步熟悉两部电话单机用空分交换方式进行通话。 3、初步建立程控交换原理系统及电话通信的概念。 4、观察并记录一个正常呼叫的全过程。 5、观察并记录一个不正常呼叫的状态。 图1-6 呼叫识别电路框图 五、 实验步骤 1、接上交流电源线。 2、将K11~K14,K21~K24,K31~K34,K41~K44接2,3脚;K70~K75接2,3脚;K60~K63接2,3脚。 3、先打开“交流开关”,指示发光二极管亮后,再分别按下直流输出开关J8,J9。此时实验箱上的五组电源已供电,各自发光二极管亮。 4、按 “复位”键进行一次上电复位,此时,CPU已对系统进行初始化处理,数码管循环显示“P” ,即可进行实验。 5、将三用表拔至直流电压档,然后测量TP91,TP92,TP93,TP94,TP95的电压是否正常:TP91为-12V,TP92为-48V,TP93为+5V,TP94为+12V,TP95为-5V。(-48V允许误差±10%,其它为±5%) 6、将四个用户接上电话单机。 7、正常呼叫全过程的观察与记录。(现以用户1为主叫,用户4为被叫进行实验) A、 主叫摘机,听到拨号音,数码管显示主叫电话号码“68” 。 B、 主叫拨首位被叫号码“8”,主叫拨号音停,主叫继续拨完被叫号码“9”。 C、 被叫振铃,主叫听到回铃音。 D、 被叫摘机,被叫振铃停,主叫回铃音停,双方通话。数码管显示主叫号码和被叫号码,并开始通话计时。 E、 挂机,任意一方先挂机(如主叫先挂机),另一方(被叫)听到忙音,计时暂停,双方都挂机后,数码管循环显示“P” 。 8、不正常呼叫的自动处理 A、 主叫摘机后在规定的系统时间内不拨号,主叫听到忙音。(系统时间可以设置,在系统复位后按“时间”可循环显示“10”,“30”,“100”,分别表示10秒,30秒,1分钟,选定一个时间,按“确定”即系统时间被设置,在复位状态时,系统时间默认为10秒。) B、 拨完第一位号码后在规定的系统时间内没有拨第二位号码时,主叫听到忙音。 C、 号码拨错时(如主叫拨“56” ),主叫听到忙音。 D、 被叫振铃后在规定的系统时间内不摘机,被叫振铃音停,主叫听到忙音。 六、 实验注意事项 对实验系统加电一定要严格遵循先打开系统工作电源的“交流开关”,然后再打开直流输出开关J8,J9。实验结束后,先分别关直流输出开关J8,J9。最后再关“交流开关”,以避免实验电路的器件损坏。 七、 实验报告要求 1、画出实验系统电路的方框图,并作简要叙述。 2、对正常呼叫全过程进行记录。 实验二 用户线接口电路及二\四线变换实验 一、实验目的 1、全面了解用户线接口电路功能(BORST)的作用及其实现方法。 2、通过对MH88612C电路的学习与实验,进一步加深对BORST功能的理解。 3、了解二\四线变换电路的工作原理。 二、预习要求 认真预习程控交换原理中有关用户线接口电路等章节。 三、实验仪器仪表 1、主机实验箱 一台 2、电话单机 二台 3、20MHz示波器 一台 4、三用表 一台 四、电路工作过程 在现代电话通信设备与程控交换机中,由于交换网络不能通过铃流、馈电等电流,因而将过去在公用设备(如绳路)实现的一些用户功能放到“用户电路”来完成。 用户电路也可称为用户线接口电路(Subscriber Line Interface Circuit—SLIC)。任何交换机都具有用户线接口电路。 模拟用户线接口电路在实现上的最大压力是应能承受馈电、铃流和外界干扰等高压大电流的冲击,过去都是采用晶体管、变压器(或混合线圈)、继电器等分立元件构成,随着微电子技术的发展,近十年来在国际上陆续开发多种模拟SLIC,它们或是采用半导体集成工艺或是采用薄膜、厚膜混合工艺,并已实用化。在实际中,基于实现和应用上的考虑,通常将BORSCHT功能中过压保护由外接元器件完成,编解码器部分另单成一体,集成为编解码器(CODEC),其余功能由所谓集成模拟SLIC完成。 在布控交换机中,向用户馈电,向用户振铃等功能都是在绳路中实现的,馈电电压一般是-60V,用户的馈电电流一般是20mA~30 mA,铃流是25HZ, 90V左右,而在程控交换机中,由于交换网络处理的是数字信息,无法向用户馈电、振铃等,所以向用户馈电、振铃等任务就由用户线接口电路来承担完成,再加上其它一些要求,程控交换机中的用户线接口电路一般要具有B(馈电)、O(过压保护)、R(振铃)、S(监视)、C(编译码)、H(混合)、T(测试)七项功能。 模拟用户线接口电路的功能可以归纳为BORSCHT七种功能,具体含义是: (1)馈电(B-Battery feeling)向用户话机送直流电流。通常要求馈电电压为—48伏,环路电流不小于18mA。 (2)过压保护(O-Overvoltage protection)防止过压过流冲击和损坏电路、设备。 (3)振铃控制(R-Ringing Control)向用户话机馈送铃流,通常为25HZ/90Vrms正弦波。 (4)监视(S-Supervision)监视用户线的状态,检测话机摘机、挂机与拨号脉冲等信号以送往控制网络和交换网络。 (5)编解码与滤波(C-CODEC/Filter)在数字交换中,它完成模拟话音与数字码间的转换。通常采用PCM编码器(Coder)与解码器(Decoder)来完成,统称为CODEC。相应的防混叠与平滑低通滤波器占有话路(300HZ~3400HZ)带宽,编码速率为64kb/s。 (6)混合(H-Hyhird)完成二线与四线的转换功能,即实现模拟二线双向信号与PCM发送,接收数字四线单向信号之间的连接。过去这种功能由混合线圈实现,现在改为集成电路,因此称为“混合电路”。 (7)测试(T-Test)对用户电路进行测试。 模拟用户线接口功能见图2—1。 铃流发生器 馈电电源 发送码流 过 振 低通 编 a 压 测 铃 馈 混 码 模 拟 保 试 继 电 合 平衡 器 用 (编码信号) 户 护 开 电 电 电 网络 解 线 b 电 关 器 路 路 码 路 低通 器 接收码流 测试 振铃控台 用户线 总线 制信号弹 状态信号 图2-1 模拟用户线接口功能框 (一)用户线接口电路 在本实验系统中,用户线接口电路选用的是MITEL公司的MH88612C。MH88612C是2/4线厚膜混合用户线接口电路。它包含向用户话机恒流馈电、向被叫用户话机馈送铃流、用户摘机后自行截除铃流,摘挂机的检测及音频或脉冲信号的识别,用户线是否有话机的识别,语音信号的2/4线混合转换,外接振铃继电器驱动输出。MH88612C用户电路的双向传输衰耗均为-1dB,供电电源+5V和-5V。其各项性能指标符合邮电部制定的有关标准。 (1)该电路的基本特性 1、向用户馈送铃流 2、向用户恒流馈电 3、过压过流保护 4、被叫用户摘机自截铃 5、摘挂机检测和LED显示 6、音频或脉冲拨号检测 7、振铃继电器驱动输出 8、语音信号的2/4线转换 9、能识别是否有话机 10、无需偶合变压器 11、体积小及低功耗 12、极少量外围器件 13、厚膜混合型工艺 14、封装形式为20引线单列直插 图2-2是它的管脚排列图 (2)MH88612C引出端功能的说明 0脚:IC Internal Connection:空端。 1脚:TF Tip Feed: 连接外接二极管作为保护电路连到-48V和地。。 2脚:IC Internal Connection:空端。 3脚:VR Voice Receive(input): 四线语音信号的接收端。 4脚:VRef Voltage Reference:设置向用户电话线送恒流馈电的参考电压,恒流通过VRef调节;也可接地,一般为21mA环流。 5脚:VEE 负供电电源,通常为-5V DC。 6脚:GNDA 供电电源和馈电电源的地端,模拟接地。 7脚:GS Gain setting(input):低电平时直接接收附加增益为-0.5 dB, 此增益除编解码增益设置之外的,高电平时为0dB。 8脚:VX Voice Transmit(output):四线语音信号的发送端。 9脚:TIP 连接用户电话的“TIP”线。 10脚:RING 连接用户电话的“RING”线。 11脚:RF Ring Feed:外部连接至振铃继电器。 12脚:VDD 正供电电源,通常为+5V DC。 13脚:RC Relay Control(input)振铃继电器控制输入端,高电平有效 14脚:RD 振铃继电器驱动输出端,外接振铃继电器线圈至地端,内部有一线圈感应箝位二极管。 15脚:RV Ring Feed Voltage:用户线铃流源输入端,外部连接至振铃继电器。 16脚:VRLY 振铃继电器正供电电源,能常为+5V DC。 17脚:IC Internal Connection:空端。 18脚:VBat 用户线馈电电压,通常为-48V DC 19脚:CAP 连接外部电容作为振铃滤波控制连电阻到地。 20脚:SHK 摘挂机状态检测及脉冲号码输出端,摘机时输出高电平。 (3)用户线接口电路主要功能 图2-3是MH88612C内部电路方框图,其主要功能说明如下: TF VR TIP RING VX RF RV VRLY RC VRef RD CAP SHK 图2-3 MH88612C内部电路方框图 1、向用户话机供电,MH88612C可对用户话机提供恒流馈电,馈电电流由VBAT以及VDD供给。恒定的电流为25 mA。当环路电阻为2KΩ时,馈电电流为18 mA,具体如下: A、 供电电源VBat采用-48V; B、 在静态情况下(不振铃、不呼叫),-48V电源通过继电器静合接点至话机; C、 在振铃时,-48V电源通过振铃支路经继电器动合接点至话机; D、 用户挂机时,话机叉簧下压馈电回路断开,回路无电流流过; E、 用户摘机后,话机叉簧上升,接通馈电回路(在振铃时接通振铃支路)回路。 2、MH88612C内部具有过压保护的功能,可以抵抗保护TIP- -RING端口间的瞬时高压,如结合外部的热敏与压敏电阻保护电路,则可保护250V左右高压。 3、振铃电路可由外部的振铃继电器和用户电路内部的继电器驱动电路以及铃流电源向用户馈送铃流:当继电器控制端(RC端)输入高电平,继电器驱动输出端(RD端)输出高电平,继电器接通,此时铃流源通过与振铃继电器连接的15端(RV端)经TIP––RING端口向被叫用户馈送铃流。当控制端(RC端)输入低电平或被叫用户摘机都可截除铃流。用户电路内部提供一振铃继电器感应电压抑制箝位二极管。 4、监视用户线的状态变化即检测摘挂机信号,具体如下: A、用户挂机时,用户状态检测输出端输出低电平,以向CPU中央集中控制系统表示用户“闲”; B、用户摘机时,用户状态检测输出端输出高电平,以向CPU中央集中控制系统表示“忙”; 5、在TIP––RING端口间传输的语音信号为对地平衡的双向语音信号,在四线VR端与VX端传输的信号为收发分开的不平衡语音信号。MH88612C可以进行TIP––RING端口与四线VR端和VX端间语音信号的双向传输和2/4线混合转换。 6、MH88612C可以提供用户线短路保护:TIP线与RING线间,TIP线与地间,RING线与地间的长时间的短路对器件都不会损坏。 7、MH88612C提供的双向语音信号的传输衰耗均为-dB。该传输衰耗可以通过MH88612C用户电路的内部调整,也可通过外部电路调整; 8、MH88612C的四线端口可供语音信号编译码器或交换矩阵使用。 由图1-1可知,本实验系统共有四个用户线接口电路,电路的组成与工作过程均一样,因此只对其中的一路进行分析。 图2-4是用户1用户线接口电路的原理图: 图2-4 用户线接口电路电原理图 为了简单和经济起见,反映用户状态的信号一般都是直流信号,当用户摘机时,用户环路闭合,有用户线上有直流电流流过。主叫摘机表示呼叫信号,被叫摘机,则表示应答信号,当用户挂机时,用户环路断开,用户线上的直流电流也断开,因此交换机可以通过检测用户线上直流电流的有无来区分用户状态。 当用户摘机时,发光二极管D10亮表示用户已处于摘机状态,TP13由低电平变成高电平,此状态送到CPU进行检测该路是否摘机,当检测到该路有摘机时,CPU命令拨号音及控制电路送出f=450HZ,U=3V的波形。 此时,在TP12上能检测到如图2—5所示波形 TP12 0 2VP-P t f = 400~450Hz 图2-5 450Hz拨号音波形 当用户听到450HZ拨号音信号时,用户开始拨电话号码,双音多频号码检测电路检测到号码时通知CPU进行处理,CPU命令450HZ拨号音发生器停止送拨号音,用户继续拨完号码,CPU检测主叫所要被叫用户的号码后,立即向被叫用户送振铃信号,提醒被叫用户接听电话,同时向主叫用户送回铃音信号,以表示线路能够接通,当被叫用户摘机时,CPU接通双方线路,通信过程建立。一旦接通链路,CPU即开始计时,当任一方先挂机,CPU检测到后,立即向另一方送忙音,以示催促挂机,至此,主、被叫用户一次通信过程结束。 通过上述简单分析,不难得出各测量点的波形。 TP11:通信时有发送话音波形;拨号时有瞬间DTMF波形;不通信时则此点无波形。 TP12:通信时有接收话音波形:摘机后拨号前有450HZ拨号音信号;不通信时则此点无波形。 TP13:摘挂机状态检测测量点 挂机:TP13=低电平。 摘机:TP13=高电平。 TP14:振铃控制信号输入,高电平有效。即工作时为高电平,常态为低电平。 由于4个用户线接口电路的测量点相同,故对其它三个用户线接口电路的测量点就不一一叙述,波形均相同,即: TP11=TP21=TP31=TP41 TP12=TP22=TP32=TP42 TP13=TP23=TP33=TP43 TP14=TP24=TP34=TP44 (二)二\四线变换电路 在该实验系统中,二\四线变换由用户线接口电路中的语音单元电路实现,图2-6为电路的功能框图,该电路完成二线–––单端之间信号转换,在MH88612C内部电路中已经完成了该变换。 T TR R 图2-6 二/四线变换功能框图 二\四线变换的作用就是把用户线接口电路中的语音模拟信号(TR)通过该电路的转换分成去话(T)与来话(R),对该电话的要求是: 1、将二线电路转换成四线电路; 2、信号由四线收端到四线发端要有尽可能大的衰减,衰减越大越好; 3、信号由二线端到四线发端和由四线收端到二线端的衰减应尽可能小,越小越好; 4、应保持各传输端的阻抗匹配; 以便于PCM编译码电路形成发送与接收的数字信号。 五、实验内容 1、参考有关程控交换原理教材中的用户线接口电路等单节,对照该实验系统中的电路,了解其电路的组成与工作过程。 2、通过主叫、被叫的摘、挂机操作,了解B、R、S等功能的具体作用。 六、实验步骤 1. 接上交流电源线。 2. 将K11~K14,K21~K24,K31~K34,K41~K44接2,3脚;K70~K75接2,3脚;K60~K63接2,3脚。 3. 先打开“交流开关”,指示发光二极管亮后,再分别按下直流输出开关J8,J9,此时实验箱上的五组电源已供电,各自发光二极管亮。 4. 按“复位”键进行一次上电复位,此时,CPU已对系统进行初始化处理,显示电路循环显示“P”,即可进行实验。 5. 用户1,用户3接上电话单机。 6. 用户电话单机的直流供电(B)的观测。(现以用户1为例) 1) 用户1的电话处于挂机状态,用三用表的直流档测量TP1A,TP1B对地的电压,TP1A为-48V,TP1B为0V,它们之间电压差为48V。 2) 用户1的电话处于摘机状态,用三用表的直流档测量TP1A,TP1B对地的电压,TP1A为-10V左右(此时的电压与电话的内阻抗有关,所以每部电话的测量值不一定相同),TP1B为-3.7V左右。 以上给出的电压值只是作为参考。 7. 观察二/四线变换的作用。 1) 用正常的呼叫方式,使用户1、用户3处于通话状态。 2) 当用户1对着电话讲话时(或按电话上的任意键),用示波器观察TP11上的波形,为语音信号(或双音多频信号),不讲话时无信号。 3) 当用户1听到用户3讲话时(或用户3按电话上任意键),用示波器观察TP12上的波形,为语音信号(或双音多频信号),对方不讲话时无信号。 4) 用示波器观察TP1A。不管是用户1讲话还是用户3讲话(或按电话上的任意键)此测试点都有语音波形(或双音多频信号)。 8. 摘、挂机状态检测的观测。 1) 当用户1的电话摘机时,用示波器测量TP13为高电平(4V左右)。 2) 当用户1的电话挂机时,用示波器测量TP13为低电平(0V左右)。 9. 被叫话机振铃(R)的观测。 1) 用户1处于挂机状态,用户3呼叫用户1,即用户3拨打“68”,使用户1振铃。 2)当用户1的电话振铃时,用示波器观察TP14,振铃时TP14为高电平(3V左右);不振铃时TP14为低电平(0V左右)。 七、实验注意事项 当实验过程中出现不正常现象时,请按一下“复位”键,以使系统重新启动。 八、实验报告要求 1、画出本次实验电路方框图,并能说出其工作过程。 2、画出各测量点在各种情况下的波形图。 实验三 程控交换PCM编译码器实验 一、实验目的 1、掌握PCM编译码器在程控交换机中的作用。 2、熟悉单片PCM编译码集成电路TP3067的使用方法。 二、预习要求 1、查阅有关TP3067的使用说明及其应用电路。 2、认真预习程控交换原理中有关这方面的内容。 三、实验仪器仪表 1、主机实验箱 一台 2、电话单机 二台 3、20MHz示波器 一台 4、音频信号源 一台 四、实验电路工作过程 1、PCM编译码器的简单介绍 模拟信号经过编译码器时,在编码电路中,它要经过取样、量化、编码,如图3—1(a)所示。到底在什么时候被取样,在什么时序输出PCM码则由A→D控制来决定。同样PCM码被接收到译码电路后经过译码低通、放大。最后输出模拟信号到话机,把这两部分集成在一个芯片上就是一个单路编译码器,它只能为一个用户服务,即在同一时刻只能为一个用户进行A\D及D\A变换。 编码器把模拟信号变换成数字信号的规律一般有二种,一种是μ律十五折线变换法,它一般用在PCM24路系统中,另一种是A律十三折线非线性变换法,它一般应用于PCM30\32路系统中,这是一种比较常用的变换法,模拟信号经取样后就进行A律十三折变换,最后变成8位PCM码头,在单路编译码器中,经变换后的PCM码是在一个时隙中被发送出去,这个时序号是由A→D控制电路来决定的,而在其它时隙时编码器是没有输出的,即对一个单路编译码器来说,它在一个PCM帧里只在一个由它自己的A→D控制电路决定的时隙里输出8位PCM码,同样在一个PCM帧里,它的译码电路也只能在一个由它自己的D—A控制电路决定的时序里,从外部接收8位PCM码。 其实电路编译码器的发送时序和接收时序还是可由外部电路来控制的,编译码器的发送时序由A→D控制电路来控制,而A→D控制电路还是受外部控制电路的控制,同样在译码电路中D→A控制电路也受外部控制电路的控制,这样,我们只要向A→D控制电路或D→A控制电路发某种命令即可控制单路编译码器的发送时序和接收时序号,从而也可以达到总线交换的目的,但各种单路编译码器对其发送时序和接收时序的控制方式都有所不同。象有些编译器就有二种方式,一种是编程法,即给它内部的控制电路输进一个控制字,令其在某某时隙干什么工作,另一种是直接控制,这时它有两个控制端,我们定义为FSX和FSr,要求FSX和FSr是周期性的,并且它的周期和PCM的周期要相同,都为125μS,这样,每来一个FSX,其中codec就输出一个PCM码,每来一个FSr,其codec就从外部输入一个PCM码。 图3-1(b)是PCM的译码电路方框图,它的工作过程同图3-1(a)的工作过程完全相反,因此这里就不再讨论了。 (a)A→D电路 (b)D→A电路 图3—1 A\D及D\A电路框图 2.在本实验系统的PCM编译码电路中,器件为美国国家半导体公司的TP3067。图3-2是它的管脚排列图。 图3-2 TP3067管脚排列图 其引脚符号说明 符号 功能 VP0+ 接收功率放大器的非倒相输出 GNDA 模拟地,所有信号均以该引脚为参考点 VP0- 接收功率放大器的倒相输出 VPI 接收功率放大器的倒相输入 VFRO 接收滤波器的模拟输出 VCC 正电源引脚,VCC=+5V±5% FSR 接收帧同步脉冲,它启动BCLKR,于是PCM数据移入DR,FSR为8KHz脉冲序列。 DR 接收帧数据输入,PCM数据随着FSR前沿移入DR BCLKR\CLKSESL 在FSR的前沿后把数据移入DR的位时钟,其频率可从64KHz至2.48MHz。另一方面它也可能是一个逻辑输入,以此为在同步模式中的主时钟选择频率1.536MHz\1.544MHz或2.048MHz,BCLKR用在发送和接收两个方向(见表3-1) MCLKR\PDN 接收主时钟,其频率可以为1.536MHz、1.544MHz或2.148MHz,它允许与MCLKX异步,但为了获得最佳性能应当与MCLKX同步,当MCLKR连续联在低电位时,CLKX被选用为所有内部定时,当MCLKR连续工作在高电位时,器件就处于掉电模式。 MCLKX 发送主时钟,其频率可以是1.536MHZ,1.544MHZ或2.048MHz,它允许与MCLKR异步,同步工作能实现最佳性能。 BCLKX 把PCM数据从DX上移出的位时钟,其频率可 64kHz变至2.048MHz,但必须与MCLKX同步。 DX 由FSX启动的三态PCM数据输出 FSX 发送帧同步脉冲输入,它启动BCLKX并使DX上PCM数据移出DX上。 ANLB 模拟环回路控制输入,在正常工作时必须置为逻辑“0”当拉到逻辑“1”时,发送滤波器和发送前置放大器输出的连接线被断开,开而改为和接收功率放大器的VP0+输出连接。 GSX 发送输入放大器的模拟输出。用来在外部调节增益。 VFXI- 发送输入放大器的倒相输入。 VFXI+ 发送输入放大器的非倒相输入。 VBB 负电源引脚,VBB= -5V±5%。 3、PCM编译码电路的工作时钟 由上述电路分析可知,PCM编译码电路所需的工作时钟为2.048MHZ,FSR、FSX帧同步信号为8KHZ窄脉冲。它们的时序关系如图3-3 TP2048 0 TPTS0~ TPTS7 0 图3—3 PCM编译码工作钟各测量点波形图 图3-4 PCM编解码电原理图 五、实验内容 PCM编译码(C)的功能实验 六、实验步骤 1. 接上交流电源线。 2. 将K11~K14,K21~K24,K31~K34,K41~K44接2,3脚;K70~K74接2,3脚,K75接1,2脚;K60~K63接2,3脚;KTS7接2,3脚;K51、K52接2、3脚。 3. 先打开“交流开关”,指示发光二极管亮后,再分别按下直流输出开关J8,J9,此时实验箱上的五组电源已供电,各自发光二极管亮。 4. 按“复位”键进行一次上电复位,此时,CPU已对系统进行初始化处理,显示电路循环显示“P”,即可进行实验。 5. 将一外加音频信号正弦波(VP-P为1.5伏,频率为1KHZ左右)接入至TPIN输入端(在实验箱上面中部)。 6. 用示波器逐点观察TPIN、TPDT、TPDTMF各测量点波形。 7. 慢慢增加外加音频信号的幅值,并用示波器观察TPDTMF的波形的变化。 说明:图3-5是PCM编译码输入输出波形图。有一点需注意,PCM编译码电路中,在没有外加信号输入时,PCM编码电路还是有输出的,此时该芯片对输入随机噪声进行编译码,一旦有信号输入,它会立即对输入信号进行编码。 TPIN 0 t TPTS6 t 125uS TPDT 0 t TPDTMF 0 t 图3-5 PCM编译码电路输入、输出波形图 七、实验注意事项 1、在进行PCM实验时,对TP3067芯片要特别小心谨慎操作,+5V、-5V电源必须同时加入,以保证该芯片有接地回路,否则,该芯片特别容易损坏。 2、观测各测量点波形时,示波器探头不能乱碰到其它测量点。 八、实验报告要求 1、画出各测量点的波形,注明在何种状态下测试到的波形。 2、当外加信号源的幅值到达一定值时,TPDTMF外的波形就会失真,这是为什么,分析其原因。 3、写出对实验电路的改进措施,有何体会? 实验四 多种信号音及铃流信号发生器实验 一、实验目的 1、了解电话通信中常用的几种信号和铃流信号的电路组成与产生方法。 2、熟悉这些音信号在传送过程中的技术要求和实现方法。 二、预习要求 预习有关拨号音,忙音,回铃音,铃流等有关内容。 三、实验仪器仪表 1、主机实验箱 一台 2、电话机 二台 3、20MHz示波器 一台 四、电路工作过程 我们知道,在用户话机与电信局的交换机之间的线路上,要沿两个方向传递语言信息。但是,为了接通一个电话,除了上述情况外,还必须沿两个方向传送所需的控制信号。比如,当用户想要通话时,必须首先向程控机提供一个信号,能让交换机识别并使之准备好有关设备,此外,还要把指明呼叫的目的地的信号(被叫)发往交换机。当用户想要结束通话时,也必须向电信局交换机提供一个信号,以释放通话期间所使用的设备。除了用户要向交换机传送信号之外,还需要传送相反方向的信号,如交换机要向用户传送关于交换机设备状况,以及被叫用户状态的信号。 由此可见,一个完整的电话通信系统,除了交换系统和传输系统外,还应有信号系统。 下面是本实验系统的传送信号流程,见图4-1所示。 用户向电信局交换机发送的信号有用户状态信号和号码信号。交换机向用户发送的信号有各种可闻信号与振铃信号(铃流)两种方式。 a、各种可闻信号:一般采用频率为450Hz的交流信号,例如: 拨号音:(Dial tone)连续发送的信号。 回铃音:(Ringing tone)1秒送,4秒断的5秒断续信号,与振铃一致。 忙音:(busy tone)0.35秒送,0.35秒断的0.7秒断续信号。 b、振铃信号(铃流):一般采用频率为25Hz,幅度为75V±15V的交流电压,以1秒送,4秒断的5秒断续方式发送。 在呼叫建立过程中,交换机应向主叫用户发送各种信号音,以使用户能了解连续进展情况和下一步应采取的操作。 用户线 用户线 主叫用户 被叫用户 摘机 拨号音信号 回铃音信号 振铃信号 话音信号 通信建立 忙音信号 挂机(先挂方) 挂机信号 挂机 (用户线信号) 图4-1 本实验系统传送信号流程图 (一)拨号音及产生电路 主叫用户摘机,CPU检测到该用户有摘机状态后,立即送出的音信号,表示可以拨号,当CPU中央处理单元收到第一个拨号脉冲后,应立即给予切断该信号,拨号音用连续的信号音。在本实验系统中,频率为400Hz~450Hz之间,幅度在1.5V~3.5 V之间,图4-2(a)是该电路的框图,图4-2(b)是该原理图。 (a) 450HZ方框图 (b) 450HZ电原理图 图4-2 450Hz拨号音电路图 (二)回铃音及控制电路 回音信号由CPU中央处理单元控制送出,通知主叫用户正在对被叫用户振铃,回铃音信号所用频率也同拨号音频率,继续周期为1秒通,4秒断,与振铃一致。 各国所用的断续周期不同,如日本为1秒断2秒续,重复周期为3秒。美国和加拿大为2秒续,4秒断,重复周期为6秒。我国采用4秒断,1秒续的5秒周期信号。因此在本实验系统中采用大约4秒断,1秒续的重复周期为5秒信号,见图4-3所示。 (a) 方框图 (b) 电原理图 图4-3 回铃音控制产生电路框图及原理图 (三)忙音及控制电路 忙音表示用户处于忙状态,此时用户应挂机等一会再重新呼叫。 在本实验系统中采用大约0.35秒断,0.35秒续的400Hz~450Hz的信号,见图4-4所示。 (a) 方框图 (b) 电原理图 图4-4 忙音控制产生电路框图及电原理图 (四)铃流信号发生器电路 铃流信号的作用是交换机向被叫用户发出,作为呼入信号,一般采用低频电流,如频率有16.6Hz、25Hz、33.3Hz等几种。 它的断续周期同回铃音信号相同,因此,在本实验系统中采用大约4秒断、1秒通的断续信号。图4-5是它的原理方框图,电原理图4-6所示。 图4-5 25HZ铃流发生器框图 图4-6 25Hz铃流发生器电原理图 上述四种信号在本实验系统中均有具体电路实现,然而在程控交换机中,信号音还不止上述几种,在此作一简单介绍,不作实验要求。 图4-7中各测量点的波形 (1)450Hz拨号音电路,其测量点为TP60; (2)回铃音控制电路,其测量点为TP61; (3)忙音控制电路,其测量点为TP62; (4)25Hz铃流号发生器电路,其测量点为TP63; (5)铃流信号输出的变压电路,其测量点为TP64; TP60 +1.5V O t -1.5V f=400~450Hz TP61 4.2V O t 1s 4s TP62 4.2V 0 t 0.35s 0.35s TP63 4.2V 0 t TP64 +50~60V 0 t -50~60V 图4-7 各测量点的波形图 (六)音信号的数字方式产生 众所周知,在数字程控交换机中直接进行交换的是PCM数字信息,在这样的情况下如何使用户接收到信号音(如拨号音,回铃音,忙音等)是一个重要的问题。因为模拟电路产生的信号音是不能通过PCM交换系统的,这就是要求设计一个数字型信号音发生器,使之能向交换网络输出这样一些PCM数字信息,这些数字信息经过非线性译码后能成为一个我们所需的模拟信号音。 1、传统方式产生数字音信号 电路见图4-8所示,可知,这是一种常见的PCM编码方式,400Hz~450Hz的正弦信号由硬件电路实现,再经过PCM编码器电路后,就可输出音信号的PCM数字码流了,经过数字交换网络后,再进行D/A变换还原成正弦信号送往用户电路即可。 图4—8 传统方式产生音信号电原理图 2、用数字电路产生音信号 图4-9是大约450Hz正弦波信号一个周期取样示意图,图4-10是数字电路产生音信号的原理框图。 0 t1 t2 t3 t4 A B C D 图4-9 450Hz正弦波信号取样示意图 图4—10 数字型信号音产生电路原理框图 由此可见,我们只要对正弦信号在理论上以每隔125μs取样一次,并将取样所得的正弦信号幅度按照A律十三折线非线性编码的规律进行计算,变成二进制编码,然后把这些二进制码存贮在EEPROM中,只要每隔125μs对它读出一次即可得到PCM数字信息码流。(注意:TP3067编码输出时,偶数位取反,例如+2.5V的电压编码输入应为 1111 1111,而TP3067输出为 1010 1010。) 五、实验内容 1、用三用表或示波器测量拨号音,忙音、回铃音及铃流信号的各测量点电压或波形,即测量点TP60、TP61、TP62、TP63、TP64。 六、实验步骤 1. 接上交流电源线。 2. 将K11~K14,K21~K24,K31~K34,K41~K44接2,3脚;K70~K75接2,3脚;K60~K63接2,3脚。 3. 先打开“交流开关”,指示发光二极管亮后,再分别按下直流输出开关J8、J9,此时实验箱上的五组电源已供电,各自发光二极管亮。 4. 按“复位”键进行一次上电复位,此时,CPU已对系统进行初始化处理,显示电路循环显示“P”,即可进行实验。 5. 用示波器测量TP60、TP61、TP62、TP63、TP64各点波形。(观察TP61、TP62时示波器应设置为直流档) TP60 TP61 TP62 TP63 TP64 6. 用户1、用户3接上电话单机,用户1呼叫用户3,在呼叫过程中观察TP12的波形。(示波器设为直流档) 1) 用双踪示波器观察TP12的波形和TP60的波形,用户1摘机后听到拨号音时。即TP12与TP60的波形一样为450HZ的三角波信号。 2) 用户1拨完被叫电话号码“88” 后听到回铃音时,用双踪示波器观察TP12的波形和TP61的波形。即当TP61为高电平时(用户1听到回铃音),TP12有450HZ的三角波信号;当TP61为低电平时,TP12无波形。 3) 用户3振铃时,用双踪示波器观察TP3A的波形和TP64的波形。即当用户3振铃时,TP3A与TP64的波形一样;不振铃时,TP3A无波形。 4) 用户3摘机通话后,用户3先挂机,此时用户1听到忙音,用双踪示波器观察TP12的波形和TP62的波形。即当TP62为高电平时(用户1听到忙音),TP12有450HZ的三角波信号;当TP62为低电平时,TP12无波形。 七、实验注意事项 1、此项实验必须要由两人合作完成。 2、在测量25Hz的铃流信号发生器输出的波形时,一定要注意三用表的量程和示波器的电压量程档,以防止损坏仪器和其它电子器件。 八、实验报告要求 1、认真画出实验过程各测量点波形,并进行分析。 2、画出电路组成框图。 3、在实验过程中遇到的其它情况作出记录,并进行分析。 实验五 双音多频DTMF接收实验 一、实验目的 1、了解电话号码双音多频信号在程控交换系统中的发送和接收方法。 2、熟悉该电路的组成及工作过程。 二、预习要求 1、认真预习有关双音多频等相关内容。 三、实验仪器仪表 1、主机实验箱 一台 2、电话单机 两台 3、20MHz示波器 一台 四、实验电路工作过程 (一)双音多频拨号简单介绍 在电话单机中,有两种拨号方式,即脉冲拨号和双音多频拨号。 双音多频拨号方式中的双音多频是指用两个特定的单音频信号的组合来代表数字或功能,两个单音频的频率不同,所代表的数字和功能也不同,在双音多频电话机中有16个按键,其中有10个数字键0~9,6个功能键*、#、A、B、C、D,按照组合的原理,它必须有8种不同的单音频信号,由于采用的频率有8种,故又称之为多频,又因以8种频率中任意抽出2种进行组合,又称其为8中取2的编码方式。 根据CCITT的建议,国际上采用697Hz、770Hz、852Hz、941Hz、1209Hz、1336Hz、1477Hz和1633Hz,把这8种频率分成两个群,即高频群和低频群,从高频群和低频群中任意各抽出一种频率进行组合,共有16种不同组合,代表16种不同数字或功能,见表5-1。 表5-1 1209 1336 1447 1633 697 1 2 3 A 770 4 5 6 B 852 7 8 9 C 941 * 0 # D 表中*、# 键作特殊功能用(如闭音、重发)等,A、B、C、D留作它用,例如拨数字号码“8”,则发双音多频信号频率为fH=1336Hz、fL=852Hz。 双音多频,简写DTMF(DTMF=Dual Tone Multirequency) fH (C1~C4) (R1~R4) fL 图5-1 一个典型的DTMF发送电路原理框图 DTMF发送器的原理与构成如图5-1所示,它主要包括: (1)晶体振荡器––––外接晶体(通常采用3.579545MHz)与片内电路构成振荡器,经分频产生参考信号。 (2)键控可变时钟产生电路–––––它是一种可控分频比的分频器,通常由n级移位寄存器与键控反馈逻辑单元组成。 (3)正弦波产生电路–––––它由正弦波编码器与D/A变换器构成,通常,可变速时钟信号先经5位移位寄存器,产生一组5位移位代码,再由可编程逻辑阵列(PLA)将其转换成二进制代码,加到D/A变换器形成台阶型正弦波。显然台阶的宽度等于时钟频率的倒数,这样形成的正弦波信号频率必然对应时钟的速率和按键的号码。 (4)混合电路–––––将键盘所对应产生的行、列正弦波信号(即低、高群fL、fH)相加、混合成双音信号输出。 (5)附加功能单元,如有时含有单音抑制,输出控制(禁止)、双键同按无输出等控制电路。 DTMF发送器按输入控制方式可分为键盘行列控制和BCD接口控制两种。它们的控制部分真值表分别示于表5-2、表5-3。 表5-2键盘控制接口功能真值表 输入 行 列 R1 R2 R3 R4 C1 C2 C3 C4 发送 fL(HZ) 697 770 852 941 频率 fH(HZ) 1209 1336 1477 1633 表5-3 BCD码控制接口功能真值表 BCD 码 输 入 发 送 频 率 R1 R2 R3 R4 fL(HZ) fH(HZ) 0 0 0 0 941 1336 0 0 0 1 697 1209 0 0 1 0 697 1336 0 0 1 1 697 1477 0 1 0 0 770 1209 0 1 0 1 770 1336 0 1 1 0 770 1477 0 1 1 1 852 1209 1 0 0 0 852 1336 1 0 0 1 852 1477 (二)双音多频接收电路 图5-2 典型DTMF接收器原理框图 DTMF接收器包括DTMF分组滤波器和DTMF译码器,其基本原理如图5-2所示。DTMF接收器先经高、低群带通滤器进行fL/fH区分,然后过零检测、比较,得到相应于DTMF的两路fL、fH信号输出。该两路信号经译码、锁存、缓冲,恢复成对应于16种DTMF信号音的4比特二进制码(D1~D4)。 图5-3 MT8870芯片及管脚排列图 在本实验系统电路中,DTMF接收器采用的是MT8870芯片。 图5-3是该芯片的管脚排列图。 1、该电路的基本特性 (1)提供DTMF信号分离滤波和译码功能,输出相应16种DTMF频率组合的4位并行二进制码。 (2)可外接3.579545MHz晶体,与内含振荡器产生基准频率信号。 (3)具有抑制拨号音和模拟信号输入增益可调的能力。 (4)二进制码为三态输出。 (5)提供基准电压(VDD\2)输出。 (6)电源 +5V (7)功耗 15mw (8)工艺 CMOS (9)封装 18引线双列直插 2、管脚简要说明 引出端符号说明 IN+,IN- 运放同、反相输入端,模拟信号或DTMF信号从此端输入。 FB 运放输出端,外接反馈电阻可调节输入放大器的增益。 VREF 基准电压输出。 IC 内部连接端,应接地。 OSC1,OSC0 振荡器输入、输出端,两端外接3.579545MHz晶体。 EN 数据输出允许端,若为高电平输入,即允许D01~D04输出, 若为低电平输入,则禁止D01~D04输出。 D01~D04 数据输出,它是相应于16种DTMF信号(高,低单音组合) 的4位二进制并行码,为三态缓冲输出。 CI\GT 控制输入,若此输入电压高于门限值VTSt,则电路将接收 DTMF单音对,并锁存相应码字于输出,若输入电压低于VTSt,则电路不接收新的单音对。 EC0 初始控制输出,若电路检测出一可识别的单音对,则此端即变为高电平,若无输入信号或连续失真,则EC0返回低电平。 CID 延迟控制输出,当一有效单音对被接收,CI超过VTSt,输出锁存器被更新,则CID为高电平,若CI低于VTSt,则CID返至低电平。 VDD 接正电源,通常接+5V。 VSS 接负电源,通常接地。 3、电路的基本工作原理 它完成典型DTMF接收器的主要功能:输入信号的高,低频组带通滤波、限幅、频率检测与确认、译码、锁存与缓冲输出及振荡,监测等,具体说来,就是DTMF信号从芯片的输入端输入,经过输入运放和拨号音抑制滤波器进行滤波后,分两路分别进入高,低频组滤波器以分离检测出高、低频组信号。 如果高,低频组信号同时被检测出来,便在EC0输出高电平作为有效检测DTMF信号的标志;如果DTMF信号消失,则EC0即返至低电平,与此同时,EC0通过外接R向C充电,得到CI,GT。(通常此两端相短接)积分波形,如图5-4所示,若经tGTP延时后,CI,GT。电压高于门限值VTst时,产生内部标志,这样,该电路在出现EC0标志时,将证实后的两单音送往译码器,变成4比特码字并送到输出锁存器,而CI标志出现时,则该码字送到三态输出端D01——D04,另外,CI信号经形成和延时,从CID端输出,提供一选通脉冲,表明该码字已被接收和输出已被更新,如若积分电压降到门限VTst以下,使CID也回到低电平。 图5-4是它的工作时序波形图 图5-4 MT8870的时序图 图5-7 DTMF信号测电路原理框图 其中,双音多频信号测试点为TPDTMF,数据输出允许端EN的测量点为TPSTD,它经反相器反向后得到。数据输出则可以通过发光二极管D103~D100显示出来,它代表的数是8421码。 五、实验内容 1、用示波器观察并测量发送DTMF信号的波形,在用户线接口电路的输入端进行测量,即在用户1用户线接口电路的测量点TP1A与TP1B进行测量。 2、用示波器观察并测量DTMF信号接收的波形TPDTMF,以及在MT8870电路输出端TPSTD。 其中,TPDTMF为双音多频信号的测量点 TPSTD为数据输出允许端EN的反相测量点,识别到双音多频信号时为低,否则就为高。 六、实验步骤 1. 接上交流电源线。 2. 将K11~K14,K21~K24,K31~K34,K41~K44接2,3脚;K71~K75接2,3脚;K61~K63接2,3脚,K70、K60接1、2脚。 3. 先打开“交流开关”,指示发光二极管亮后,再分别按下直流输出开关J8、J9,此时实验箱上的五组电源已供电,各自发光二极管亮。 4. 按“复位”键进行一次上电复位,此时,CPU已对系统进行初始化处理,显示电路循环显示“P”,即可进行实验。 5. 用户1、用户3接上电话单机。 6. 用户1摘机,开始拨打号码,即按电话单机上的任意键,用示波器的直流档对以下测量点进行观察并记录波形: 1) TPDTMF:当有键按下时有双音多频信号,无键按下时无信号。 2) TPSDT:当有键按下时该点是低电平,无键按下时该点为高电平。 3) TP11:当有键按下时有双音多频信号,无键按下时无信号。 7. 按不同的键时,其双音多频信号的波形不一样,要仔细观察。 8. 在按键过程中观察发光二极管D103~D100与所按键值的关系:(显示二极管是在该按键抬起的瞬间发生改变的) D103~D100对应的是8421码,如接下的键值为5时,对应的码字为0101,发光二极管D102,D100发光。在按键的过程中观察所按键值与发光二极管是否满足上述对应关系。 七、注意事项 1、使主机实验箱加电处于正常工作状态,并严格遵循操作规程。 2、在测量观察上述各测量点波形时,两位同学一定要配合好,即一位同学按照正常拨打电话的顺序进行操作,另一位同学要找到相应的测量点和有关电路单元,小心慎重操作,仔细体会实验过程中的各种实验现象。 3、在测量TP1A时,示波器接头的另一接地线接到TP1B上。 八、实验报告要求 1、画出DTMF接收电路的电原理图,并能简要分析工作过程。 2、画出在接收DTMF过程中各有关测量点在有、无信号状态的波形,并能作简要的分析与说明。 实验六 空分交换网络原理 系统实验 一、实验目的 1、掌握程控交换的基本原理与实现方法。 2、通过对MT8816芯片的实验,熟悉空分交换网络的工作过程。 二、预习要求 认真预习《程控交换原理》教材中的相关内容。 三、实验仪器仪表 1、主机实验箱 一台 2、电话单机 二~四台 3、20MHz示波器 一台 四、实验电路工作过程 (一)原理说明 其实,我们在实验一中已经对实验系统中的交换网络有了一些了解,下面我们则比较详细分析它的工作过程。它是由两大部分组成,即话路部分和控制部分,话路部分包括交换网络,用户电路出中继电路,入中继电路,收号器,音信号发生器以及信号设备等;控制部分则是一台电子计算机,它包括中央处理器,存储器和输入、输出设备。 在我们本实验系统中,交换网络的方框图见图6-1所示。 图6-1 实验系统的交换网络结构方框图 (二)电子接线器简介 早先的程控空分交换机的网络,采用的接线器是机械的,也就是说它由机械接点组成的。然后由这些机械接线器组成交换网络。这些机械接线器包括小型纵横接线器、螺簧接线器、剩簧接线器、笛簧接线器……五花八门,品种繁多。由于目前已不采用,所以不在这里介绍。当前的空分交换机采用的是电子接线器。这是从MOS型超大规模接线器。目前,生产电子接线器的电子化成为可能。电子接线器就是MOS型的空分接线器。目前,生产电子接线器的厂家很多,型号也各有不同,如Mitel公司的MT8804,MT8812,MT8816等,MOTOROLA公司的142100,145100等,SGS公司的M089,M099,M093等。这些电子接线器在我国生产和引进的空分用户交换机中均能见到。 下面将重点分析MT8816芯片的工作过程。 (1)MT8816基本特性 由图6-2可见,该芯片是8×16模拟开关阵列,它内含7–––128线地址译码器,控制锁存器和8×16交叉点开关阵列,其电路的基本特性为: 1、提供8×16模拟开关阵列功能 2、导通电阻(VDD=12V) 45Ω 3、导通电阻偏差(VDD=12V) 5Ω 4、模拟信号最大幅度 12VPP 5、开关带宽 45MHZ 6、非线性失真 0.01% 7、电源 4.5~13.2V 8、工艺 CMOS 9、封装 双列直插式 (a) MT8816管脚排列图 VCC VEE VSS COL0 COL7 (b) MT8816功能方框图 图6-2 MT8816功能方框图 (2)MT8816管脚说明 下面将对该管脚功能作一简要说明 COL0~COL7 列输入\输出,开关阵列8路列输入或输出。 ROW0~ROW15 行输入\输出,开关阵列16路行输入或输出。 ACOL0~ACOL2 列地址码输入,对开关阵列进行列寻址。 AROW0~AROW3 行地址码输入,对开关阵行进行行寻址。 ST 选通脉冲输入,高电平有效,使地址码与数据得以控制相应开关的通、断。在ST上升沿前,地址必须进入稳定态,在ST下降沿处,数据也应该是稳定的。 DI 数据输入,若DI为低电平,不管CS处于什么电平,均将全部开关置于截止状态。 RESET 复位信号输入,若为高电平,不管CS处于什么电平,均将全部开关置于截止状态。 CS 片选信号输入,高电平有效。 VDD 正电源,电压范围为4.5~13.2V。 VEE 负电源。 VSS 数字地。 (3)MT8816工作原理 下面我们将对MT8816型电子接线器作一介绍,使大家了解电子接线器的结构原理。其它型号的电子接线器也大同小异。 MT8816是CMOS大规模集成电路芯片。这是一片8×16模拟交换矩阵,如图6-3所示 COL7 COL6 COL5 COL4 COL3 COL2 COL1 COL0 图6-3 MT8816交换矩阵示意图 图中有8条COL线(L0—L7)和16条ROW线(J1~J15),形成一个模拟交换矩阵。它们可以通过任意一个交叉点接通。芯片有保持电路,因此可以保持任一叉接点处于接通状态,直至来复信号为止。CPU可以通过地址线ACOL2 ~ACOL0和数据线AROW3~AROW0进行控制和选择需要接通的交叉点号。ACOL2 ~ACOL0管COL7 ~COL0中的一条线。ACOL7 ~ACOL0编成二进制码,经过译码以后就可以接通交叉点相应的COLi;数据线AROW3~AROW0管ROW15~ROW0中的一条。AROW3~AROW0是不编码的,某一条AROW7线为“1”,控制相应ROWi的以接通有关的交叉点。例如要接通L1和J8之间的交叉点。这时一方面向ACOL0 ~ACOL2。送001,另一方面向AROW3送“1”。当送出地址启动门ST时,就可以将相应交叉点接通了,图中还有一个端子叫“CS”片选端。当CS为“1”时,全部交叉点就打开了。 电子接线器速度快,驱动要求低,并能自己保持。因此使用起来十分方便。 其它型号的芯片其基本原理也大致相同。区别只是容量不一样。 电子接线器的优点是体积小,价格便宜,它的缺点是导通电阻较机械接点大(一般几十欧姆到一百欧姆),并且串音衰耗也较机电的接线器小,因此电子接线器组成的交换网络和由机械接点组成的交换网络也有所区别。 五、实验内容 利用空分自动交换网络进行两部电话单机通话,对工作过程作记录。 六、实验步骤 1. 接上交流电源线。 2. 将K11~K14,K21~K24,K31~K34,K41~K44接2,3脚;K70~K75接2,3脚;K60~K63接2,3脚。 3. 先打开“交流开关”,指示发光二极管亮后,再分别按下直流输出开关J8、J9,此时实验箱上的五组电源已供电,各自发光二极管亮。 4. 按“复位”键进行一次上电复位,此时,CPU已对系统进行初始化处理,显示电路循环显示“P”,即可进行实验。 5. 将四个用户接上电话单机。 6. 首先用户1呼叫用户3,并进行通话,然后用户2呼叫用户4通话。 7. 用双踪示波器观察 1) 当用户1说话时 (或按电话上的任意键),TP11(用户1的去话)、TP32(用户3的来话)有语音波形(或双音多频信号),且波形一致,只是TP11的幅值比TP32的幅值大;不说话时无波形。 2) 当用户3说话时(或按电话上的任意键),TP31(用户3的去话)、TP12(用户1的来话)有语音波形(或双音多频信号),且波形一致,只是TP31的幅值比TP12的幅值大;不说话时无波形。 3) 当用户2说话时(或按电话上的任意键),TP21(用户2的去话)、TP42(用户4的来话)有语音波形(或双音多频信号),且波形一致,只是TP21的幅值比TP42的幅值大;不说话时无波形。 4) 当用户4说话时(或按电话上的任意键),TP41(用户4的去话)、TP22(用户2的来话)有语音波形(或双音多频信号),且波形一致,只是TP41的幅值比TP22的幅值大;不说话时无波形。 七、实验报告要求 1、画出本实验系统自动交换网络的电路框图,并分析工作过程。 实验七 程控交换原理编程调试实验 一、实验目的 1、了解CPU的工作原理及各种控制过程。 2、体会程控交换原理实验系统进行电话通信时的控制过程。 二、预习要求 1、熟练使用8051系列单片机仿真器。 2、预习《MCS-51单片机原理与应用》。 三、实验设备 1、主机实验箱 一台 2、电话单机 四台 3、PC机 一台 4、MCS-51系统单片机仿真器 一套 四、实验编程 本实验分为七个单元实验,每个实验单元完成对一个单元电路的控制或一种系统设置。图7-1为本实验总体框图。 图7-1 实验总体框图 在本次实验中,我们通过实际编程调试,实现程控交换机中CPU对话路设备的控制,进一步加深对程控交换网络工作原理的认识。在实验四中我们已经了解到实验系统中已由硬件产生了各种信号音,在电话拨打和接续过程中,CPU自动将各种信号音按照电话接续规则接入电话机,使我们能自如地拨打电话,各种信号音都是通过可由计算机控制的开关接入电话线路的,CPU根据电话接续规则,打开或关闭各种信号音的接入开关,使我们能从拨打电话的过程中听到各种信号音。 注意,系统定义:用户1系统定义为第1路; 用户2系统定义为第2路; 用户3系统定义为第3路; 用户4系统定义为第4路; 下面我们按图7-1将实验系统通过MCS-51单片机仿真器连接到计算机,打开单片机仿真调试软件,编辑、修改、编译源程序,下载执行CPU控制指令,
27.93MB
单片机应用技术选编(6).(北航出版.何立民)
2016-06-09书名:《单片机应用技术选编(6)》(北京航空航天大学出版社.何立民) PDF格式扫描版,全书分为8章,共603页。1998年8月出版。 内容简介 《单片机应用技术选编》系列图书是汇集了多年间国内主要期刊杂志中有关单片机应用系统的通用技术、实用技术以及相关领域中的新器件、新技术等技术文摘。反映了当时国内单片机应用、开发的先进水平,具有重要参考价值。本书是第6卷,选编了1997年499篇文章。其中全文编辑115篇,其余384篇摘要编辑。 注:原书无书签。为了方便阅读,本人在上传前添加了完整详细的书签。 目 录 第一章 单片机综合应用技术 1.1 存储器技术的发展及趋势 1.2
30.51MB
单片机应用技术选编(1).(北航出版.何立民)
2016-06-08书名:《单片机应用技术选编(1)》(北京航空航天大学出版社.何立民) PDF格式扫描版,全书分为8章,共720页。1993年2月出版。 内容简介 《单片机应用技术选编》系列图书是汇集了多年间国内主要期刊杂志中有关单片机应用系统的通用技术、实用技术以及相关领域中的新器件、新技术等技术文摘。反映了当时国内单片机应用、开发的先进水平,具有重要参考价值。本书是第1卷,选编了1989-1991年间177篇文章。 目 录 第一章 单片机系统综合应用技术 1 1.1 且使用 8098单片机的几点体会 2 1.2 单片机的冷启动与热启动 3 1.3 大容量动态存储器在单片机系统中的应用11 1.4 MCS-51单片机系统中动态 RAM的刷新技巧14 1.5 MCS-51单片机系统中外RAM空间超64KB的扩展方法16 1.6 8031单片机P0口和P2口的应用开发 18 1.7 74LS164在 8031单片机中的两种用法26 1.8 用于 8031单片机的快速I/O接口28 1.9 MCS-51定时器定时常数初值的精确设定法30 1.10 8253的翻转问题及 MC6840的替代方法32 1.11 MCS-51单片机外部中断源的扩展设计35 1.12 MCS-51单片机多外中断扩展方法40 1.13 用优先权编码器74LS348扩展51系列单片机的外中断源42 1.14 用优先权编码器74LS148扩展51系列单片机的外中断源47 1.15 8031单片机与 BG5119A汉字库的接口方法52 1.16 可背插 SRAM的日历时钟 DS1216及其应用55 1.17 实时日历时钟集成电路MSM5832及其时序60 1.18 实时日历时钟集成电路MSM5832的接口技术63 1.19 实时时钟/日历芯片MC146818及其应用67 1.20 与 SICE仿真器通讯的IBM-PC机通讯程序的改进74 1.21 代码形式参数汇编子程序的应用82 1.22 单片机应用系统中的查表程序设计86 1.23 用状态综合法设计键盘监控程序90 1.24 单片机系统程序的加密技术96 1.25 MCS-96单片机程序保密的几种方法100 1.26 GAL输出宏单元原理及使用105 1.27 通用阵列逻辑 GAL应用于步进电机控制实例110 第二章 传感器与前向通道接口技术117 2.1 集成温度传感器 LM134及其应用118 2.2 AD590集成温度一电流传感器原理及应用124 2.3 集成温度传感器 AD590的应用129 2.4 GS-800和 GS-130可燃气体传感器133 2.5 集成化霍尔开关传感器135 2.6 一种新颖实用的氧气/频率转换电路139 2.7 MCS-51单片机与数字式温度传感器的接口设计142 2.8 数字式温度传感器 SWC与 8031的接口及应用145 2.9 低成本高精度压力传感器微机接口设计147 2.10 峰值检测电路原理及应用151 2.11 用 LF398制作的实用峰值和谷值保持电路153 2.12 AD637集成真有效值转换器156 2.13 传感器信号调理模块 ZB31162 2.14 2B31模块在称重智能仪表中的应用166 2.15 传感器信号调理模块 2B30/2B31及其应用169 2.16 高精度光纤位移测量系统的电路设计175 2.17 集成电压一电流转换器 XTR100的工作原理及应用179 2.18 传感器信号变送器 F693及其应用185 2.19 一种用两片 VFC32构成的隔离放大器电路191 2.20 实用线性隔离放大器192 2.21 电桥放大电路中 7650的一些应用问题194 2.22 A/D转换器 ICL7109的应用研究196 2.23 5G14433模数转换器的启停控制200 2.24 ADC1130模数转换器及其使用204 2.25 16位 A/D转换器 ADC1143及其与 80C31单片机的接口208 2.26 串行 I/O D/A A/D转换器与单片机的接口213 2.27 单片机应用系统中的数字化传感器接口技术216 2.28 ADVFC32 A/D转换接口技术220 2.29 V/F和 F/V转换器 TD650原理与应用224 2.30 AD650与 MC-51单片机的接口技术230 2.31 利用VCO电路与单片机接口实现A/D转换235 2.32 LM2907/2917系列F/V变换器在汽车检测中的应用238 2.33 单信号多通道输入法改善 A/D转换器性能241 2.34 用多片 A们转换芯片提高 A/D转换速度245 2.35 实时数控增益调整与浮点 ADC电路249 2.36 电荷耦合器件的单片机驱动253 2.37 电荷耦合器
98.26MB
Oracle 数据库管理艺术:11g新特性(世界级Oracle专家权威力作)--详细书签版
2013-02-06CruiseYoung提供的带有详细书签的电子书籍目录 http://blog.csdn.net/fksec/article/details/7888251 Oracle 数据库管理艺术:11g新特性(世界级Oracle专家权威力作) 基本信息 原书名: Oracle Database 11g: New Features for DBAs and Developers 原出版社: Apress 作者: (美)Sam R. Alapati Charles Kim 译者: 钟鸣 王君 丛书名: 图灵程序设计丛书 出版社:人民邮电出版社 ISBN:9787115191106 上架时间:2008-12-4 出版日期:2009 年1月 开本:16开 页码:488 版次:1-1 内容简介 本书是经典名著《oracle 10g数据库管理艺术》一书的姊妹篇,通过示例全面而又详细地讲述了oracle 11g的新特性,讲述了更改管理、数据库自动化、性能管理、故障诊断、存储管理、安全管理、性能管理、应用开发、数据仓库等各个方面的改进和创新。通过阅读本书,读者将全面了解oracle 11g新特性,从而进行更好的管理或开发。 本书结构清晰,内容全面,示例丰富,适用于所有dba 和开发人员。 作译者 Charles Kim Oracle OCP DBA、Red Hat RHCT和微软MCP,具有17年以上的IT经验,自1991年以来就一直使用Oracle。他曾经担任世界领先的金融信息服务公司Fidelity的首席Oracle数据库工程顾问。目前,他管理DBAExpert.com网站并给Oracle DBA和开发人员提供技术解决方案。此外,他还是Oracle Press的技术编辑。 Sam R. Alapati 世界顶尖的Oracle技术专家,一位经验丰富的数据库管理员,有20多年从业经历。他拥有Oracle OCP DBA证书和HP-UX CSA证书,曾经担任Oracle公司的高级顾问,并在AT&T、雷曼兄弟、NBC等世界顶级公司担任DBA。目前,他管理着世界上最大的Oracle数据库之一——美国童子军全国总部数据库。除本书外,他还是《Oracle 10g数据库管理艺术》(人民邮电出版社2007年出版)的作者,而且是Oracle公司OCP考试官方教材的作者。 目录 封面 -19 封底 489 扉页 -18 版权 -17 版权声明 -16 献词 -15 译者序 -14 致谢 -13 前言 -11 目录 -6 第1章 安装、升级和管理更改 1 1.1 服务器安装中的新特性 1 1.1.1 最佳灵活结构的更改 2 1.1.2 安装选项的更改 3 1.1.3 新的Oracle Database 11g组件 3 1.1.4 角色和权限更改 4 1.2 安装Oracle Database 11g 5 1.3 数据库创建中的新特性 6 1.3.1 新初始化参数 7 1.3.2 DBCA的增强 10 1.3.3 新Oracle后台进程 13 1.3.4 Oracle新提供的PL/SQL程序包 13 1.4 升级到Oracle Database 11g 14 1.4.1 升级与兼容问题 14 1.4.2 Oracle Database 11g的升级路径 15 1.4.3 用DBUA进行升级 20 1.4.4 升级的性能测试 20 1.4.5 升级到11g后的降级 20 1.4.6 滚动升级功能的增强 21 1.4.7 Oracle Clusterware升级 21 1.5 Real Application Testing 28 1.5.1 Database Replay 29 1.5.2 SQL Performance Analyzer 37 1.6 数据库软件补丁 42 1.6.1 Database Control中的补丁新特性 43 1.6.2 应急热补丁(联机数据库补丁) 44 1.6.3 Database Change Management Pack 44 1.6.4 软件和数据库克隆 45 第2章 数据库诊断和故障修复 46 2.1 故障诊断基础设施 47 2.1.1 问题和意外事件 48 2.1.2 Incident Packaging Service 49 2.1.3 ADR的结构和位置 49 2.2 调查和解决问题 50 2.2.1 使用命令行工具adrci 51 2.2.2 Support Workbench 59 2.3 数据库健康检查 64 2.3.1 检查、故障和修复 65 2.3.2 Health Monitor检查的类型 65 2.3.3 手动检查 66 2.4 Data Recovery Advisor 71 2.4.1 通过RMAN管理Data Recovery Advisor 71 2.4.2 SQL Test Case Builder 77 2.5 在处理数据讹误方面的改进 78 第3章 数据库管理 80 3.1 数据库自动化 80 3.1.1 自动内存管理 81 3.1.2 自动数据库维护任务 84 3.2 与闪回有关的新特性 89 3.2.1 Total Recall和闪回数据归档 89 3.2.2 闪回事务处理取消 98 3.3 数据库管理的新特性 100 3.3.1 虚拟列 100 3.3.2 新的数据分区方案 102 3.3.3 允许DDL锁等待DML锁 102 3.3.4 显式锁定表 102 3.3.5 不可见索引 103 3.3.6 只读表 106 3.3.7 临时表的管理 107 3.3.8 从内存中创建初始化参数文件 108 3.3.9 复原点的增强功能 109 3.3.10 数据库驻留连接池 111 3.3.11 比较和会聚数据库对象 114 3.4 SQL*Plus的新特性 117 3.4.1 SQL*Plus错误日志 118 3.4.2 SQL*Plus可执行程序中的默认设置 119 3.4.3 增强对SQL*Plus的BLOB数据类型的支持 119 3.5 联机应用维护 119 3.5.1 支持新的对象 120 3.5.2 增强的联机索引创建和重建 120 3.5.3 增强的默认列值功能 120 3.5.4 联机重组实体化视图 121 3.5.5 使依赖对象的无效性最小化 121 3.6 Oracle增强的表压缩选项 122 3.6.1 新压缩特性的工作原理 122 3.6.2 存储和性能的增益 123 3.6.3 实现OLTP表的压缩 123 3.6.4 压缩非结构数据 123 3.7 企业管理器的新特性 124 3.7.1 Availability标签页 125 3.7.2 Server标签页 125 3.7.3 新的Related Links 126 3.7.4 LogMiner支持 127 3.7.5 数据库诊断和调整包 128 3.8 Oracle Scheduler的新特性 129 3.8.1 轻型作业 129 3.8.2 远程外部作业 130 3.8.3 Data Guard的Scheduler支持 132 第4章 性能管理 134 4.1 SQL和PL/SQL性能增强 135 4.1.1 自动“本机”PL/SQL编译 135 4.1.2 更快的DML触发器 138 4.1.3 自适应游标共享 138 4.2 新的结果高速缓存功能 140 4.2.1 使用服务器结果高速缓存提高性能 140 4.2.2 管理查询结果高速缓存 148 4.2.3 PL/SQL函数结果高速缓存 150 4.2.4 内单元内联 153 4.3 自动SQL调整 153 4.3.1 Oracle Database 11g中SQL调整的自动化 153 4.3.2 SQL Access Advisor增强 156 4.4 优化程序和统计数据收集增强 158 4.4.1 多列统计 158 4.4.2 函数和表达式的表达式统计 161 4.4.3 更改统计首选项 162 4.4.4 保持统计数据挂起与立即公开统计数据 163 4.4.5 SQL Plan Management 166 4.4.6 ADDM增强 171 4.4.7 AWR基线 174 4.4.8 基线模板 175 4.4.9 自适应基线度量阈值 177 4.5 Database Control中与性能有关的更改 177 4.5.1 定制性能页 177 4.5.2 平均活动会话 178 4.5.3 ADDM性能分析 179 第5章 数据库安全 180 5.1 企业数据库安全问题 180 5.1.1 更强的口令散列算法 180 5.1.2 创新的安全性 181 5.1.3 延迟失败登录 183 5.1.4 口令区分大小写 184 5.1.5 基本遵从行业安全建议 184 5.1.6 升级隐含的安全问题 185 5.1.7 口令版本 185 5.1.8 区分大小写的口令文件 185 5.1.9 更改默认用户口令 186 5.1.10 数据库连接和区分大小写 187 5.1.11 口令管理 187 5.2 表空间加密 191 5.2.1 创建Oracle Wallet 192 5.2.2 钱夹需求 193 5.2.3 加密表空间的几点说明 193 5.2.4 加密一个表空间 194 5.3 企业管理器集成 196 5.3.1 用Enterprise Manager Database Control进行透明的数据加密 196 5.3.2 用Database Control进行表空间加密 196 5.3.3 Policy Trend Overview 198 5.3.4 Database Control中的其他安全管理集成 199 5.4 UTL_程序包网络访问管理 199 5.4.1 UTL_*网络程序包的细粒度访问控制 200 5.4.2 Automatic Storage Management的sysasm权限 206 5.4.3 LOB加密增强 207 5.4.4 Data Pump加密 207 5.4.5 RMAN虚拟专用目录 207 5.4.6 RMAN备份粉碎 207 5.4.7 具有LogMiner支持的TDE 207 5.4.8 带Data Guard SQL Apply的TDE 207 5.4.9 Oracle Audit Vault 208 5.4.10 带硬件安全模块集成的TDE 208 5.5 Oracle高级安全特性 209 5.5.1 Kerberos交叉领域支持 209 5.5.2 sysdba强身份验证 209 5.6 Oracle调用接口增强 210 5.6.1 设置坏数据包捕捉的信息级别 210 5.6.2 延迟或删除数据库连接 210 5.6.3 配置服务器连接尝试的最大次数 211 5.6.4 控制数据库版本信息的显示 211 5.6.5 设置未授权访问的标题和审计 212 第6章 备份和恢复 213 6.1 增强块介质恢复 213 6.1.1 使用recover...block命令的先决条件 214 6.1.2 使用recover...block命令 215 6.2 RMAN管理增强 217 6.2.1 用RMAN替换变量编写脚本 217 6.2.2 新RMAN配置参数 219 6.2.3 分段备份大文件 220 6.2.4 创建归档(长期的)备份 222 6.2.5 新的验证命令 225 6.2.6 配置归档重做日志删除策略 228 6.2.7 归档重做日志失败切换 230 6.2.8 备份粉碎 230 6.2.9 优化的重做数据备份 231 6.3 活动(基于网络)的数据库复制 231 6.3.1 先决条件 232 6.3.2 必要的spfile修改 232 6.3.3 执行活动复制 234 6.3.4 支持网络的复制如何工作 238 6.4 恢复目录管理 239 6.4.1 合并恢复目录 239 6.4.2 移动恢复目录到另一个数据库 241 6.4.3 虚拟专用目录 242 6.5 增强的RMAN与Data Guard的集成 246 6.5.1 不用数据库连接配置RMAN 246 6.5.2 复原备份控制文件为备用控制文件 247 6.5.3 重新同步恢复目录 248 6.5.4 备份文件可访问组 248 6.5.5 备用数据库中的块更改跟踪支持 248 第7章 Data Pump 249 7.1 API增强 249 7.2 压缩增强 250 7.3 加密 253 7.3.1 指定加密 254 7.3.2 选择加密方式 254 7.4 重用转储文件 256 7.5 重映射数据 257 7.6 重映射表 259 7.7 分区的导出和导入 259 7.8 忽略错误 262 7.9 基于Data Pump的外部表 262 第8章 Oracle Streams 268 8.1 同步捕捉 268 8.1.1 同步捕捉的限制 269 8.1.2 配置同步捕捉 269 8.1.3 同步捕捉的DBA视图 271 8.2 组合捕捉和应用 272 8.2.1 组合捕捉和应用的必要条件 272 8.2.2 组合捕捉和应用验证 272 8.3 Performance Advisor 273 8.4 Streams拓扑 274 8.5 用于“比较和修复”的DBMS_COMPARISON 276 8.5.1 DBMS_COMPARISON的必要条件 277 8.5.2 支持的数据库对象类型 277 8.5.3 比较 277 8.5.4 比较维护 279 8.5.5 复查以前的比较 279 8.5.6 会聚共享数据库对象(修复) 280 8.6 目的的拆分和合并 281 8.6.1 拆分流 281 8.6.2 合并流 282 8.6.3 合并流作业 282 8.7 可用性改进 282 8.7.1 消息跟踪 283 8.7.2 自动化客户机和阈值的预警 283 8.7.3 确定新支持的表视图 284 8.7.4 确定必需的最小检查点SCN 284 8.7.5 后台进程名更改 284 8.7.6 对存储为CLOB的XMLType值的支持 285 8.7.7 对透明数据加密的支持 285 8.7.8 对Oracle Scheduler的支持 285 第9章 存储管理 286 9.1 自动存储管理 286 9.1.1 对ASM的误解 287 9.1.2 RMAN和ASM 287 9.1.3 sysasm权限和osasm组 287 9.1.4 快速重平衡 290 9.2 ASM升级 290 9.2.1 手动升级 290 9.2.2 用DBUA升级 291 9.2.3 滚动升级 294 9.3 ASM的首选读取 296 9.3.1 首选读取设置 296 9.3.2 监视首选读取 297 9.3.3 ASM限制方式 298 9.3.4 磁盘组属性 302 9.3.5 分配单元尺寸 305 9.3.6 RDBMS和ASM兼容性 306 9.3.7 快速镜像重同步 308 9.4 asmcmd命令 313 9.4.1 ls 313 9.4.2 lsdg 313 9.4.3 lsct 314 9.4.4 lsdsk 314 9.4.5 cp 315 9.5 元数据备份和复原 317 9.5.1 使用md_backup备份磁盘组 318 9.5.2 用md_restore复原磁盘组 318 9.5.3 元数据备份和复原演示 319 9.5.4 其他的md_restore示例 325 9.5.5 用ASMCMD进行坏块恢复 325 9.6 Oracle Direct NFS 325 9.6.1 设置Direct NFS 326 9.6.2 验证Direct NFS 327 9.6.3 禁用Direct NFS 328 9.6.4 网络接口卡绑定 328 9.6.5 Direct NFS性能 328 第10章 Data Guard 329 10.1 活动的物理备用数据库复制 330 10.2 实时查询备用 332 10.2.1 启动实时查询备用 332 10.2.2 确认实时查询备用数据库生效 333 10.2.3 设计实时查询数据库 334 10.3 快照备用 334 10.3.1 转换为快照备用 335 10.3.2 转换回物理备用 337 10.4 使用物理备用滚动升级 338 10.4.1 准备主数据库 338 10.4.2 转换为逻辑备用:保持一致性 338 10.4.3 重做传送的改进 339 10.4.4 块更改跟踪支持 340 10.4.5 RMAN理解Data Guard配置 340 10.4.6 与RMAN集成的改进 340 10.4.7 压缩重做的通信量 341 10.4.8 使用NET_TIMEOUT属性的直方图 341 10.4.9 Maximum Performance方式的快速启动失败切换 342 10.5 逻辑备用:SQL Apply 342 10.5.1 支持透明的数据加密(TDE) 343 10.5.2 动态设置Data Guard SQL Apply参数 344 10.5.3 支持VPD和FGA 345 10.5.4 DBMS_SCHEDULER的支持 345 10.5.5 逻辑备用归档日志存储 346 10.5.6 SQL Apply事件消息 346 10.6 Data Guard Broker 347 10.6.1 Data Guard Broker的命令行界面 347 10.6.2 定制快速启动失败切换事件 349 10.6.3 从应用中启动快速启动失败切换 350 10.6.4 新的Data Guard Manager属性 350 10.6.5 用物理备用检测丢失写条件 351 10.6.6 异构OS的Data Guard配置的支持 352 10.6.7 Oracle Database 11g Data Guard优于存储供应商的解决方案 352 第11章 应用开发 353 11.1 新PL/SQL特性 353 11.1.1 CONTINUE语句 353 11.1.2 无dual的序列 353 11.1.3 本机编译 354 11.1.4 SIMPLE_INTEGER 354 11.1.5 正则表达式增强 356 11.1.6 SQL语句的PL/SQL函数调用中的有名和混合参数 358 11.1.7 子程序内联 358 11.1.8 广义调用 361 11.1.9 跨会话的PL/SQL函数结果高速缓存 364 11.1.10 FORALL中的Bulk In-Bind记录表 368 11.1.11 动态SQL对称和新功能 370 11.2 新的触发器特性 373 11.2.1 触发器次序:FOLLOWS子句 374 11.2.2 创建触发器为ENABLED或DISABLED 374 11.2.3 复合触发器类型 374 11.3 XML DB改进 379 11.3.1 信息库事件 379 11.3.2 支持Content Repository APIfor Java: JSR-17 379 11.3.3 ACL安全 379 11.3.4 新的XMLType 379 11.3.5 XMLIndex 384 11.3.6 Oracle XML DB的本机Web服务 394 11.3.7 XQuery增强 400 11.3.8 XML开发工具包(XDK)的改进 401 11.4 Application Express(APEX)增强 404 11.4.1 APEX配置 404 11.4.2 APEX增强 405 11.5 PHP支持增强 406 11.6 Java增强 406 11.6.1 即时编译程序和本机编译 406 11.6.2 JAR支持 407 11.6.3 对loadjava工具的改进 408 11.6.4 对dropjava工具的改进 408 11.6.5 对ojvmjava工具的改进 409 11.6.6 ojvmtc工具 410 第12章 数据仓库 411 12.1 下一代LOB 411 12.1.1 SecureFiles的必要条件 412 12.1.2 BasicFile和SecureFiles 412 12.1.3 LOB的性能 413 12.1.4 去复制 413 12.1.5 DBMS_LOB.SETOPTIONS 417 12.1.6 加密 417 12.1.7 压缩 418 12.1.8 db_securefile初始化参数 419 12.1.9 将BasicFiles移植到SecureFiles 420 12.1.10 LOB预取 421 12.2 数据仓库的新特性 421 12.2.1 分区变更跟踪 421 12.2.2 实体化视图刷新性能的改进 423 12.2.3 实体化视图的QUERY REWRITE功能的增强 423 12.2.4 pivot操作符 425 12.2.5 unpivot操作符 429 12.3 分区 430 12.3.1 Partition Advisor 431 12.3.2 引用分区 435 12.3.3 间隔分区 437 12.3.4 扩展组合分区 442 12.3.5 基于虚拟列的分区 445 12.3.6 系统分区 448 12.3.7 增强分区修剪功能 450 12.4 Oracle Multimedia 450 12.4.1 增强对DICOM的支持 450 12.4.2 ORDDICOM对象类型 450 12.4.3 图像处理 451 12.4.4 对SecureFiles的支持 451 12.4.5 其他多媒体功能的增强 451 索引 452 译者序 Oracle Database 11g使数据库基础架构更加高效、灵活且易于管理。它在数据库管理方面有许多创新和增强,包括更改管理、故障诊断、性能管理、Data Guard管理、安全管理、存储管理和数据仓库管理等。在开发方面也有较大的创新和增强,包括本机编译PL/SQL代码、PL/SQL内联以及触发器等。除了上述较大较明显的改进外,还有几百个较小的重要改进,它们使数据库更可靠、性能更好、更容易使用和更安全。由于篇幅有限,这里就不展开叙述了,请读者阅读本书,书中自会有精彩的讨论。. 本书的两位作者Sam R. Alapati和Charles Kim都是具有20年左右数据库工作经验的资深专家,目前都在从事Oracle数据库管理方面的工作。他们对Oracle数据库的管理和使用具有丰富的经验。Sam R. Alapati拥有Oracle DBA的OCP证书以及HP-UX系统管理员证书,撰写过多部关于Oracle的著作。Charles Kim是Oracle Press的技术编辑,曾经在相关网站上提出过关于Oracle的高水平论题,发表过高质量的文章。 如前所述,Oracle Database 11g有数百个大大小小的改进和创新,要对它们进行系统的介绍,并使读者容易掌握是一件极为困难的事情。这要求作者首先要对以前的Oracle版本有全面充分的了解,其次要深入研究Oracle Database 11g,知道它有什么样的功能,哪些是以前版本没有的,哪些是以前版本有但进行了改进的。最后,还需要对这些改进和创新进行有机的组织,撰写成文。 为此,Sam R. Alapati设法参与了Oracle Database 11g Beta版扩大测试组的工作,试用了beta版软件,参考了Oracle公司向beta版测试参与者提供的技术研究论文,为本书的撰写做了充分的准备。.. 译者对作者的这种严谨的工作态度表示由衷的敬佩,向他们致以崇高的敬意! 作者的这种严谨的工作态度也给译者带来了很大的压力(也可以说是动力)。为了正确地翻译本书的技术内容,表达作者的意图,译者参考了许多相关的Oracle书籍,专门安装了Oracle Database 11g、Oracle Database 10g和Oracle 9i等软件,建立了工作环境,以便在翻译过程中参考。对于本书的翻译,不敢说是尽善尽美,但至少我们尽力了。当然,由于译者水平受限,翻译时间有限,在翻译中肯定有许多不到之处,敬请读者批评指正。 参加本书翻译的主要成员是钟鸣和王君。全书由刘晓霞同志审校。同时担任部分翻译及校对工作的还有梅刚、郝玉洁、杨桦、杨卫军、孙登峰、陈聪、邵晖、汪海玲、何江华、田晓涛、冯建奎、耿娜、左钦文、谌汉娥、张杰民、朱涛江、施加松、孙勇、陈小雷、刘伟、邵俊峰、梁卫平、赫立亮、苏秀玲、赵彦萍、马永良、张启斌、文卫东、张野、李海俊、汪民红、侯进、范庆英、严雷磊、方遒等。... 译者 2008年6月11日 前言 Oracle Database 11g在更改管理、故障诊断、性能管理、Data Guard管理、存储管理和数据仓库等方面有一些重要的创新。除数据库管理方面的更改之外,还有一些应用开发特性方面的重大改进,包括本机编译PL/SQL代码、PL/SQL内联以及触发器增强等。除了一些较大较明显的更改外,还有几百个较小但重要的更改,它们使数据库更可靠、性能更好、更容易使用和更安全。. 这个前言概述了将在本书中介绍的新版本的重要特性。 更改管理 更改管理是Oracle Database 11g新特性中最好的一个。数据库和服务器升级具有相当大的不确定性。Oracle Database 11g允许在更改之前和之后测试和比较性能,因此能方便地测试升级或其他更改。Oracle称其为Real Application Testing(真正应用测试)特性,它由提供高级更改管理能力的两个重要新特性组成: Database Replay(数据库重放)允许捕捉生产数据库的工作负载并在测试服务器上对其重放,可以在测试服务器上用捕捉到的生产负载真实地测试更改; 另一更改管理工具是SQL Performance Analyzer(SQL性能分析程序),它帮助确定系统更改对SQL语句性能的作用。 数据库自动化增强 Oracle Database 11g提供了一些有用的自动数据库管理特性。其中主要有以下几点。 automatic memory management(自动内存管理)特性允许通过设置一个名为memory_target的初始化参数来自动化Oracle内存的系统全局区(SGA)和程序全局区(PGA)组件。 Automatic SQL Tuning(自动SQL调整)特性在晚间维护时间窗中自动运行SQL Tuning Advisor(SQL调整顾问),甚至自动实现该顾问所做的SQL概要文件建议。 Automatic Database Diagnostic Monitor(ADDM,自动数据库诊断监控器)现在除覆盖单个数据库实例外,还覆盖了Oracle Real Application Clusters(Oracle真正应用集群)。 性能管理 除了每晚自动运行SQL Tuning Advisor以外,还有几项改善数据库性能的创新。下面阐述了与数据库性能相关的重要改进。 Automatic Workload Repository(自动工作负载信息库)基线增强现在除了固定基线外,还允许创建移动时间窗基线和基线模板。 SQL Plan Management(SQL计划管理)允许你自动控制SQL计划演变。 当多列相关时,多列统计数据给优化程序提供了更有用的统计数据。 私有统计数据允许在将优化程序统计数据公布给查询优化程序使用前测试这些数据。 服务器端结果高速缓存允许高速缓存SQL和PL/SQL结果,从而极大地提高了性能。也存在新的客户端结果高速缓存。 SQL Test Case Builder(SQL测试案例生成器)允许方便地创建测试案例,使你能在别的系统上重新生成一个有问题的SQL意外事件。 故障诊断能力增强 . Oracle Database 11g提供了合并故障诊断的能力,使故障诊断和修复比过去方便。下面列出了它所包括的组件。 自动诊断信息库将所有诊断数据合并到数据库外的某个集中位置。 Automatic Health Monitor(自动健康监控器)允许进行主动和被动的数据库健康检查。 Support Workbench(支持工作台)给几个诊断任务提供帮助,包括传送意外事件报告给Oracle Support。 Incident Packaging Service(意外事件打包服务)是把所有诊断数据打包为一个可编辑包以便发送给Oracle Support的一种有效的方法。 Data Guard增强 Oracle在Oracle Database 11g Data Guard技术栈中打包了重要的新特性。最新且最大的Data Guard进步如下: 实时查询备用数据库; 快照备用数据库; 逻辑备用数据库改进; 重做日志压缩; Data Guard Broker(数据保护代理)增强; Recovery Manager(RMAN)与Data Guard的结合;.. 物理备用的滚动升级; 快速启动失败切换改进。 存储管理改进 在Oracle Database 11g中,自动存储管理(ASM)并入了许多改进。有关的ASM新特性包括: 滚动升级; ASM快速磁盘重同步; ASM首选读取故障组; 向后兼容的ASM磁盘组属性; 通过sysasm角色分离DBA和SA角色; check、mount和drop命令的新的可管理性选项; 在磁盘组之间、跨ASM实例以及在ASM和操作系统之间复制文件的copy命令; ASM扩展,如磁盘组元数据的备份、恢复以及块修复等。 Direct NFS对网络附加存储(NAS)上的数据库实现进行了简化,提高了性能。由于简单和低成本,客户喜欢选择块设备上的NFS解决方案,而且Direct NFS使NFS实现更简单和更快。 一般的数据库管理 有很多新的数据库管理特性都很有用,包括: 不可见索引,允许测试新索引而不影响性能,因为你可以在可见和不可见之间切换索引状态; 存在几种分区方案——引用分区、内部分区、系统分区和虚拟列分区; 虚拟列允许使用动态计算表列,这些列利用函数从已有列生成新列; 不可见索引通过让你在需要时使索引对优化程序可用来测试索引的使用; 只读表允许你阻止用户修改关键表的内容; 容易增加有默认值的列说明你可以联机增加列而不影响性能; SecureFiles是一种完全经过了重新设计、用于性能和安全的LOB,它们包括加密、去复制和压缩等功能; Data Pump结合了数据加密、掩码和压缩。 安全性增强 Oracle Database 11g中的安全特性将使得数据库管理员更容易实施安全措施。Oracle采取了比过去更严格的安全措施。主要的安全性增强包括: 表空间加密超越了以前版本中透明的表级加密,增强了数据库的安全性; 区分大小写的口令和更强的口令验证遵从了管理需求; 数据重映射屏蔽了静止数据; 来自数据库的细粒度的网络访问保护了数据库生态系统; 带SALT的SHA-1加密算法替代了口令散列算法; Enterprise Manager Database Console中增加了安全支持; 带硬件安全模块集成的TDE提供了最高级别的TDE安全; OCI安全捕捉坏数据包的信息的级别,n次坏数据包后延迟或删除数据库连接,配置服务器连接尝试的最大次数,启用登录和审计的标题页。 应用改进 对于应用开发人员,Oracle Database 11g提供了以下一些有用的增强。 旋转(pivot)操作通过把行转换为列并在处理过程中聚集数据,为行政管理报表提供交叉表格报表。 逆旋转(unpivot)操作把数据从列转为行。 PL/SQL现在可以不用C编译器,直接建立本机编译的PL/SQL代码。 跨会话PL/SQL函数结果高速缓存允许开发人员请求在SGA中高速缓存函数调用的结果,如果在以后的调用中给此函数传入相同的参数,则从高速缓存中返回结果。 PL/SQL中的内联是一种优化,PL/SQL编译程序用子程序(函数和过程)的代码来替换对子程序的调用代码。 新的SIMPLE_INTEGER数据类型提供了比PLS_INTEGER更快的性能。 触发器现在可以控制触发的次序,可以在ENABLED或DISABLED状态创建,复合触发器在一个DML操作的生命期中维持某种公共的状态。 REGEXP_INSTR()和REGEXP_SUBSTR()的一个新参数允许你选择被求值的正则表达式中的第n个子表达式。 Binary XML在数据库中引入了XML的优点。Binary XML格式通常会减少XML文档的冗长性,从而降低分析的成本。 XML模式进化功能允许对XML模式进行某些种类的更改而不用停机。 XQuery增加了两个新函数:XMLExists和XMLCast。 新XMLIndex可用来索引XML数据的内部结构,改进XML检索的性能。 XDK的新改进为XMLDiff和XMLPatch SQL操作符,它们用来比较和修补XML文档。 分区新特性 Oracle Database 11g中有许多新技术,用于对表数据进行分区以提高公司数据的性能和组织。这些分区技术包括: 引用分区允许具有父子关系的表通过从父表继承分区键进行逻辑等同分区,不需要复制键列; 间隔分区为范围分区自动创建维护分区; 扩展组合分区允许数据沿两维分区; 虚拟列分区允许虚拟列被定义为分区键列。 高可用性增强 有几个关于备份和恢复、闪回技术以及SQL修复和数据恢复的极为有用的创新。现在可以创建虚拟专用目录来控制对中心RMAN恢复目录的访问。 一个名为支持网络的数据库复制(network-aware duplication)的新特性,允许在之前没有备份源数据库的情况下,使用正在运行的数据库的数据文件创建一个数据库副本。 闪回事务处理取消(flashback transaction backout)特性允许一次性撤销整个事务处理及其依赖事务处理。 闪回归档特性允许你跟踪存储在SQL表中的数据(可以根据需要跟踪任意长时间),同时提供自动的历史数据管理。 SQL Repair Advisor(SQL修复顾问)以SQL补丁的形式提供可选择的工作区,以解决失败的SQL语句而不用更改SQL语句本身。 Data Recovery Advisor(数据恢复顾问)通过取得可以实现的修复忠告和建议,允许方便地从数据失败中恢复。 虚拟专用目录通过限制用户只能访问基恢复目录的一个子集,提供更好的安全性。 在闪回日志的帮助下提高块介质恢复性能。 可以合并恢复目录。 备份中可以使用新的section size参数进行数据文件的并行备份。 联机补丁增强使得能容易地在不停机的情况下应用补丁。 高级压缩 下面列出了Oracle Database 11g提供的新的高级压缩功能。 新版本允许压缩从属于正常数据操纵语言(DML)活动的OLTP数据。 在Data Pump操作中不仅可以压缩元数据,还可以压缩导出数据。 可以看到,Oracle Database 11g中有许多令人激动的新特性。那么,还等什么呢?让我们开始这些新特性的深入讨论吧!... 媒体评论 “这是市面上最详细的11g参考书,内容非常丰富,我极力推荐此书。”... ——Amazon.com 书摘 第1章安装、升级和管理更改 1.1服务器安装中的新特性 1.1.1最佳灵活结构的更改 Oracle Database 11g安装过程在指定Oracle基目录、Oracle主目录和闪回恢复区(flash recovery area)的方法上有一些变化。此外,还有一个名为自动诊断信息库(automatic diagnostic repository,ADR)的新基础设施,它为所有数据库诊断信息提供了统一场所。 1.选择Oracle基目录位置 Oracle基目录是安装Oracle软件的顶层目录,这个目录的OFA推荐路径为/mount_poi nt/app/[Oracle软件拥有者]。例如,一般的Oracle基目录路径为/u01/app/oracle,其中oracle为Oracle软件拥有者。建议将Oracle基目录作为一个环境变量,就像在以前的Oracle版本中一样,不过以后的Oracle版本可能会使它成为一个强制性的变量。Oracle Universal Installer现在提供了一个编辑或选择Oracle基目录的列表框。Oracle Universal Installer从你提供的Oracle基目录位置自动导出默认的Oracle主目录位置。Oracle主目录为Oracle基目录的一个子目录,这是你安装自己的所有Oracle软件的位置。如果想指定其他目录作为Oracle主目录,可以编辑Oracle Universal Installer提供的目录位置。Oracle建议你为用户创建的多个Oracle主目录指定相同的Oracle基目录。 2.选择数据文件和闪回恢复区位置 在Oracle Database 11g中,默认情况下所有数据文件都位于Oracle基目录下的一个目录层上。闪回恢复区也在Oracle基目录下的一个目录层上,Oracle建议在与驻留数据文件的磁盘不同的某个磁盘上创建闪回恢复区。而在Oracle Database 10g中,闪回恢复区和数据文件两者都位于Oracle主目录中。在Oracle Database11g数据库中,假如你选择/uol/app/oracle作为Oracle基目录,则数据文件和闪回恢复区的位置应该如下所示: ……
2.57MB
书 名:<< C#程序开发范例宝典>>【中卷】(分三卷上传完本书案例)
2010-04-05内容提要 本书紧密围绕程序开发人员在编程中遇到的实际问题和开发中应该掌握的技术,全面介绍了应用C#进行程序开发的技术和技巧。全书包括窗体与界面设计、控件应用、组件应用、图形技术、多媒体技术、文件系统、操作系统与Windows相关程序、注册表、数据库技术、SQL查询相关技术、LINQ查询技术、报表与打印技术、图 表技术、硬件相关开发技术、网络开发技术、Web编程、加密、安全与软件注册、数据结构与算法、C#高级开发、实用工具、程序打包等共21章,572个实例。 本书附有配套光盘。光盘提供了书中所有实例的源代码,全部源代码都经过精心调试,在Windows XP/Windows 2000/Windows Server 2003等操作系统下测试通过,均能够正常运行。 本书适合程序开发人员,也可供大中专院校师生阅读。 目 录 第1章 窗体与界面设计 1 1.1 菜单应用实例 2 实例001 带历史信息的菜单 2 实例002 菜单动态合并 3 实例003 像开始菜单一样漂亮的菜单 4 实例004 任务栏托盘菜单 4 实例005 可以拉伸的菜单界面 5 实例006 级联菜单 6 1.2 工具栏设计 6 实例007 带背景的工具栏 7 实例008 浮动工具栏 7 实例009 带下拉菜单的工具栏 8 实例010 具有提示功能的工具栏 8 1.3 状态栏设计 9 实例011 在状态栏中显示检查框 9 实例012 带进度条的状态栏 10 实例013 状态栏中加入图标 11 1.4 导航菜单界面 11 实例014 OutLook界面 11 实例015 带导航菜单的主界面 12 实例016 图形化的导航界面 14 1.5 特色程序界面 15 实例017 隐藏式窗体 15 实例018 类似Windows XP的程序界面 18 实例019 软件启动界面 19 实例020 以树形显示的程序界面 20 实例021 动态按钮的窗体界面 21 1.6 特殊形状的窗体 23 实例022 非矩形窗体 23 实例023 建立字体形状窗体 24 实例024 控件随窗体自动调整 25 实例025 带分隔栏的窗体 25 实例026 随机更换主界面背景 26 1.7 多媒体光盘 27 实例027 自动启动的多媒体光盘程序 27 实例028 为触摸屏程序添加虚拟键盘 28 1.8 窗体效果 29 实例029 半透明渐显窗体 29 实例030 窗口颜色的渐变 30 1.9 窗体动画 31 实例031 窗体中的滚动字幕 31 实例032 动画显示窗体 32 实例033 制作闪烁的窗体 33 实例034 实现任务栏通知窗口 34 实例035 动画形式的程序界面 38 1.10 标题栏窗体 39 实例036 使窗体标题栏文字右对齐 39 实例037 没有标题栏但可以改变大小的窗口 39 1.11 设置窗体位置 40 实例038 设置窗体在屏幕中的位置 40 实例039 始终在最上面的窗体 41 实例040 从桌面右下角显示的窗体 41 1.12 设置窗体大小 43 实例041 获取桌面大小 43 实例042 在窗口间移动按钮 44 实例043 如何实现Office助手 45 1.13 窗体控制技术 46 实例044 在关闭窗口前加入确认对话框 46 实例045 通过子窗体刷新父窗体 47 实例046 拖动无边框窗体 51 1.14 其他技术 52 实例047 禁用窗口上的关闭按钮 52 实例048 实现动态系统托盘图标 53 实例049 实现气泡提示窗口 54 第2章 控件应用 56 2.1 TextBox控件应用 57 实例050 只允许输入数字的TextBox控件 57 实例051 在TextBox控件底端显示下划线 59 实例052 屏蔽TextBox控件上的粘贴功能 61 实例053 屏蔽TextBox控件上默认的右键菜单 62 2.2 ComboBox控件应用 63 实例054 美化ComboBox控件下拉列表 63 实例055 用ComboBox控件制作浏览器网址输入框 64 2.3 RichTextBox控件应用 65 实例056 在RichTextBox控件中添加超链接文字 65 实例057 在RichTextBox控件中显示RTF格式的文件 66 实例058 为RichTextBox控件添加自定义滚动条 68 实例059 在RichTextBox控件中实现关键字描红 69 实例060 在RichTextBox控件中实现项目编号功能 71 实例061 设置RichTextBox控件中文本对齐方式 74 2.4 ListBox控件应用 77 实例062 在ListBox控件间交换数据 77 实例063 将数据库数据添加到ListBox控件中 78 实例064 借助绑定控件实现数据选择录入 79 实例065 设置ListBox控件选择项 80 2.5 选择类控件应用 83 实例066 利用选择控件实现权限设置 83 实例067 利用选择控件实现复杂查询 85 2.6 ListView控件应用 87 实例068 ListView控件间的数据移动 87 实例069 将数据库数据添加到ListView控件 90 实例070 在ListView控件中实现修改功能 91 实例071 在ListView控件中对数据排序或统计 92 实例072 在ListView控件中绘制底纹 93 实例073 在列表视图中拖动视图项 94 实例074 使ListView控件中的选择项高亮显示 97 实例075 带复选框的ListView控件 99 2.7 TreeView控件应用 100 实例076 将数据库数据显示到树视图中 100 实例077 用TreeView控件制作导航界面 102 实例078 用TreeView控件遍历磁盘目录 102 实例079 修改TreeView控件中的节点 105 实例080 将XML文件节点绑定到TreeView控件中 106 2.8 DataGridView控件应用 108 实例081 DataGridView控件的分页功能 108 实例082 从DataGridView控件拖放数据至TreeView控件 113 实例083 在DataGridView控件中实现合并单元格 116 实例084 在DataGridView控件中显示图片 118 实例085 为DataGridView控件实现复选功能 120 实例086 禁用DataGridView控件列表头自动排序 122 2.9 其他控件典型应用 123 实例087 TrackBar控件的简单应用 123 实例088 自制平滑进度条控件 125 实例089 MaskedTextBox控件的简单应用 128 实例090 制作日历计划任务 130 实例091 在ProgressBar控件中显示进度百分比 132 实例092 在NumericUpDown控件中显示当前系统日期 133 2.10 控件技术 134 实例093 程序运行时智能增减控件 134 实例094 多控件的焦点循环移动 136 实例095 动态创建控件 138 实例096 在Button按钮上绘图 138 2.11 焦点变换与输入控制 140 实例097 按回车键焦点在控件中移动的录入窗口 140 实例098 程序运行时拖动控件 141 实例099 控件得到焦点时变色 142 实例100 控件的输入限制 143 2.12 特殊控件 144 实例101 为控件制作立体效果 144 实例102 获取控件名称和内容 145 第3章 组件应用 147 3.1 BackgroundWorker组件 148 实例103 BackgroundWorker组件执行异步操作 148 3.2 ErrorProvider组件 150 实例104 使用ErrorProvider组件验证文本框输入 150 3.3 EventLog组件 151 实例105 使用EventLog组件读写Windows系统事件日志 151 实例106 使用EventLog组件保存Windows系统日志 153 实例107 使用EventLog组件向本机现有日志中添加条目 155 3.4 FileSystemWatcher组件 156 实例108 使用FileSystemWatcher组件监视系统日志文件是否被更改 157 3.5 HelpProvider组件 158 实例109 使用HelpProvider组件调用帮助文件 159 3.6 Process组件 159 实例110 使用Process组件访问本地进程 159 3.7 Timer组件 161 实例111 使用Timer组件制作计时器 161 实例112 使用Timer组件显示当前系统时间 165 实例113 使用Timer组件制作左右飘动的窗体 166 实例114 使用Timer组件实现奥运倒计时 167 3.8 ServiceController组件 169 实例115 使用ServiceController组件控制计算机的服务 169 3.9 ImageList组件 171 实例116 使用ImageList组件制作动画图片 171 3.10 DirectoryEntry组件 172 实例117 使用DirectoryEntry组件建立虚拟目录 172 第4章 图形技术 174 4.1 绘制图形 175 实例118 绘制公章 175 实例119 在图片中写入文字 176 实例120 局部图片的复制 178 实例121 波形图的绘制 179 4.2 图形转换 180 实例122 BMP转换成JPG格式 181 实例123 JPG转换成BMP格式 182 实例124 位图转化为WMF格式 183 实例125 ICO文件转化为位图 184 实例126 图片批量转换工具 185 4.3 图像预览 187 实例127 局部图像放大 187 实例128 浏览大图片 188 实例129 剪切图片 189 实例130 图像旋转 192 实例131 鼠标拖曳图像 193 4.4 图形缩放与变换 194 实例132 如何放大和缩小图像 194 实例133 如何旋转JPG图像 195 实例134 如何实现图形翻转 196 4.5 图像效果 196 实例135 百叶窗效果显示图像 197 实例136 推拉效果显示图像 198 实例137 水平交错效果显示图像 199 实例138 垂直交错效果显示图像 200 实例139 图像纹理效果 201 实例140 图像浮雕效果 203 实例141 积木效果 204 实例142 马赛克效果显示图像 205 实例143 雾化效果显示图像 206 实例144 锐化效果显示图像 207 实例145 黑白效果显示图像 208 实例146 光晕效果显示图像 209 4.6 图像字体 210 实例147 倒影效果的文字 210 实例148 投影效果的文字 211 实例149 印版效果的文字 213 实例150 阴影效果的文字 214 实例151 倾斜效果的文字 214 实例152 渐变效果的文字 215 实例153 缩放效果的文字 216 实例154 辉光效果文字 217 实例155 如何在图片中移动文字 220 4.7 图像动画 221 实例156 动画背景窗体 221 实例157 随鼠标移动的图像 223 实例158 十字光标定位 224 实例159 抓取鼠标指针的形状 225 实例160 图像的上下对接显示 226 实例161 任意角度旋转图像 227 实例162 以四周扩散形式显示图像 229 4.8 图像识别 230 实例163 查看图片的像素 230 实例164 设置图像中指定位置的像素值 230 实例165 在图像文件中实现自定义标记 232 实例166 获取指定点的RGB值 234 4.9 图像工具 235 实例167 获取图片类型 235 实例168 简单画图程序 236 实例169 看图工具 239 实例170 文字保存为图片 240 实例171 捕获屏幕 241 4.10 图像应用 243 实例172 随机更换壁纸程序 243 实例173 屏幕保护 244 实例174 模拟石英钟 247 实例175 生肖速查 249 第5章 多媒体技术 251 5.1 CD、VCD播放 252 实例176 播放指定的avi-mid-wav文件 252 实例177 获取多媒体详细信息列表 253 5.2 MP3、WAV播放 254 实例178 带记忆功能的MP3播放器 254 实例179 自动播放的MP3播放器 257 实例180 学校体操定时音乐播放 258 实例181 播放系统自带的事件声音 259 实例182 获取MP3文件的歌词 260 实例183 M3U文件的创建及删除 264 实例184 获取MP3文件的播放时间 267 实例185 异步加载并播放声音文件 269 5.3 动画播放 270 实例186 播放Flash动画 270 实例187 制作AVI播放器 272 实例188 播放GIF动画 273 实例189 利用Image制作小动画 274 5.4 媒体控制 275 实例190 检测是否安装声卡 275 实例191 打开和关闭CDROM 276 实例192 控制PC喇叭发声 277 实例193 获取显示设备的名称及PNPDeviceID 278 实例194 如何收听网络电台 279 实例195 获取显示设备的最大、最小及当前刷新率 281 实例196 隐藏控制面板中的声音设备 281 实例197 获取显示设备的当前显示模式 282 实例198 获取声音设备的名称及PNPDeviceID 283 实例199 语音计算器 284 5.5 多媒体应用 286 实例200 开机祝福程序 286 实例201 制作家庭影集 287 实例202 产品电子报价 288 实例203 产品滚动展示程序 290 实例204 将图片资源添加到EXE里 291 5.6 屏幕保护相关程序 292 实例205 电子相册屏幕保护程序 292 实例206 歌曲播放屏幕保护程序 293 第6章 文件系统 294 6.1 创建、删除文件和文件夹 295 实例207 创建和删除文件夹 295 实例208 建立临时文件 296 实例209 根据日期动态建立文件 296 实例210 清空回收站 298 6.2 查找文件 299 实例211 搜索文件 299 实例212 检查文件是否存在 300 实例213 提取指定文件夹目录 301 6.3 修改文件 302 实例214 更改文件名称 302 实例215 修改文件属性 303 实例216 修改文件及目录的名称 304 6.4 文件目录 305 实例217 获得临时文件目录 305 实例218 获取应用程序所在目录 305 实例219 得到系统当前目录 306 实例220 在程序中改变当前路径 307 6.5 复制文件 307 实例221 使用FileStream复制大文件 308 实例222 复制文件时显示复制进度 310 实例223 批量复制文件 312 6.6 指定类型的文件操作 313 实例224 文本文件的操作 313 实例225 使用ROT13加密解密文件 314 6.7 其他 315 实例226 获取窗口文本 315 实例227 判断文件是否正在被使用 316 实例228 在程序中调用.HLP文件 317 实例229 C#中实现文件拖放 317 实例230 文件比较 318 实例231 获取文件夹中的图标资源 319 实例232 获取文件夹下的所有文件夹及文件的名称 321 第7章 操作系统与Windows相关程序 324 7.1 启动相关 325 实例233 进入Windows系统前发出警告 325 实例234 实现注销、关闭和重启计算机 326 7.2 获得磁盘属性 328 实例235 获得硬盘序列号 328 实例236 获取映射驱动器路径 330 实例237 判断驱动器类型 331 实例238 获取所有逻辑分区 332 7.3 磁盘相关设置 333 实例239 取消磁盘共享 333 实例240 检查驱动器容量 334 实例241 检测磁盘是否准备好 335 实例242 图表显示磁盘容量 335 实例243 格式化磁盘 337 7.4 系统控制 338 实例244 将计算机设置为休眠状态 338 实例245 切换输入法 339 实例246 创建应用程序快捷方式 340 7.5 系统设置 340 实例247 设置桌面背景 341 实例248 设置系统时间 342 实例249 设置屏幕分辨率 343 7.6 系统监控 344 实例250 检测系统启动模式 344 实例251 内存使用状态监控 345 实例252 键盘钩子屏蔽热键 346 实例253 CPU使用率 348 7.7 系统软件信息 350 实例254 获取计算机中已安装的字体 350 实例255 获取计算机的显示设备信息 351 实例256 获取系统启动后经过的时间 351 实例257 系统已经安装的打印机信息 352 7.8 鼠标操作 353 实例258 切换鼠标左右键 353 实例259 限制鼠标活动区域 354 实例260 获取鼠标在任意点的颜色值 355 实例261 设置鼠标样式 357 7.9 程序控制 359 实例262 打开控制面板中的程序 359 实例263 添加程序托盘 360 实例264 不出现在任务栏上的程序 360 实例265 怎样调用外部的EXE文件 361 实例266 关闭外部已开启的程序 362 7.10 程序运行 363 实例267 防止程序多次运行 363 实例268 程序运行时禁止关机 364 实例269 获取任务栏尺寸大小 365 实例270 改变系统提示信息 366 实例271 获取系统环境变量 367 实例272 启动屏幕保护 368 7.11 系统隐藏 369 实例273 隐藏、显示任务栏 369 实例274 隐藏、显示开始按钮 370 实例275 查看当前系统版本 371 实例276 使桌面图标文字透明 372 实例277 检索系统中正在运行的任务 373 实例278 隐藏、显示桌面图标 374 7.12 其他 375 实例279 两种信息发送方式 375 实例280 判断计算机中是否安装了SQL软件 378 第8章 注册表 380 8.1 个性桌面 381 实例281 禁用桌面选项卡 381 实例282 禁用外观选项卡 382 实例283 禁用屏幕保护选项卡 383 实例284 设置任务栏时间样式 383 8.2 系统设置 384 实例285 隐藏桌面快捷方式图标的小箭头 384 实例286 禁用Windows任务管理器 385 实例287 禁用任务栏的右键菜单 386 8.3 IE浏览器设置 387 实例288 修改IE浏览器标题栏内容 387 实例289 获取IE浏览器版本信息 388 实例290 设置IE浏览器的默认主页 388 实例291 禁止修改IE浏览器主页 389 8.4 应用软件设置 390 实例292 建立数据文件与程序的关联 390 实例293 使应用程序开机自动运行 391 第9章 数据库技术 393 9.1 连接Access数据库 394 实例294 连接Access数据库 394 实例295 连接加密的Access数据库 394 实例296 自动识别Access 2000数据库路径 396 实例297 连接网络上共享的Access 2000数据库 397 实例298 将Access数据库导入Excel文件中 398 9.2 连接SQL Server数据库 400 实例299 使用ODBC DSN连接SQL Server数据库 400 实例300 使用ODBC非DSN连接SQL Server数据库 402 实例301 使用OLE DB连接SQL Server数据库 403 实例302 建立SQL Server数据库连接 404 9.3 连接其他数据库 405 实例303 连接Excel文件 405 实例304 连接Oracle数据库 406 9.4 数据库结构的读取与修改 407 实例305 读取SQL Server数据库结构 407 实例306 修改SQL Server数据库结构 409 9.5 数据录入 412 实例307 利用数据绑定控件录入数据 412 实例308 使用ADO.NET对象录入数据 414 实例309 利用SQL语句录入数据 416 实例310 利用存储过程录入数据 417 9.6 图片存取技术 420 实例311 使用存取文件名的方法存取图片 420 实例312 使用ADO.NET对象向SQL Server数据库存入图片 421 9.7 数据修改 423 实例313 利用数据绑定控件修改数据 424 实例314 利用数据对象修改数据 426 实例315 利用SQL语句修改数据 427 实例316 利用存储过程修改数据 429 9.8 数据保存前判断 431 实例317 判断输入数据是否符合要求 431 实例318 判断是否重复输入数据 433 9.9 数据删除 434 实例319 删除表格中指定的记录 434 实例320 利用SQL语句删除数据 435 9.10 数据记录 436 实例321 分页显示信息 436 实例322 移动记录 437 9.11 数据维护 439 实例323 在C#中分离SQL Server数据库 439 实例324 在C#中附加SQL Server数据库 440 实例325 在C#中附加单文件SQL Server数据库 441 9.12 数据备份恢复 442 实例326 备份SQL Server数据库 442 实例327 还原SQL Server数据库 445 9.13 管理系统开发相关 447 实例328 开启SQL Server数据库 447 实例329 断开SQL Server数据库与其他应用程序的连接 449 实例330 带图像列表的系统登录程序 450 实例331 利用SQL语句执行外围命令 451 实例332 系统初始化 452 第10章 SQL查询相关技术 454 10.1 SELECT子句 455 实例333 查询特定列数据 455 实例334 使用列别名 457 实例335 在列上加入计算 458 实例336 使用函数设置条件 459 10.2 查询常量 461 实例337 查询数字 461 实例338 查询字符串 462 实例339 查询日期数据 464 实例340 查询逻辑型数据 465 实例341 查询空(“”或Null)数据 466 10.3 查询变量 467 实例342 利用变量查询字符串数据 467 实例343 利用变量查询数值型数据 468 实例344 利用变量查询日期型数据 469 10.4 模式查询 471 实例345 利用“_”通配符进行查询 471 实例346 利用“%”通配符进行查询 472 实例347 利用“[]”通配符进行查询 473 实例348 利用“[^]”通配符进行查询 474 实例349 复杂的模式查询 475 10.5 TOP和PERCENT限制查询结果 476 实例350 查询前10名数据 476 实例351 取出数据统计结果的后10名数据 478 实例352 查询销售量占前50%的图书信息 479 实例353 查询库存数量占后20%的图书信息 480 10.6 周期、日期查询 481 实例354 查询指定日期的数据 481 实例355 查询指定时间段的数据 482 实例356 按年、月或日查询数据 484 10.7 比较、逻辑、重复查询 486 实例357 利用运算符查询指定条件的数据 486 实例358 NOT与谓词进行组合条件的查询 488 实例359 查询时不显示重复记录 489 实例360 列出数据表中的重复记录和记录条数 491 10.8 在查询中使用OR和AND运算符 492 实例361 利用OR运算符进行查询 492 实例362 利用AND运算符进行查询 493 实例363 同时利用OR、AND运算符进行查询 495 10.9 排序、分组统计 496 实例364 数据分组统计(单列) 497 实例365 在分组查询中使用ALL关键字 498 实例366 在分组查询中使用CUBE运算符 500 实例367 在分组查询中使用ROLLUP运算符 502 实例368 对数据进行降序查询 503 实例369 对数据进行多条件排序 505 实例370 对统计结果进行排序 506 实例371 按仓库分组统计图书库存(多列) 507 实例372 多表分组统计 508 实例373 使用COMPUTE 509 实例374 使用COMPUTE BY 511 10.10 聚合函数 512 实例375 利用聚合函数SUM对销售额进行汇总 512 实例376 利用聚合函数AVG求某班学生的平均年龄 514 实例377 利用聚合函数MIN求销售额、利润最少的商品 515 实例378 利用聚合函数MAX求月销售额完成最多的员工 517 实例379 利用聚合函数COUNT求日销售额大于某值的商品数 518 实例380 利用聚合函数First或Last求数据表中第一条或最后一条记录 519 10.11 多表查询(连接查询) 521 实例381 利用FROM子句进行多表查询 521 实例382 使用表别名 522 实例383 合并多个结果集 523 10.12 嵌套查询 525 实例384 简单嵌套查询 525 实例385 复杂嵌套查询 526 实例386 嵌套查询在查询统计中的应用 528 10.13 子查询 530 实例387 用子查询做派生的表 530 实例388 用子查询作表达式 531 实例389 在Update语句中应用子查询 532 10.14 联合语句Union 533 实例390 使用联合查询 533 实例391 多表联合查询 535 实例392 对联合查询后的结果进行排序 536 10.15 内联接查询 537 实例393 简单内联接查询 538 实例394 复杂内联接查询 539 实例395 使用内联接选择一个表与另一个表中行相关的所有行 540 10.16 外联接查询 541 实例396 左外联接查询 541 实例397 右外联接查询 543 实例398 使用外联接进行多表联合查询 544 10.17 利用IN进行查询 545 实例399 用IN查询表中的记录信息 545 实例400 使用IN引入子查询限定查询范围 546 10.18 交叉表查询 547 实例401 利用Trasform分析数据 547 实例402 利用Trasform动态分析数据 549 实例403 静态交叉表(SQLServer 2000) 551 实例404 动态交叉表(SQLServer 2000) 553 10.19 函数查询 555 实例405 在查询语句中使用格式化函数 555 实例406 在查询语句中使用字符串函数 557 实例407 在查询中使用日期函数 558 10.20 having语句应用 559 实例408 利用having语句过滤分组数据 559 实例409 having语句应用在多表查询中 561 10.21 视图的应用 562 实例410 在C#中应用视图 562 实例411 获取数据库中的全部用户视图 563 实例412 通过视图修改数据 564 10.22 存储过程的应用 565 实例413 C#应用存储过程 565 实例414 应用存储过程添加数据 566 实例415 应用存储过程修改数据 567 实例416 应用存储过程删除数据 568 实例417 C#应用查询存储过程 569 实例418 获取数据库中的全部存储过程 570 实例419 加密存储过程 571 10.23 触发器的应用 572 实例420 Insert触发器的应用 572 实例421 Update触发器在系统日志中的应用 574 实例422 触发器的嵌套使用 575 实例423 获取数据库中的触发器 576 第11章 LINQ查询技术 577 11.1 使用LINQ技术操作SQL数据库 578 实例424 使用LINQ技术查询SQL数据库中的数据 578 实例425 使用LINQ技术向SQL数据库中添加数据 581 实例426 使用LINQ技术在SQL数据库中修改数据 582 实例427 使用LINQ技术在SQL数据库中删除数据 583 实例428 使用LINQ技术查询前5名数据 584 实例429 使用LINQ技术对数据进行排序 585 实例430 使用LINQ技术统计员工的工资总额 587 11.2 LINQ技术其他应用 588 实例431 使用LINQ技术获取文件详细信息 588 实例432 使用LINQ技术对XML文件进行操作 589 第12章 报表与打印技术 594 12.1 Windows打印组件 595 实例433 打印窗体中的数据 595 实例434 图形打印 597 12.2 利用报表生成器设计报表 598 实例435 利用报表专家设计并显示学生基本信息 598 实例436 分组统计报表 601 实例437 在水晶报表中添加图表 602 12.3 水晶报表基本操作 605 实例438 在水晶报表中使用Access数据库 605 实例439 在水晶报表中使用SQL Server数据库 606 实例440 订货总金额超过10万元显示“恭喜获奖”文字 607 实例441 薪资大于或等于1万元使用蓝色字体标记 609 实例442 筛选薪资大于2000元的男员工 610 实例443 按类别分组统计图书库存 611 实例444 按成绩总分降序排序 612 实例445 部门销售量占公司总销售量的业绩百分比 613 12.4 子报表的使用 614 实例446 插入子报表 615 实例447 编辑与重新导入子报表 615 实例448 根据需要显示子报表 617 12.5 调用Office进行打印 618 实例449 利用Word打印员工报表 618 实例450 利用Excel打印学生信息报表 620 第13章 图表技术 622 13.1 简单图表 623 实例451 绘制面形图 623 实例452 绘制椭圆 624 实例453 绘制矩形 625 实例454 绘制曲线 626 实例455 绘制柱形图 627 13.2 柱形图表 628 实例456 将汇总数据利用图表分析 628 实例457 柱形图表分析商品走势 630 实例458 对排序数据进行分析 632 实例459 利用控件实现柱形图分析 633 实例460 在柱形图的指定位置显示说明文字 634 13.3 折线图表 635 实例461 利用图表分析产品销售走势 635 实例462 利用图表分析彩票中奖情况 637 实例463 多曲线数据分析 638 实例464 网站人气指数曲线分析 641 13.4 饼形图表 643 实例465 利用饼形图分析公司男女比率 643 实例466 利用饼形图分析产品市场占有率 644 实例467 利用多饼形图分析企业人力资源情况 645 实例468 制作一个可以旋转的饼形图 647 13.5 图表技术的应用 648 实例469 绘制验证码 649 实例470 在饼形图的外围显示说明文字 650 第14章 硬件相关开发技术 655 14.1 串口控制 656 实例471 通过串口发送数据 656 实例472 通过串口关闭对方计算机 657 14.2 加密狗 659 实例473 密码写入与读出加密狗 659 实例474 使用加密狗进行身份验证 661 14.3 IC卡应用 662 实例475 向IC卡中写入数据 662 实例476 读取IC卡中的数据 665 实例477 利用IC卡制作考勤程序 666 14.4 指纹识别器应用 667 实例478 将指纹数据存入数据库中 667 实例479 使用指纹识别器进行员工考勤 669 14.5 监控 671 实例480 简易视频程序 671 实例481 摄像头监控录像 674 实例482 超市摄像头定时监控系统 675 14.6 语音卡控制 677 实例483 语音卡电话呼叫系统 677 实例484 客户来电查询系统 682 实例485 语音卡实现电话录音 683 14.7 手机程序开发 685 实例486 利用短信猫收发短信息 685 实例487 利用短信远程关闭计算机 688 实例488 短信息采集烟草销售数据 690 实例489 “春晚”节目评比短信息互动平台 692 14.8 其他程序 693 实例490 条形码扫描器销售商品 693 实例491 利用神龙卡制作练歌房程序 694 第15章 网络开发技术 697 15.1 计算机设置 698 实例492 通过计算机名获取IP地址 698 实例493 通过IP地址获取主机名称 699 实例494 修改本机IP地址 700 实例495 得到本机MAC地址 702 实例496 获得系统打开的端口和状态 703 实例497 更改DNS地址 705 15.2 远程控制 706 实例498 远程控制计算机 706 实例499 远程服务控制 708 15.3 网络复制文件 710 实例500 网络中的文件复制 710 15.4 局域网管理 712 实例501 在局域网内发送信息 712 实例502 获取网络中所有工作组名称 714 实例503 列出工作组中所有计算机 715 实例504 获取网络中某台计算机的磁盘信息 716 实例505 映射网络驱动器 718 15.5 网络连接与通信 719 实例506 编程实现Ping操作 719 15.6 网络聊天室 721 实例507 利用C#设计聊天程序 721 实例508 点对点聊天室 723 第16章 Web编程 726 16.1 浏览器应用 727 实例509 制作自己的网络浏览软件 727 实例510 XML数据库文档的浏览 730 16.2 上网控制 732 实例511 定时上Internet 732 实例512 监测当前网络连接状态 734 16.3 邮件管理 734 实例513 收取电子邮件 735 实例514 SMTP协议发送电子邮件 738 16.4 网上信息提取 739 实例515 提取并保存网页源码 739 实例516 提取网页标题 742 第17章 加密、安全与软件注册 744 17.1 数据加密与解密 745 实例517 数据加密技术 745 实例518 文本文件加密与解密 746 实例519 利用图片加密文件 750 17.2 Access数据库安全 753 实例520 如何编程修复Access数据库 753 实例521 访问带验证模式的SQL Server 2000数据库 754 17.3 软件注册与加密 756 实例522 利用INI文件对软件进行注册 756 实例523 利用注册表设计软件注册程序 758 实例524 利用网卡序列号设计软件注册程序 760 实例525 根据CPU序列号、磁盘序列号设计软件注册程序 762 第18章 数据结构与算法 765 18.1 链表的实现 766 实例526 单向链表的实现 766 18.2 双向链表 770 实例527 双向链表 770 18.3 堆栈 775 实例528 堆栈的实现 775 18.4 队列 777 实例529 队列的实现 777 18.5 树的实现 778 实例530 树的实现 778 18.6 排序 782 实例531 冒泡排序 783 实例532 选择排序 783 实例533 插入排序 784 实例534 希尔排序 785 18.7 常见算法的实际应用 786 实例535 判断素数的算法 786 实例536 加密和解密算法 787 实例537 判断身份证是否合法 788 实例538 判断IP地址是否合法的算法 790 实例539 按要求生成指定位数编号 791 实例540 身份证号从15位升到18位算法 791 实例541 百钱百鸡的算法 792 实例542 韩信点兵的算法 793 实例543 实现裴波那契数列求和 794 实例544 求水仙花数的算法 795 实例545 如何将B转换成GB、MB和KB 796 实例546 0~N位数的任意组合 796 实例547 在数组中快速查找近似值 799 第19章 C#高级开发 800 19.1 Windows服务开发 801 实例548 将局域网聊天程序开发成Windows服务 801 19.2 Remoting分布式开发 807 实例549 运用Remoting实现文件传送 807 实例550 大规模数据访问时缓解服务器压力 813 19.3 COM+服务开发 819 实例551 COM+服务实现银行转账系统 819 实例552 COM+服务解决同时访问大量数据并发性 823 第20章 实用工具 827 20.1 数据库工具 828 实例553 自动配置ODBC的程序 828 实例554 制作SQL Server提取器 831 20.2 个人工具 833 实例555 个人通讯录 833 实例556 电子名片盒 835 实例557 个人日记本 836 实例558 个人理财管理 838 20.3 实用工具 840 实例559 电话区号、邮编管理软件 840 实例560 IP地址及手机号码归属地查询 841 实例561 火车时刻查询软件 844 实例562 网站网址导航程序 847 20.4 其他工具 850 实例563 人民币金额转换 850 实例564 列举局域网SQL服务器 852 实例565 整点报时程序 853 实例566 红绿灯程序 854 实例567 万年历 857 实例568 彩票抽奖机 859 实例569 电子相册 860 第21章 程序打包 863 21.1 最简单的程序打包 864 实例570 最简单的程序打包 864 实例571 将特定文件安装到指定文件夹中 866 21.2 打包注册表信息 868 实例572 打包注册表信息 868 技术要点对应实例位置 871 图书目录:
8.33MB
书 名:<< C#程序开发范例宝典>>【下卷】(分三卷上传完本书案例)
2010-04-05内容提要 本书紧密围绕程序开发人员在编程中遇到的实际问题和开发中应该掌握的技术,全面介绍了应用C#进行程序开发的技术和技巧。全书包括窗体与界面设计、控件应用、组件应用、图形技术、多媒体技术、文件系统、操作系统与Windows相关程序、注册表、数据库技术、SQL查询相关技术、LINQ查询技术、报表与打印技术、图 表技术、硬件相关开发技术、网络开发技术、Web编程、加密、安全与软件注册、数据结构与算法、C#高级开发、实用工具、程序打包等共21章,572个实例。 本书附有配套光盘。光盘提供了书中所有实例的源代码,全部源代码都经过精心调试,在Windows XP/Windows 2000/Windows Server 2003等操作系统下测试通过,均能够正常运行。 本书适合程序开发人员,也可供大中专院校师生阅读。 目 录 第1章 窗体与界面设计 1 1.1 菜单应用实例 2 实例001 带历史信息的菜单 2 实例002 菜单动态合并 3 实例003 像开始菜单一样漂亮的菜单 4 实例004 任务栏托盘菜单 4 实例005 可以拉伸的菜单界面 5 实例006 级联菜单 6 1.2 工具栏设计 6 实例007 带背景的工具栏 7 实例008 浮动工具栏 7 实例009 带下拉菜单的工具栏 8 实例010 具有提示功能的工具栏 8 1.3 状态栏设计 9 实例011 在状态栏中显示检查框 9 实例012 带进度条的状态栏 10 实例013 状态栏中加入图标 11 1.4 导航菜单界面 11 实例014 OutLook界面 11 实例015 带导航菜单的主界面 12 实例016 图形化的导航界面 14 1.5 特色程序界面 15 实例017 隐藏式窗体 15 实例018 类似Windows XP的程序界面 18 实例019 软件启动界面 19 实例020 以树形显示的程序界面 20 实例021 动态按钮的窗体界面 21 1.6 特殊形状的窗体 23 实例022 非矩形窗体 23 实例023 建立字体形状窗体 24 实例024 控件随窗体自动调整 25 实例025 带分隔栏的窗体 25 实例026 随机更换主界面背景 26 1.7 多媒体光盘 27 实例027 自动启动的多媒体光盘程序 27 实例028 为触摸屏程序添加虚拟键盘 28 1.8 窗体效果 29 实例029 半透明渐显窗体 29 实例030 窗口颜色的渐变 30 1.9 窗体动画 31 实例031 窗体中的滚动字幕 31 实例032 动画显示窗体 32 实例033 制作闪烁的窗体 33 实例034 实现任务栏通知窗口 34 实例035 动画形式的程序界面 38 1.10 标题栏窗体 39 实例036 使窗体标题栏文字右对齐 39 实例037 没有标题栏但可以改变大小的窗口 39 1.11 设置窗体位置 40 实例038 设置窗体在屏幕中的位置 40 实例039 始终在最上面的窗体 41 实例040 从桌面右下角显示的窗体 41 1.12 设置窗体大小 43 实例041 获取桌面大小 43 实例042 在窗口间移动按钮 44 实例043 如何实现Office助手 45 1.13 窗体控制技术 46 实例044 在关闭窗口前加入确认对话框 46 实例045 通过子窗体刷新父窗体 47 实例046 拖动无边框窗体 51 1.14 其他技术 52 实例047 禁用窗口上的关闭按钮 52 实例048 实现动态系统托盘图标 53 实例049 实现气泡提示窗口 54 第2章 控件应用 56 2.1 TextBox控件应用 57 实例050 只允许输入数字的TextBox控件 57 实例051 在TextBox控件底端显示下划线 59 实例052 屏蔽TextBox控件上的粘贴功能 61 实例053 屏蔽TextBox控件上默认的右键菜单 62 2.2 ComboBox控件应用 63 实例054 美化ComboBox控件下拉列表 63 实例055 用ComboBox控件制作浏览器网址输入框 64 2.3 RichTextBox控件应用 65 实例056 在RichTextBox控件中添加超链接文字 65 实例057 在RichTextBox控件中显示RTF格式的文件 66 实例058 为RichTextBox控件添加自定义滚动条 68 实例059 在RichTextBox控件中实现关键字描红 69 实例060 在RichTextBox控件中实现项目编号功能 71 实例061 设置RichTextBox控件中文本对齐方式 74 2.4 ListBox控件应用 77 实例062 在ListBox控件间交换数据 77 实例063 将数据库数据添加到ListBox控件中 78 实例064 借助绑定控件实现数据选择录入 79 实例065 设置ListBox控件选择项 80 2.5 选择类控件应用 83 实例066 利用选择控件实现权限设置 83 实例067 利用选择控件实现复杂查询 85 2.6 ListView控件应用 87 实例068 ListView控件间的数据移动 87 实例069 将数据库数据添加到ListView控件 90 实例070 在ListView控件中实现修改功能 91 实例071 在ListView控件中对数据排序或统计 92 实例072 在ListView控件中绘制底纹 93 实例073 在列表视图中拖动视图项 94 实例074 使ListView控件中的选择项高亮显示 97 实例075 带复选框的ListView控件 99 2.7 TreeView控件应用 100 实例076 将数据库数据显示到树视图中 100 实例077 用TreeView控件制作导航界面 102 实例078 用TreeView控件遍历磁盘目录 102 实例079 修改TreeView控件中的节点 105 实例080 将XML文件节点绑定到TreeView控件中 106 2.8 DataGridView控件应用 108 实例081 DataGridView控件的分页功能 108 实例082 从DataGridView控件拖放数据至TreeView控件 113 实例083 在DataGridView控件中实现合并单元格 116 实例084 在DataGridView控件中显示图片 118 实例085 为DataGridView控件实现复选功能 120 实例086 禁用DataGridView控件列表头自动排序 122 2.9 其他控件典型应用 123 实例087 TrackBar控件的简单应用 123 实例088 自制平滑进度条控件 125 实例089 MaskedTextBox控件的简单应用 128 实例090 制作日历计划任务 130 实例091 在ProgressBar控件中显示进度百分比 132 实例092 在NumericUpDown控件中显示当前系统日期 133 2.10 控件技术 134 实例093 程序运行时智能增减控件 134 实例094 多控件的焦点循环移动 136 实例095 动态创建控件 138 实例096 在Button按钮上绘图 138 2.11 焦点变换与输入控制 140 实例097 按回车键焦点在控件中移动的录入窗口 140 实例098 程序运行时拖动控件 141 实例099 控件得到焦点时变色 142 实例100 控件的输入限制 143 2.12 特殊控件 144 实例101 为控件制作立体效果 144 实例102 获取控件名称和内容 145 第3章 组件应用 147 3.1 BackgroundWorker组件 148 实例103 BackgroundWorker组件执行异步操作 148 3.2 ErrorProvider组件 150 实例104 使用ErrorProvider组件验证文本框输入 150 3.3 EventLog组件 151 实例105 使用EventLog组件读写Windows系统事件日志 151 实例106 使用EventLog组件保存Windows系统日志 153 实例107 使用EventLog组件向本机现有日志中添加条目 155 3.4 FileSystemWatcher组件 156 实例108 使用FileSystemWatcher组件监视系统日志文件是否被更改 157 3.5 HelpProvider组件 158 实例109 使用HelpProvider组件调用帮助文件 159 3.6 Process组件 159 实例110 使用Process组件访问本地进程 159 3.7 Timer组件 161 实例111 使用Timer组件制作计时器 161 实例112 使用Timer组件显示当前系统时间 165 实例113 使用Timer组件制作左右飘动的窗体 166 实例114 使用Timer组件实现奥运倒计时 167 3.8 ServiceController组件 169 实例115 使用ServiceController组件控制计算机的服务 169 3.9 ImageList组件 171 实例116 使用ImageList组件制作动画图片 171 3.10 DirectoryEntry组件 172 实例117 使用DirectoryEntry组件建立虚拟目录 172 第4章 图形技术 174 4.1 绘制图形 175 实例118 绘制公章 175 实例119 在图片中写入文字 176 实例120 局部图片的复制 178 实例121 波形图的绘制 179 4.2 图形转换 180 实例122 BMP转换成JPG格式 181 实例123 JPG转换成BMP格式 182 实例124 位图转化为WMF格式 183 实例125 ICO文件转化为位图 184 实例126 图片批量转换工具 185 4.3 图像预览 187 实例127 局部图像放大 187 实例128 浏览大图片 188 实例129 剪切图片 189 实例130 图像旋转 192 实例131 鼠标拖曳图像 193 4.4 图形缩放与变换 194 实例132 如何放大和缩小图像 194 实例133 如何旋转JPG图像 195 实例134 如何实现图形翻转 196 4.5 图像效果 196 实例135 百叶窗效果显示图像 197 实例136 推拉效果显示图像 198 实例137 水平交错效果显示图像 199 实例138 垂直交错效果显示图像 200 实例139 图像纹理效果 201 实例140 图像浮雕效果 203 实例141 积木效果 204 实例142 马赛克效果显示图像 205 实例143 雾化效果显示图像 206 实例144 锐化效果显示图像 207 实例145 黑白效果显示图像 208 实例146 光晕效果显示图像 209 4.6 图像字体 210 实例147 倒影效果的文字 210 实例148 投影效果的文字 211 实例149 印版效果的文字 213 实例150 阴影效果的文字 214 实例151 倾斜效果的文字 214 实例152 渐变效果的文字 215 实例153 缩放效果的文字 216 实例154 辉光效果文字 217 实例155 如何在图片中移动文字 220 4.7 图像动画 221 实例156 动画背景窗体 221 实例157 随鼠标移动的图像 223 实例158 十字光标定位 224 实例159 抓取鼠标指针的形状 225 实例160 图像的上下对接显示 226 实例161 任意角度旋转图像 227 实例162 以四周扩散形式显示图像 229 4.8 图像识别 230 实例163 查看图片的像素 230 实例164 设置图像中指定位置的像素值 230 实例165 在图像文件中实现自定义标记 232 实例166 获取指定点的RGB值 234 4.9 图像工具 235 实例167 获取图片类型 235 实例168 简单画图程序 236 实例169 看图工具 239 实例170 文字保存为图片 240 实例171 捕获屏幕 241 4.10 图像应用 243 实例172 随机更换壁纸程序 243 实例173 屏幕保护 244 实例174 模拟石英钟 247 实例175 生肖速查 249 第5章 多媒体技术 251 5.1 CD、VCD播放 252 实例176 播放指定的avi-mid-wav文件 252 实例177 获取多媒体详细信息列表 253 5.2 MP3、WAV播放 254 实例178 带记忆功能的MP3播放器 254 实例179 自动播放的MP3播放器 257 实例180 学校体操定时音乐播放 258 实例181 播放系统自带的事件声音 259 实例182 获取MP3文件的歌词 260 实例183 M3U文件的创建及删除 264 实例184 获取MP3文件的播放时间 267 实例185 异步加载并播放声音文件 269 5.3 动画播放 270 实例186 播放Flash动画 270 实例187 制作AVI播放器 272 实例188 播放GIF动画 273 实例189 利用Image制作小动画 274 5.4 媒体控制 275 实例190 检测是否安装声卡 275 实例191 打开和关闭CDROM 276 实例192 控制PC喇叭发声 277 实例193 获取显示设备的名称及PNPDeviceID 278 实例194 如何收听网络电台 279 实例195 获取显示设备的最大、最小及当前刷新率 281 实例196 隐藏控制面板中的声音设备 281 实例197 获取显示设备的当前显示模式 282 实例198 获取声音设备的名称及PNPDeviceID 283 实例199 语音计算器 284 5.5 多媒体应用 286 实例200 开机祝福程序 286 实例201 制作家庭影集 287 实例202 产品电子报价 288 实例203 产品滚动展示程序 290 实例204 将图片资源添加到EXE里 291 5.6 屏幕保护相关程序 292 实例205 电子相册屏幕保护程序 292 实例206 歌曲播放屏幕保护程序 293 第6章 文件系统 294 6.1 创建、删除文件和文件夹 295 实例207 创建和删除文件夹 295 实例208 建立临时文件 296 实例209 根据日期动态建立文件 296 实例210 清空回收站 298 6.2 查找文件 299 实例211 搜索文件 299 实例212 检查文件是否存在 300 实例213 提取指定文件夹目录 301 6.3 修改文件 302 实例214 更改文件名称 302 实例215 修改文件属性 303 实例216 修改文件及目录的名称 304 6.4 文件目录 305 实例217 获得临时文件目录 305 实例218 获取应用程序所在目录 305 实例219 得到系统当前目录 306 实例220 在程序中改变当前路径 307 6.5 复制文件 307 实例221 使用FileStream复制大文件 308 实例222 复制文件时显示复制进度 310 实例223 批量复制文件 312 6.6 指定类型的文件操作 313 实例224 文本文件的操作 313 实例225 使用ROT13加密解密文件 314 6.7 其他 315 实例226 获取窗口文本 315 实例227 判断文件是否正在被使用 316 实例228 在程序中调用.HLP文件 317 实例229 C#中实现文件拖放 317 实例230 文件比较 318 实例231 获取文件夹中的图标资源 319 实例232 获取文件夹下的所有文件夹及文件的名称 321 第7章 操作系统与Windows相关程序 324 7.1 启动相关 325 实例233 进入Windows系统前发出警告 325 实例234 实现注销、关闭和重启计算机 326 7.2 获得磁盘属性 328 实例235 获得硬盘序列号 328 实例236 获取映射驱动器路径 330 实例237 判断驱动器类型 331 实例238 获取所有逻辑分区 332 7.3 磁盘相关设置 333 实例239 取消磁盘共享 333 实例240 检查驱动器容量 334 实例241 检测磁盘是否准备好 335 实例242 图表显示磁盘容量 335 实例243 格式化磁盘 337 7.4 系统控制 338 实例244 将计算机设置为休眠状态 338 实例245 切换输入法 339 实例246 创建应用程序快捷方式 340 7.5 系统设置 340 实例247 设置桌面背景 341 实例248 设置系统时间 342 实例249 设置屏幕分辨率 343 7.6 系统监控 344 实例250 检测系统启动模式 344 实例251 内存使用状态监控 345 实例252 键盘钩子屏蔽热键 346 实例253 CPU使用率 348 7.7 系统软件信息 350 实例254 获取计算机中已安装的字体 350 实例255 获取计算机的显示设备信息 351 实例256 获取系统启动后经过的时间 351 实例257 系统已经安装的打印机信息 352 7.8 鼠标操作 353 实例258 切换鼠标左右键 353 实例259 限制鼠标活动区域 354 实例260 获取鼠标在任意点的颜色值 355 实例261 设置鼠标样式 357 7.9 程序控制 359 实例262 打开控制面板中的程序 359 实例263 添加程序托盘 360 实例264 不出现在任务栏上的程序 360 实例265 怎样调用外部的EXE文件 361 实例266 关闭外部已开启的程序 362 7.10 程序运行 363 实例267 防止程序多次运行 363 实例268 程序运行时禁止关机 364 实例269 获取任务栏尺寸大小 365 实例270 改变系统提示信息 366 实例271 获取系统环境变量 367 实例272 启动屏幕保护 368 7.11 系统隐藏 369 实例273 隐藏、显示任务栏 369 实例274 隐藏、显示开始按钮 370 实例275 查看当前系统版本 371 实例276 使桌面图标文字透明 372 实例277 检索系统中正在运行的任务 373 实例278 隐藏、显示桌面图标 374 7.12 其他 375 实例279 两种信息发送方式 375 实例280 判断计算机中是否安装了SQL软件 378 第8章 注册表 380 8.1 个性桌面 381 实例281 禁用桌面选项卡 381 实例282 禁用外观选项卡 382 实例283 禁用屏幕保护选项卡 383 实例284 设置任务栏时间样式 383 8.2 系统设置 384 实例285 隐藏桌面快捷方式图标的小箭头 384 实例286 禁用Windows任务管理器 385 实例287 禁用任务栏的右键菜单 386 8.3 IE浏览器设置 387 实例288 修改IE浏览器标题栏内容 387 实例289 获取IE浏览器版本信息 388 实例290 设置IE浏览器的默认主页 388 实例291 禁止修改IE浏览器主页 389 8.4 应用软件设置 390 实例292 建立数据文件与程序的关联 390 实例293 使应用程序开机自动运行 391 第9章 数据库技术 393 9.1 连接Access数据库 394 实例294 连接Access数据库 394 实例295 连接加密的Access数据库 394 实例296 自动识别Access 2000数据库路径 396 实例297 连接网络上共享的Access 2000数据库 397 实例298 将Access数据库导入Excel文件中 398 9.2 连接SQL Server数据库 400 实例299 使用ODBC DSN连接SQL Server数据库 400 实例300 使用ODBC非DSN连接SQL Server数据库 402 实例301 使用OLE DB连接SQL Server数据库 403 实例302 建立SQL Server数据库连接 404 9.3 连接其他数据库 405 实例303 连接Excel文件 405 实例304 连接Oracle数据库 406 9.4 数据库结构的读取与修改 407 实例305 读取SQL Server数据库结构 407 实例306 修改SQL Server数据库结构 409 9.5 数据录入 412 实例307 利用数据绑定控件录入数据 412 实例308 使用ADO.NET对象录入数据 414 实例309 利用SQL语句录入数据 416 实例310 利用存储过程录入数据 417 9.6 图片存取技术 420 实例311 使用存取文件名的方法存取图片 420 实例312 使用ADO.NET对象向SQL Server数据库存入图片 421 9.7 数据修改 423 实例313 利用数据绑定控件修改数据 424 实例314 利用数据对象修改数据 426 实例315 利用SQL语句修改数据 427 实例316 利用存储过程修改数据 429 9.8 数据保存前判断 431 实例317 判断输入数据是否符合要求 431 实例318 判断是否重复输入数据 433 9.9 数据删除 434 实例319 删除表格中指定的记录 434 实例320 利用SQL语句删除数据 435 9.10 数据记录 436 实例321 分页显示信息 436 实例322 移动记录 437 9.11 数据维护 439 实例323 在C#中分离SQL Server数据库 439 实例324 在C#中附加SQL Server数据库 440 实例325 在C#中附加单文件SQL Server数据库 441 9.12 数据备份恢复 442 实例326 备份SQL Server数据库 442 实例327 还原SQL Server数据库 445 9.13 管理系统开发相关 447 实例328 开启SQL Server数据库 447 实例329 断开SQL Server数据库与其他应用程序的连接 449 实例330 带图像列表的系统登录程序 450 实例331 利用SQL语句执行外围命令 451 实例332 系统初始化 452 第10章 SQL查询相关技术 454 10.1 SELECT子句 455 实例333 查询特定列数据 455 实例334 使用列别名 457 实例335 在列上加入计算 458 实例336 使用函数设置条件 459 10.2 查询常量 461 实例337 查询数字 461 实例338 查询字符串 462 实例339 查询日期数据 464 实例340 查询逻辑型数据 465 实例341 查询空(“”或Null)数据 466 10.3 查询变量 467 实例342 利用变量查询字符串数据 467 实例343 利用变量查询数值型数据 468 实例344 利用变量查询日期型数据 469 10.4 模式查询 471 实例345 利用“_”通配符进行查询 471 实例346 利用“%”通配符进行查询 472 实例347 利用“[]”通配符进行查询 473 实例348 利用“[^]”通配符进行查询 474 实例349 复杂的模式查询 475 10.5 TOP和PERCENT限制查询结果 476 实例350 查询前10名数据 476 实例351 取出数据统计结果的后10名数据 478 实例352 查询销售量占前50%的图书信息 479 实例353 查询库存数量占后20%的图书信息 480 10.6 周期、日期查询 481 实例354 查询指定日期的数据 481 实例355 查询指定时间段的数据 482 实例356 按年、月或日查询数据 484 10.7 比较、逻辑、重复查询 486 实例357 利用运算符查询指定条件的数据 486 实例358 NOT与谓词进行组合条件的查询 488 实例359 查询时不显示重复记录 489 实例360 列出数据表中的重复记录和记录条数 491 10.8 在查询中使用OR和AND运算符 492 实例361 利用OR运算符进行查询 492 实例362 利用AND运算符进行查询 493 实例363 同时利用OR、AND运算符进行查询 495 10.9 排序、分组统计 496 实例364 数据分组统计(单列) 497 实例365 在分组查询中使用ALL关键字 498 实例366 在分组查询中使用CUBE运算符 500 实例367 在分组查询中使用ROLLUP运算符 502 实例368 对数据进行降序查询 503 实例369 对数据进行多条件排序 505 实例370 对统计结果进行排序 506 实例371 按仓库分组统计图书库存(多列) 507 实例372 多表分组统计 508 实例373 使用COMPUTE 509 实例374 使用COMPUTE BY 511 10.10 聚合函数 512 实例375 利用聚合函数SUM对销售额进行汇总 512 实例376 利用聚合函数AVG求某班学生的平均年龄 514 实例377 利用聚合函数MIN求销售额、利润最少的商品 515 实例378 利用聚合函数MAX求月销售额完成最多的员工 517 实例379 利用聚合函数COUNT求日销售额大于某值的商品数 518 实例380 利用聚合函数First或Last求数据表中第一条或最后一条记录 519 10.11 多表查询(连接查询) 521 实例381 利用FROM子句进行多表查询 521 实例382 使用表别名 522 实例383 合并多个结果集 523 10.12 嵌套查询 525 实例384 简单嵌套查询 525 实例385 复杂嵌套查询 526 实例386 嵌套查询在查询统计中的应用 528 10.13 子查询 530 实例387 用子查询做派生的表 530 实例388 用子查询作表达式 531 实例389 在Update语句中应用子查询 532 10.14 联合语句Union 533 实例390 使用联合查询 533 实例391 多表联合查询 535 实例392 对联合查询后的结果进行排序 536 10.15 内联接查询 537 实例393 简单内联接查询 538 实例394 复杂内联接查询 539 实例395 使用内联接选择一个表与另一个表中行相关的所有行 540 10.16 外联接查询 541 实例396 左外联接查询 541 实例397 右外联接查询 543 实例398 使用外联接进行多表联合查询 544 10.17 利用IN进行查询 545 实例399 用IN查询表中的记录信息 545 实例400 使用IN引入子查询限定查询范围 546 10.18 交叉表查询 547 实例401 利用Trasform分析数据 547 实例402 利用Trasform动态分析数据 549 实例403 静态交叉表(SQLServer 2000) 551 实例404 动态交叉表(SQLServer 2000) 553 10.19 函数查询 555 实例405 在查询语句中使用格式化函数 555 实例406 在查询语句中使用字符串函数 557 实例407 在查询中使用日期函数 558 10.20 having语句应用 559 实例408 利用having语句过滤分组数据 559 实例409 having语句应用在多表查询中 561 10.21 视图的应用 562 实例410 在C#中应用视图 562 实例411 获取数据库中的全部用户视图 563 实例412 通过视图修改数据 564 10.22 存储过程的应用 565 实例413 C#应用存储过程 565 实例414 应用存储过程添加数据 566 实例415 应用存储过程修改数据 567 实例416 应用存储过程删除数据 568 实例417 C#应用查询存储过程 569 实例418 获取数据库中的全部存储过程 570 实例419 加密存储过程 571 10.23 触发器的应用 572 实例420 Insert触发器的应用 572 实例421 Update触发器在系统日志中的应用 574 实例422 触发器的嵌套使用 575 实例423 获取数据库中的触发器 576 第11章 LINQ查询技术 577 11.1 使用LINQ技术操作SQL数据库 578 实例424 使用LINQ技术查询SQL数据库中的数据 578 实例425 使用LINQ技术向SQL数据库中添加数据 581 实例426 使用LINQ技术在SQL数据库中修改数据 582 实例427 使用LINQ技术在SQL数据库中删除数据 583 实例428 使用LINQ技术查询前5名数据 584 实例429 使用LINQ技术对数据进行排序 585 实例430 使用LINQ技术统计员工的工资总额 587 11.2 LINQ技术其他应用 588 实例431 使用LINQ技术获取文件详细信息 588 实例432 使用LINQ技术对XML文件进行操作 589 第12章 报表与打印技术 594 12.1 Windows打印组件 595 实例433 打印窗体中的数据 595 实例434 图形打印 597 12.2 利用报表生成器设计报表 598 实例435 利用报表专家设计并显示学生基本信息 598 实例436 分组统计报表 601 实例437 在水晶报表中添加图表 602 12.3 水晶报表基本操作 605 实例438 在水晶报表中使用Access数据库 605 实例439 在水晶报表中使用SQL Server数据库 606 实例440 订货总金额超过10万元显示“恭喜获奖”文字 607 实例441 薪资大于或等于1万元使用蓝色字体标记 609 实例442 筛选薪资大于2000元的男员工 610 实例443 按类别分组统计图书库存 611 实例444 按成绩总分降序排序 612 实例445 部门销售量占公司总销售量的业绩百分比 613 12.4 子报表的使用 614 实例446 插入子报表 615 实例447 编辑与重新导入子报表 615 实例448 根据需要显示子报表 617 12.5 调用Office进行打印 618 实例449 利用Word打印员工报表 618 实例450 利用Excel打印学生信息报表 620 第13章 图表技术 622 13.1 简单图表 623 实例451 绘制面形图 623 实例452 绘制椭圆 624 实例453 绘制矩形 625 实例454 绘制曲线 626 实例455 绘制柱形图 627 13.2 柱形图表 628 实例456 将汇总数据利用图表分析 628 实例457 柱形图表分析商品走势 630 实例458 对排序数据进行分析 632 实例459 利用控件实现柱形图分析 633 实例460 在柱形图的指定位置显示说明文字 634 13.3 折线图表 635 实例461 利用图表分析产品销售走势 635 实例462 利用图表分析彩票中奖情况 637 实例463 多曲线数据分析 638 实例464 网站人气指数曲线分析 641 13.4 饼形图表 643 实例465 利用饼形图分析公司男女比率 643 实例466 利用饼形图分析产品市场占有率 644 实例467 利用多饼形图分析企业人力资源情况 645 实例468 制作一个可以旋转的饼形图 647 13.5 图表技术的应用 648 实例469 绘制验证码 649 实例470 在饼形图的外围显示说明文字 650 第14章 硬件相关开发技术 655 14.1 串口控制 656 实例471 通过串口发送数据 656 实例472 通过串口关闭对方计算机 657 14.2 加密狗 659 实例473 密码写入与读出加密狗 659 实例474 使用加密狗进行身份验证 661 14.3 IC卡应用 662 实例475 向IC卡中写入数据 662 实例476 读取IC卡中的数据 665 实例477 利用IC卡制作考勤程序 666 14.4 指纹识别器应用 667 实例478 将指纹数据存入数据库中 667 实例479 使用指纹识别器进行员工考勤 669 14.5 监控 671 实例480 简易视频程序 671 实例481 摄像头监控录像 674 实例482 超市摄像头定时监控系统 675 14.6 语音卡控制 677 实例483 语音卡电话呼叫系统 677 实例484 客户来电查询系统 682 实例485 语音卡实现电话录音 683 14.7 手机程序开发 685 实例486 利用短信猫收发短信息 685 实例487 利用短信远程关闭计算机 688 实例488 短信息采集烟草销售数据 690 实例489 “春晚”节目评比短信息互动平台 692 14.8 其他程序 693 实例490 条形码扫描器销售商品 693 实例491 利用神龙卡制作练歌房程序 694 第15章 网络开发技术 697 15.1 计算机设置 698 实例492 通过计算机名获取IP地址 698 实例493 通过IP地址获取主机名称 699 实例494 修改本机IP地址 700 实例495 得到本机MAC地址 702 实例496 获得系统打开的端口和状态 703 实例497 更改DNS地址 705 15.2 远程控制 706 实例498 远程控制计算机 706 实例499 远程服务控制 708 15.3 网络复制文件 710 实例500 网络中的文件复制 710 15.4 局域网管理 712 实例501 在局域网内发送信息 712 实例502 获取网络中所有工作组名称 714 实例503 列出工作组中所有计算机 715 实例504 获取网络中某台计算机的磁盘信息 716 实例505 映射网络驱动器 718 15.5 网络连接与通信 719 实例506 编程实现Ping操作 719 15.6 网络聊天室 721 实例507 利用C#设计聊天程序 721 实例508 点对点聊天室 723 第16章 Web编程 726 16.1 浏览器应用 727 实例509 制作自己的网络浏览软件 727 实例510 XML数据库文档的浏览 730 16.2 上网控制 732 实例511 定时上Internet 732 实例512 监测当前网络连接状态 734 16.3 邮件管理 734 实例513 收取电子邮件 735 实例514 SMTP协议发送电子邮件 738 16.4 网上信息提取 739 实例515 提取并保存网页源码 739 实例516 提取网页标题 742 第17章 加密、安全与软件注册 744 17.1 数据加密与解密 745 实例517 数据加密技术 745 实例518 文本文件加密与解密 746 实例519 利用图片加密文件 750 17.2 Access数据库安全 753 实例520 如何编程修复Access数据库 753 实例521 访问带验证模式的SQL Server 2000数据库 754 17.3 软件注册与加密 756 实例522 利用INI文件对软件进行注册 756 实例523 利用注册表设计软件注册程序 758 实例524 利用网卡序列号设计软件注册程序 760 实例525 根据CPU序列号、磁盘序列号设计软件注册程序 762 第18章 数据结构与算法 765 18.1 链表的实现 766 实例526 单向链表的实现 766 18.2 双向链表 770 实例527 双向链表 770 18.3 堆栈 775 实例528 堆栈的实现 775 18.4 队列 777 实例529 队列的实现 777 18.5 树的实现 778 实例530 树的实现 778 18.6 排序 782 实例531 冒泡排序 783 实例532 选择排序 783 实例533 插入排序 784 实例534 希尔排序 785 18.7 常见算法的实际应用 786 实例535 判断素数的算法 786 实例536 加密和解密算法 787 实例537 判断身份证是否合法 788 实例538 判断IP地址是否合法的算法 790 实例539 按要求生成指定位数编号 791 实例540 身份证号从15位升到18位算法 791 实例541 百钱百鸡的算法 792 实例542 韩信点兵的算法 793 实例543 实现裴波那契数列求和 794 实例544 求水仙花数的算法 795 实例545 如何将B转换成GB、MB和KB 796 实例546 0~N位数的任意组合 796 实例547 在数组中快速查找近似值 799 第19章 C#高级开发 800 19.1 Windows服务开发 801 实例548 将局域网聊天程序开发成Windows服务 801 19.2 Remoting分布式开发 807 实例549 运用Remoting实现文件传送 807 实例550 大规模数据访问时缓解服务器压力 813 19.3 COM+服务开发 819 实例551 COM+服务实现银行转账系统 819 实例552 COM+服务解决同时访问大量数据并发性 823 第20章 实用工具 827 20.1 数据库工具 828 实例553 自动配置ODBC的程序 828 实例554 制作SQL Server提取器 831 20.2 个人工具 833 实例555 个人通讯录 833 实例556 电子名片盒 835 实例557 个人日记本 836 实例558 个人理财管理 838 20.3 实用工具 840 实例559 电话区号、邮编管理软件 840 实例560 IP地址及手机号码归属地查询 841 实例561 火车时刻查询软件 844 实例562 网站网址导航程序 847 20.4 其他工具 850 实例563 人民币金额转换 850 实例564 列举局域网SQL服务器 852 实例565 整点报时程序 853 实例566 红绿灯程序 854 实例567 万年历 857 实例568 彩票抽奖机 859 实例569 电子相册 860 第21章 程序打包 863 21.1 最简单的程序打包 864 实例570 最简单的程序打包 864 实例571 将特定文件安装到指定文件夹中 866 21.2 打包注册表信息 868 实例572 打包注册表信息 868 技术要点对应实例位置 871 图书目录:
13.91MB
书 名:<< C#程序开发范例宝典>>【上卷】(分三卷上传完本书案例)
2010-04-10内容提要 本书紧密围绕程序开发人员在编程中遇到的实际问题和开发中应该掌握的技术,全面介绍了应用C#进行程序开发的技术和技巧。全书包括窗体与界面设计、控件应用、组件应用、图形技术、多媒体技术、文件系统、操作系统与Windows相关程序、注册表、数据库技术、SQL查询相关技术、LINQ查询技术、报表与打印技术、图 表技术、硬件相关开发技术、网络开发技术、Web编程、加密、安全与软件注册、数据结构与算法、C#高级开发、实用工具、程序打包等共21章,572个实例。 本书附有配套光盘。光盘提供了书中所有实例的源代码,全部源代码都经过精心调试,在Windows XP/Windows 2000/Windows Server 2003等操作系统下测试通过,均能够正常运行。 本书适合程序开发人员,也可供大中专院校师生阅读。 目 录 第1章 窗体与界面设计 1 1.1 菜单应用实例 2 实例001 带历史信息的菜单 2 实例002 菜单动态合并 3 实例003 像开始菜单一样漂亮的菜单 4 实例004 任务栏托盘菜单 4 实例005 可以拉伸的菜单界面 5 实例006 级联菜单 6 1.2 工具栏设计 6 实例007 带背景的工具栏 7 实例008 浮动工具栏 7 实例009 带下拉菜单的工具栏 8 实例010 具有提示功能的工具栏 8 1.3 状态栏设计 9 实例011 在状态栏中显示检查框 9 实例012 带进度条的状态栏 10 实例013 状态栏中加入图标 11 1.4 导航菜单界面 11 实例014 OutLook界面 11 实例015 带导航菜单的主界面 12 实例016 图形化的导航界面 14 1.5 特色程序界面 15 实例017 隐藏式窗体 15 实例018 类似Windows XP的程序界面 18 实例019 软件启动界面 19 实例020 以树形显示的程序界面 20 实例021 动态按钮的窗体界面 21 1.6 特殊形状的窗体 23 实例022 非矩形窗体 23 实例023 建立字体形状窗体 24 实例024 控件随窗体自动调整 25 实例025 带分隔栏的窗体 25 实例026 随机更换主界面背景 26 1.7 多媒体光盘 27 实例027 自动启动的多媒体光盘程序 27 实例028 为触摸屏程序添加虚拟键盘 28 1.8 窗体效果 29 实例029 半透明渐显窗体 29 实例030 窗口颜色的渐变 30 1.9 窗体动画 31 实例031 窗体中的滚动字幕 31 实例032 动画显示窗体 32 实例033 制作闪烁的窗体 33 实例034 实现任务栏通知窗口 34 实例035 动画形式的程序界面 38 1.10 标题栏窗体 39 实例036 使窗体标题栏文字右对齐 39 实例037 没有标题栏但可以改变大小的窗口 39 1.11 设置窗体位置 40 实例038 设置窗体在屏幕中的位置 40 实例039 始终在最上面的窗体 41 实例040 从桌面右下角显示的窗体 41 1.12 设置窗体大小 43 实例041 获取桌面大小 43 实例042 在窗口间移动按钮 44 实例043 如何实现Office助手 45 1.13 窗体控制技术 46 实例044 在关闭窗口前加入确认对话框 46 实例045 通过子窗体刷新父窗体 47 实例046 拖动无边框窗体 51 1.14 其他技术 52 实例047 禁用窗口上的关闭按钮 52 实例048 实现动态系统托盘图标 53 实例049 实现气泡提示窗口 54 第2章 控件应用 56 2.1 TextBox控件应用 57 实例050 只允许输入数字的TextBox控件 57 实例051 在TextBox控件底端显示下划线 59 实例052 屏蔽TextBox控件上的粘贴功能 61 实例053 屏蔽TextBox控件上默认的右键菜单 62 2.2 ComboBox控件应用 63 实例054 美化ComboBox控件下拉列表 63 实例055 用ComboBox控件制作浏览器网址输入框 64 2.3 RichTextBox控件应用 65 实例056 在RichTextBox控件中添加超链接文字 65 实例057 在RichTextBox控件中显示RTF格式的文件 66 实例058 为RichTextBox控件添加自定义滚动条 68 实例059 在RichTextBox控件中实现关键字描红 69 实例060 在RichTextBox控件中实现项目编号功能 71 实例061 设置RichTextBox控件中文本对齐方式 74 2.4 ListBox控件应用 77 实例062 在ListBox控件间交换数据 77 实例063 将数据库数据添加到ListBox控件中 78 实例064 借助绑定控件实现数据选择录入 79 实例065 设置ListBox控件选择项 80 2.5 选择类控件应用 83 实例066 利用选择控件实现权限设置 83 实例067 利用选择控件实现复杂查询 85 2.6 ListView控件应用 87 实例068 ListView控件间的数据移动 87 实例069 将数据库数据添加到ListView控件 90 实例070 在ListView控件中实现修改功能 91 实例071 在ListView控件中对数据排序或统计 92 实例072 在ListView控件中绘制底纹 93 实例073 在列表视图中拖动视图项 94 实例074 使ListView控件中的选择项高亮显示 97 实例075 带复选框的ListView控件 99 2.7 TreeView控件应用 100 实例076 将数据库数据显示到树视图中 100 实例077 用TreeView控件制作导航界面 102 实例078 用TreeView控件遍历磁盘目录 102 实例079 修改TreeView控件中的节点 105 实例080 将XML文件节点绑定到TreeView控件中 106 2.8 DataGridView控件应用 108 实例081 DataGridView控件的分页功能 108 实例082 从DataGridView控件拖放数据至TreeView控件 113 实例083 在DataGridView控件中实现合并单元格 116 实例084 在DataGridView控件中显示图片 118 实例085 为DataGridView控件实现复选功能 120 实例086 禁用DataGridView控件列表头自动排序 122 2.9 其他控件典型应用 123 实例087 TrackBar控件的简单应用 123 实例088 自制平滑进度条控件 125 实例089 MaskedTextBox控件的简单应用 128 实例090 制作日历计划任务 130 实例091 在ProgressBar控件中显示进度百分比 132 实例092 在NumericUpDown控件中显示当前系统日期 133 2.10 控件技术 134 实例093 程序运行时智能增减控件 134 实例094 多控件的焦点循环移动 136 实例095 动态创建控件 138 实例096 在Button按钮上绘图 138 2.11 焦点变换与输入控制 140 实例097 按回车键焦点在控件中移动的录入窗口 140 实例098 程序运行时拖动控件 141 实例099 控件得到焦点时变色 142 实例100 控件的输入限制 143 2.12 特殊控件 144 实例101 为控件制作立体效果 144 实例102 获取控件名称和内容 145 第3章 组件应用 147 3.1 BackgroundWorker组件 148 实例103 BackgroundWorker组件执行异步操作 148 3.2 ErrorProvider组件 150 实例104 使用ErrorProvider组件验证文本框输入 150 3.3 EventLog组件 151 实例105 使用EventLog组件读写Windows系统事件日志 151 实例106 使用EventLog组件保存Windows系统日志 153 实例107 使用EventLog组件向本机现有日志中添加条目 155 3.4 FileSystemWatcher组件 156 实例108 使用FileSystemWatcher组件监视系统日志文件是否被更改 157 3.5 HelpProvider组件 158 实例109 使用HelpProvider组件调用帮助文件 159 3.6 Process组件 159 实例110 使用Process组件访问本地进程 159 3.7 Timer组件 161 实例111 使用Timer组件制作计时器 161 实例112 使用Timer组件显示当前系统时间 165 实例113 使用Timer组件制作左右飘动的窗体 166 实例114 使用Timer组件实现奥运倒计时 167 3.8 ServiceController组件 169 实例115 使用ServiceController组件控制计算机的服务 169 3.9 ImageList组件 171 实例116 使用ImageList组件制作动画图片 171 3.10 DirectoryEntry组件 172 实例117 使用DirectoryEntry组件建立虚拟目录 172 第4章 图形技术 174 4.1 绘制图形 175 实例118 绘制公章 175 实例119 在图片中写入文字 176 实例120 局部图片的复制 178 实例121 波形图的绘制 179 4.2 图形转换 180 实例122 BMP转换成JPG格式 181 实例123 JPG转换成BMP格式 182 实例124 位图转化为WMF格式 183 实例125 ICO文件转化为位图 184 实例126 图片批量转换工具 185 4.3 图像预览 187 实例127 局部图像放大 187 实例128 浏览大图片 188 实例129 剪切图片 189 实例130 图像旋转 192 实例131 鼠标拖曳图像 193 4.4 图形缩放与变换 194 实例132 如何放大和缩小图像 194 实例133 如何旋转JPG图像 195 实例134 如何实现图形翻转 196 4.5 图像效果 196 实例135 百叶窗效果显示图像 197 实例136 推拉效果显示图像 198 实例137 水平交错效果显示图像 199 实例138 垂直交错效果显示图像 200 实例139 图像纹理效果 201 实例140 图像浮雕效果 203 实例141 积木效果 204 实例142 马赛克效果显示图像 205 实例143 雾化效果显示图像 206 实例144 锐化效果显示图像 207 实例145 黑白效果显示图像 208 实例146 光晕效果显示图像 209 4.6 图像字体 210 实例147 倒影效果的文字 210 实例148 投影效果的文字 211 实例149 印版效果的文字 213 实例150 阴影效果的文字 214 实例151 倾斜效果的文字 214 实例152 渐变效果的文字 215 实例153 缩放效果的文字 216 实例154 辉光效果文字 217 实例155 如何在图片中移动文字 220 4.7 图像动画 221 实例156 动画背景窗体 221 实例157 随鼠标移动的图像 223 实例158 十字光标定位 224 实例159 抓取鼠标指针的形状 225 实例160 图像的上下对接显示 226 实例161 任意角度旋转图像 227 实例162 以四周扩散形式显示图像 229 4.8 图像识别 230 实例163 查看图片的像素 230 实例164 设置图像中指定位置的像素值 230 实例165 在图像文件中实现自定义标记 232 实例166 获取指定点的RGB值 234 4.9 图像工具 235 实例167 获取图片类型 235 实例168 简单画图程序 236 实例169 看图工具 239 实例170 文字保存为图片 240 实例171 捕获屏幕 241 4.10 图像应用 243 实例172 随机更换壁纸程序 243 实例173 屏幕保护 244 实例174 模拟石英钟 247 实例175 生肖速查 249 第5章 多媒体技术 251 5.1 CD、VCD播放 252 实例176 播放指定的avi-mid-wav文件 252 实例177 获取多媒体详细信息列表 253 5.2 MP3、WAV播放 254 实例178 带记忆功能的MP3播放器 254 实例179 自动播放的MP3播放器 257 实例180 学校体操定时音乐播放 258 实例181 播放系统自带的事件声音 259 实例182 获取MP3文件的歌词 260 实例183 M3U文件的创建及删除 264 实例184 获取MP3文件的播放时间 267 实例185 异步加载并播放声音文件 269 5.3 动画播放 270 实例186 播放Flash动画 270 实例187 制作AVI播放器 272 实例188 播放GIF动画 273 实例189 利用Image制作小动画 274 5.4 媒体控制 275 实例190 检测是否安装声卡 275 实例191 打开和关闭CDROM 276 实例192 控制PC喇叭发声 277 实例193 获取显示设备的名称及PNPDeviceID 278 实例194 如何收听网络电台 279 实例195 获取显示设备的最大、最小及当前刷新率 281 实例196 隐藏控制面板中的声音设备 281 实例197 获取显示设备的当前显示模式 282 实例198 获取声音设备的名称及PNPDeviceID 283 实例199 语音计算器 284 5.5 多媒体应用 286 实例200 开机祝福程序 286 实例201 制作家庭影集 287 实例202 产品电子报价 288 实例203 产品滚动展示程序 290 实例204 将图片资源添加到EXE里 291 5.6 屏幕保护相关程序 292 实例205 电子相册屏幕保护程序 292 实例206 歌曲播放屏幕保护程序 293 第6章 文件系统 294 6.1 创建、删除文件和文件夹 295 实例207 创建和删除文件夹 295 实例208 建立临时文件 296 实例209 根据日期动态建立文件 296 实例210 清空回收站 298 6.2 查找文件 299 实例211 搜索文件 299 实例212 检查文件是否存在 300 实例213 提取指定文件夹目录 301 6.3 修改文件 302 实例214 更改文件名称 302 实例215 修改文件属性 303 实例216 修改文件及目录的名称 304 6.4 文件目录 305 实例217 获得临时文件目录 305 实例218 获取应用程序所在目录 305 实例219 得到系统当前目录 306 实例220 在程序中改变当前路径 307 6.5 复制文件 307 实例221 使用FileStream复制大文件 308 实例222 复制文件时显示复制进度 310 实例223 批量复制文件 312 6.6 指定类型的文件操作 313 实例224 文本文件的操作 313 实例225 使用ROT13加密解密文件 314 6.7 其他 315 实例226 获取窗口文本 315 实例227 判断文件是否正在被使用 316 实例228 在程序中调用.HLP文件 317 实例229 C#中实现文件拖放 317 实例230 文件比较 318 实例231 获取文件夹中的图标资源 319 实例232 获取文件夹下的所有文件夹及文件的名称 321 第7章 操作系统与Windows相关程序 324 7.1 启动相关 325 实例233 进入Windows系统前发出警告 325 实例234 实现注销、关闭和重启计算机 326 7.2 获得磁盘属性 328 实例235 获得硬盘序列号 328 实例236 获取映射驱动器路径 330 实例237 判断驱动器类型 331 实例238 获取所有逻辑分区 332 7.3 磁盘相关设置 333 实例239 取消磁盘共享 333 实例240 检查驱动器容量 334 实例241 检测磁盘是否准备好 335 实例242 图表显示磁盘容量 335 实例243 格式化磁盘 337 7.4 系统控制 338 实例244 将计算机设置为休眠状态 338 实例245 切换输入法 339 实例246 创建应用程序快捷方式 340 7.5 系统设置 340 实例247 设置桌面背景 341 实例248 设置系统时间 342 实例249 设置屏幕分辨率 343 7.6 系统监控 344 实例250 检测系统启动模式 344 实例251 内存使用状态监控 345 实例252 键盘钩子屏蔽热键 346 实例253 CPU使用率 348 7.7 系统软件信息 350 实例254 获取计算机中已安装的字体 350 实例255 获取计算机的显示设备信息 351 实例256 获取系统启动后经过的时间 351 实例257 系统已经安装的打印机信息 352 7.8 鼠标操作 353 实例258 切换鼠标左右键 353 实例259 限制鼠标活动区域 354 实例260 获取鼠标在任意点的颜色值 355 实例261 设置鼠标样式 357 7.9 程序控制 359 实例262 打开控制面板中的程序 359 实例263 添加程序托盘 360 实例264 不出现在任务栏上的程序 360 实例265 怎样调用外部的EXE文件 361 实例266 关闭外部已开启的程序 362 7.10 程序运行 363 实例267 防止程序多次运行 363 实例268 程序运行时禁止关机 364 实例269 获取任务栏尺寸大小 365 实例270 改变系统提示信息 366 实例271 获取系统环境变量 367 实例272 启动屏幕保护 368 7.11 系统隐藏 369 实例273 隐藏、显示任务栏 369 实例274 隐藏、显示开始按钮 370 实例275 查看当前系统版本 371 实例276 使桌面图标文字透明 372 实例277 检索系统中正在运行的任务 373 实例278 隐藏、显示桌面图标 374 7.12 其他 375 实例279 两种信息发送方式 375 实例280 判断计算机中是否安装了SQL软件 378 第8章 注册表 380 8.1 个性桌面 381 实例281 禁用桌面选项卡 381 实例282 禁用外观选项卡 382 实例283 禁用屏幕保护选项卡 383 实例284 设置任务栏时间样式 383 8.2 系统设置 384 实例285 隐藏桌面快捷方式图标的小箭头 384 实例286 禁用Windows任务管理器 385 实例287 禁用任务栏的右键菜单 386 8.3 IE浏览器设置 387 实例288 修改IE浏览器标题栏内容 387 实例289 获取IE浏览器版本信息 388 实例290 设置IE浏览器的默认主页 388 实例291 禁止修改IE浏览器主页 389 8.4 应用软件设置 390 实例292 建立数据文件与程序的关联 390 实例293 使应用程序开机自动运行 391 第9章 数据库技术 393 9.1 连接Access数据库 394 实例294 连接Access数据库 394 实例295 连接加密的Access数据库 394 实例296 自动识别Access 2000数据库路径 396 实例297 连接网络上共享的Access 2000数据库 397 实例298 将Access数据库导入Excel文件中 398 9.2 连接SQL Server数据库 400 实例299 使用ODBC DSN连接SQL Server数据库 400 实例300 使用ODBC非DSN连接SQL Server数据库 402 实例301 使用OLE DB连接SQL Server数据库 403 实例302 建立SQL Server数据库连接 404 9.3 连接其他数据库 405 实例303 连接Excel文件 405 实例304 连接Oracle数据库 406 9.4 数据库结构的读取与修改 407 实例305 读取SQL Server数据库结构 407 实例306 修改SQL Server数据库结构 409 9.5 数据录入 412 实例307 利用数据绑定控件录入数据 412 实例308 使用ADO.NET对象录入数据 414 实例309 利用SQL语句录入数据 416 实例310 利用存储过程录入数据 417 9.6 图片存取技术 420 实例311 使用存取文件名的方法存取图片 420 实例312 使用ADO.NET对象向SQL Server数据库存入图片 421 9.7 数据修改 423 实例313 利用数据绑定控件修改数据 424 实例314 利用数据对象修改数据 426 实例315 利用SQL语句修改数据 427 实例316 利用存储过程修改数据 429 9.8 数据保存前判断 431 实例317 判断输入数据是否符合要求 431 实例318 判断是否重复输入数据 433 9.9 数据删除 434 实例319 删除表格中指定的记录 434 实例320 利用SQL语句删除数据 435 9.10 数据记录 436 实例321 分页显示信息 436 实例322 移动记录 437 9.11 数据维护 439 实例323 在C#中分离SQL Server数据库 439 实例324 在C#中附加SQL Server数据库 440 实例325 在C#中附加单文件SQL Server数据库 441 9.12 数据备份恢复 442 实例326 备份SQL Server数据库 442 实例327 还原SQL Server数据库 445 9.13 管理系统开发相关 447 实例328 开启SQL Server数据库 447 实例329 断开SQL Server数据库与其他应用程序的连接 449 实例330 带图像列表的系统登录程序 450 实例331 利用SQL语句执行外围命令 451 实例332 系统初始化 452 第10章 SQL查询相关技术 454 10.1 SELECT子句 455 实例333 查询特定列数据 455 实例334 使用列别名 457 实例335 在列上加入计算 458 实例336 使用函数设置条件 459 10.2 查询常量 461 实例337 查询数字 461 实例338 查询字符串 462 实例339 查询日期数据 464 实例340 查询逻辑型数据 465 实例341 查询空(“”或Null)数据 466 10.3 查询变量 467 实例342 利用变量查询字符串数据 467 实例343 利用变量查询数值型数据 468 实例344 利用变量查询日期型数据 469 10.4 模式查询 471 实例345 利用“_”通配符进行查询 471 实例346 利用“%”通配符进行查询 472 实例347 利用“[]”通配符进行查询 473 实例348 利用“[^]”通配符进行查询 474 实例349 复杂的模式查询 475 10.5 TOP和PERCENT限制查询结果 476 实例350 查询前10名数据 476 实例351 取出数据统计结果的后10名数据 478 实例352 查询销售量占前50%的图书信息 479 实例353 查询库存数量占后20%的图书信息 480 10.6 周期、日期查询 481 实例354 查询指定日期的数据 481 实例355 查询指定时间段的数据 482 实例356 按年、月或日查询数据 484 10.7 比较、逻辑、重复查询 486 实例357 利用运算符查询指定条件的数据 486 实例358 NOT与谓词进行组合条件的查询 488 实例359 查询时不显示重复记录 489 实例360 列出数据表中的重复记录和记录条数 491 10.8 在查询中使用OR和AND运算符 492 实例361 利用OR运算符进行查询 492 实例362 利用AND运算符进行查询 493 实例363 同时利用OR、AND运算符进行查询 495 10.9 排序、分组统计 496 实例364 数据分组统计(单列) 497 实例365 在分组查询中使用ALL关键字 498 实例366 在分组查询中使用CUBE运算符 500 实例367 在分组查询中使用ROLLUP运算符 502 实例368 对数据进行降序查询 503 实例369 对数据进行多条件排序 505 实例370 对统计结果进行排序 506 实例371 按仓库分组统计图书库存(多列) 507 实例372 多表分组统计 508 实例373 使用COMPUTE 509 实例374 使用COMPUTE BY 511 10.10 聚合函数 512 实例375 利用聚合函数SUM对销售额进行汇总 512 实例376 利用聚合函数AVG求某班学生的平均年龄 514 实例377 利用聚合函数MIN求销售额、利润最少的商品 515 实例378 利用聚合函数MAX求月销售额完成最多的员工 517 实例379 利用聚合函数COUNT求日销售额大于某值的商品数 518 实例380 利用聚合函数First或Last求数据表中第一条或最后一条记录 519 10.11 多表查询(连接查询) 521 实例381 利用FROM子句进行多表查询 521 实例382 使用表别名 522 实例383 合并多个结果集 523 10.12 嵌套查询 525 实例384 简单嵌套查询 525 实例385 复杂嵌套查询 526 实例386 嵌套查询在查询统计中的应用 528 10.13 子查询 530 实例387 用子查询做派生的表 530 实例388 用子查询作表达式 531 实例389 在Update语句中应用子查询 532 10.14 联合语句Union 533 实例390 使用联合查询 533 实例391 多表联合查询 535 实例392 对联合查询后的结果进行排序 536 10.15 内联接查询 537 实例393 简单内联接查询 538 实例394 复杂内联接查询 539 实例395 使用内联接选择一个表与另一个表中行相关的所有行 540 10.16 外联接查询 541 实例396 左外联接查询 541 实例397 右外联接查询 543 实例398 使用外联接进行多表联合查询 544 10.17 利用IN进行查询 545 实例399 用IN查询表中的记录信息 545 实例400 使用IN引入子查询限定查询范围 546 10.18 交叉表查询 547 实例401 利用Trasform分析数据 547 实例402 利用Trasform动态分析数据 549 实例403 静态交叉表(SQLServer 2000) 551 实例404 动态交叉表(SQLServer 2000) 553 10.19 函数查询 555 实例405 在查询语句中使用格式化函数 555 实例406 在查询语句中使用字符串函数 557 实例407 在查询中使用日期函数 558 10.20 having语句应用 559 实例408 利用having语句过滤分组数据 559 实例409 having语句应用在多表查询中 561 10.21 视图的应用 562 实例410 在C#中应用视图 562 实例411 获取数据库中的全部用户视图 563 实例412 通过视图修改数据 564 10.22 存储过程的应用 565 实例413 C#应用存储过程 565 实例414 应用存储过程添加数据 566 实例415 应用存储过程修改数据 567 实例416 应用存储过程删除数据 568 实例417 C#应用查询存储过程 569 实例418 获取数据库中的全部存储过程 570 实例419 加密存储过程 571 10.23 触发器的应用 572 实例420 Insert触发器的应用 572 实例421 Update触发器在系统日志中的应用 574 实例422 触发器的嵌套使用 575 实例423 获取数据库中的触发器 576 第11章 LINQ查询技术 577 11.1 使用LINQ技术操作SQL数据库 578 实例424 使用LINQ技术查询SQL数据库中的数据 578 实例425 使用LINQ技术向SQL数据库中添加数据 581 实例426 使用LINQ技术在SQL数据库中修改数据 582 实例427 使用LINQ技术在SQL数据库中删除数据 583 实例428 使用LINQ技术查询前5名数据 584 实例429 使用LINQ技术对数据进行排序 585 实例430 使用LINQ技术统计员工的工资总额 587 11.2 LINQ技术其他应用 588 实例431 使用LINQ技术获取文件详细信息 588 实例432 使用LINQ技术对XML文件进行操作 589 第12章 报表与打印技术 594 12.1 Windows打印组件 595 实例433 打印窗体中的数据 595 实例434 图形打印 597 12.2 利用报表生成器设计报表 598 实例435 利用报表专家设计并显示学生基本信息 598 实例436 分组统计报表 601 实例437 在水晶报表中添加图表 602 12.3 水晶报表基本操作 605 实例438 在水晶报表中使用Access数据库 605 实例439 在水晶报表中使用SQL Server数据库 606 实例440 订货总金额超过10万元显示“恭喜获奖”文字 607 实例441 薪资大于或等于1万元使用蓝色字体标记 609 实例442 筛选薪资大于2000元的男员工 610 实例443 按类别分组统计图书库存 611 实例444 按成绩总分降序排序 612 实例445 部门销售量占公司总销售量的业绩百分比 613 12.4 子报表的使用 614 实例446 插入子报表 615 实例447 编辑与重新导入子报表 615 实例448 根据需要显示子报表 617 12.5 调用Office进行打印 618 实例449 利用Word打印员工报表 618 实例450 利用Excel打印学生信息报表 620 第13章 图表技术 622 13.1 简单图表 623 实例451 绘制面形图 623 实例452 绘制椭圆 624 实例453 绘制矩形 625 实例454 绘制曲线 626 实例455 绘制柱形图 627 13.2 柱形图表 628 实例456 将汇总数据利用图表分析 628 实例457 柱形图表分析商品走势 630 实例458 对排序数据进行分析 632 实例459 利用控件实现柱形图分析 633 实例460 在柱形图的指定位置显示说明文字 634 13.3 折线图表 635 实例461 利用图表分析产品销售走势 635 实例462 利用图表分析彩票中奖情况 637 实例463 多曲线数据分析 638 实例464 网站人气指数曲线分析 641 13.4 饼形图表 643 实例465 利用饼形图分析公司男女比率 643 实例466 利用饼形图分析产品市场占有率 644 实例467 利用多饼形图分析企业人力资源情况 645 实例468 制作一个可以旋转的饼形图 647 13.5 图表技术的应用 648 实例469 绘制验证码 649 实例470 在饼形图的外围显示说明文字 650 第14章 硬件相关开发技术 655 14.1 串口控制 656 实例471 通过串口发送数据 656 实例472 通过串口关闭对方计算机 657 14.2 加密狗 659 实例473 密码写入与读出加密狗 659 实例474 使用加密狗进行身份验证 661 14.3 IC卡应用 662 实例475 向IC卡中写入数据 662 实例476 读取IC卡中的数据 665 实例477 利用IC卡制作考勤程序 666 14.4 指纹识别器应用 667 实例478 将指纹数据存入数据库中 667 实例479 使用指纹识别器进行员工考勤 669 14.5 监控 671 实例480 简易视频程序 671 实例481 摄像头监控录像 674 实例482 超市摄像头定时监控系统 675 14.6 语音卡控制 677 实例483 语音卡电话呼叫系统 677 实例484 客户来电查询系统 682 实例485 语音卡实现电话录音 683 14.7 手机程序开发 685 实例486 利用短信猫收发短信息 685 实例487 利用短信远程关闭计算机 688 实例488 短信息采集烟草销售数据 690 实例489 “春晚”节目评比短信息互动平台 692 14.8 其他程序 693 实例490 条形码扫描器销售商品 693 实例491 利用神龙卡制作练歌房程序 694 第15章 网络开发技术 697 15.1 计算机设置 698 实例492 通过计算机名获取IP地址 698 实例493 通过IP地址获取主机名称 699 实例494 修改本机IP地址 700 实例495 得到本机MAC地址 702 实例496 获得系统打开的端口和状态 703 实例497 更改DNS地址 705 15.2 远程控制 706 实例498 远程控制计算机 706 实例499 远程服务控制 708 15.3 网络复制文件 710 实例500 网络中的文件复制 710 15.4 局域网管理 712 实例501 在局域网内发送信息 712 实例502 获取网络中所有工作组名称 714 实例503 列出工作组中所有计算机 715 实例504 获取网络中某台计算机的磁盘信息 716 实例505 映射网络驱动器 718 15.5 网络连接与通信 719 实例506 编程实现Ping操作 719 15.6 网络聊天室 721 实例507 利用C#设计聊天程序 721 实例508 点对点聊天室 723 第16章 Web编程 726 16.1 浏览器应用 727 实例509 制作自己的网络浏览软件 727 实例510 XML数据库文档的浏览 730 16.2 上网控制 732 实例511 定时上Internet 732 实例512 监测当前网络连接状态 734 16.3 邮件管理 734 实例513 收取电子邮件 735 实例514 SMTP协议发送电子邮件 738 16.4 网上信息提取 739 实例515 提取并保存网页源码 739 实例516 提取网页标题 742 第17章 加密、安全与软件注册 744 17.1 数据加密与解密 745 实例517 数据加密技术 745 实例518 文本文件加密与解密 746 实例519 利用图片加密文件 750 17.2 Access数据库安全 753 实例520 如何编程修复Access数据库 753 实例521 访问带验证模式的SQL Server 2000数据库 754 17.3 软件注册与加密 756 实例522 利用INI文件对软件进行注册 756 实例523 利用注册表设计软件注册程序 758 实例524 利用网卡序列号设计软件注册程序 760 实例525 根据CPU序列号、磁盘序列号设计软件注册程序 762 第18章 数据结构与算法 765 18.1 链表的实现 766 实例526 单向链表的实现 766 18.2 双向链表 770 实例527 双向链表 770 18.3 堆栈 775 实例528 堆栈的实现 775 18.4 队列 777 实例529 队列的实现 777 18.5 树的实现 778 实例530 树的实现 778 18.6 排序 782 实例531 冒泡排序 783 实例532 选择排序 783 实例533 插入排序 784 实例534 希尔排序 785 18.7 常见算法的实际应用 786 实例535 判断素数的算法 786 实例536 加密和解密算法 787 实例537 判断身份证是否合法 788 实例538 判断IP地址是否合法的算法 790 实例539 按要求生成指定位数编号 791 实例540 身份证号从15位升到18位算法 791 实例541 百钱百鸡的算法 792 实例542 韩信点兵的算法 793 实例543 实现裴波那契数列求和 794 实例544 求水仙花数的算法 795 实例545 如何将B转换成GB、MB和KB 796 实例546 0~N位数的任意组合 796 实例547 在数组中快速查找近似值 799 第19章 C#高级开发 800 19.1 Windows服务开发 801 实例548 将局域网聊天程序开发成Windows服务 801 19.2 Remoting分布式开发 807 实例549 运用Remoting实现文件传送 807 实例550 大规模数据访问时缓解服务器压力 813 19.3 COM+服务开发 819 实例551 COM+服务实现银行转账系统 819 实例552 COM+服务解决同时访问大量数据并发性 823 第20章 实用工具 827 20.1 数据库工具 828 实例553 自动配置ODBC的程序 828 实例554 制作SQL Server提取器 831 20.2 个人工具 833 实例555 个人通讯录 833 实例556 电子名片盒 835 实例557 个人日记本 836 实例558 个人理财管理 838 20.3 实用工具 840 实例559 电话区号、邮编管理软件 840 实例560 IP地址及手机号码归属地查询 841 实例561 火车时刻查询软件 844 实例562 网站网址导航程序 847 20.4 其他工具 850 实例563 人民币金额转换 850 实例564 列举局域网SQL服务器 852 实例565 整点报时程序 853 实例566 红绿灯程序 854 实例567 万年历 857 实例568 彩票抽奖机 859 实例569 电子相册 860 第21章 程序打包 863 21.1 最简单的程序打包 864 实例570 最简单的程序打包 864 实例571 将特定文件安装到指定文件夹中 866 21.2 打包注册表信息 868 实例572 打包注册表信息 868 技术要点对应实例位置 871 图书目录:
Linux系统编程:入门篇视频教程
2018-10-16Linux系统编程视频课程为《Linux系统编程》入门篇,主要针对零基础的Linux开发学员科普Linux系统编程的概念以及需要掌握的各种技能,掌握Linux命令编写、Linux学习路线并熟悉嵌入式设备编程的方法。为后续的Linux系统编程深入学习打下良好的基础。
程序员的数学:概率统计
2019-09-19编程的基础是计算机科学,而计算机科学的基础是数学。因此,学习数学有助于巩固编程的基础,写出更健壮的程序。本门课程主要讲解程序员必备的数学知识,借以培养程序员的数学思维。学习者无需精通编程,也无需精通数学。从概率统计、线性代数、微积分、优化理论、随机过程到当前大热的机器学习,讲师幽默风趣,课件精致美观,深入浅出带你重学数学!
JAVA入门精品课程
2018-12-20课程目标: 1、让初学者从小白开始,善于运用知识点,解脱学习的苦恼 2、能够学习更多的工作中使用技巧,成为编程高手
JavaEE+大数据+2个实战项目终极套餐震撼来袭
2017-05-19该套视频教程共包含16门课程,分别是Linux入门到精通、大型ERP项目实战教程、solr教程、Lucene教学视频、Java反射与注解开发、Hadoop大数据入门教程、Activiti工作流教程、redis高并发由浅入深、webservice入门教程、hibernate4入门教程、大型分布式redis+solr+Linux+nginx+springmvc+mybatis电商项目、struts2深入浅出、oracle入门到大神、springmvc深入浅出、spring 3.2教程、mybatis入门到精通教程、Java EE教程、Mysql教程。
-
下载
PCtoLCD2002.zip
PCtoLCD2002.zip
-
下载
【光盘资料】EasyARM-RT1052-AWorks_part6_硬件设计
【光盘资料】EasyARM-RT1052-AWorks_part6_硬件设计
-
下载
互联网+社区生鲜电商运营解决方案.ppt
互联网+社区生鲜电商运营解决方案.ppt
-
下载
20210418-兴业证券-紫金矿业-601899-Q1业绩超上限,世界级矿企呼之欲出.pdf
20210418-兴业证券-紫金矿业-601899-Q1业绩超上限,世界级矿企呼之欲出.pdf
-
下载
大数据分析平台总体架构解决方案.pptx
大数据分析平台总体架构解决方案.pptx
-
下载
今世缘:江苏今世缘酒业股份有限公司2020年年度报告.PDF
今世缘:江苏今世缘酒业股份有限公司2020年年度报告.PDF
-
下载
20210418-国泰君安-普门科技-688389-首次覆盖报告:电化学发光发力在即,高增长可期.pdf
20210418-国泰君安-普门科技-688389-首次覆盖报告:电化学发光发力在即,高增长可期.pdf
-
下载
锦鸡股份:2020年年度报告(更新后).PDF
锦鸡股份:2020年年度报告(更新后).PDF
-
下载
上海大学管理学院毕业论文参考文献格式Endnote处理.rar
上海大学管理学院毕业论文参考文献格式Endnote处理.rar
-
下载
20210416-广发证券-华菱钢铁-000932-“优钢”转“特钢”提升产品结构,降本增效增强盈利能力.pdf
20210416-广发证券-华菱钢铁-000932-“优钢”转“特钢”提升产品结构,降本增效增强盈利能力.pdf
