管理员模块已更新使用说明1电脑上装JDK2电脑上装mysql数据库3在dos下打开mysql后,把mysql.txt里的代码(包括insert代码)复制到dos下运行,记得最后再按一下回车键,让最后一行也运行。
4在eclipse或myeclipse下新建java项目(注意不是jsp项目)后,复制src文件夹到替换项目里的src。
然后在复制train.pro,右击项目名粘贴(即把train.pro加到项目目录里)5把mysql-connector-java-5.1.13-bin.jar添加到项目里。
右键项目,点击BuildPath后再点击addExternalArchives后找到mysql-connector-java-5.1.13-bin.jar文件打开即可。
6在eclipse里打开wed包下MySqlH.java设置mysqlroot用户的密码,Stringpassword="mysql";我的密码是mysql,这里改成你自己的密码。
7运行client包下的Administrator.java,若没有错如则OK。
8运行后点击工具条里的‘工具’,后再点击‘生成所有列车表’,若成功,此时可看见列车表里增加了很多数据。
可能有点慢,稍等一会。
9若8成功,则点击工具条里的‘工具’,后再点击‘生成所有车票表’,若成功,此时可看见车票表里增加了很多数据。
可能有点慢,稍等一会。
关于工具条理的‘生成所有列车表’‘生成所有车票表’"生成列车表""生成车票表""设置天数"的介绍1‘生成所有列车表’是根据车次表和车站表的全部数据自动生成列车表里的数据,仅限于第一次时使用。
2‘生成所有车票表’是根据列车表里的全部数据自动生成车票表里的数据,仅限于第一次时使用。
3"生成列车表"是根据你输入的某一列车次(必须是车次表里的车次和车站表里有与之相关的数据时才能使用)自动生成列车表里的数据4"生成车票表"是根据你输入的某一ID(必须是列车表里的ID)自动生成车票表里的数据5"设置天数"是设置能够预订和销售的最多天数,默认是3天,即能预订和销售3天内的车票注意: 1订票记录表,销售记录表,退票记录表里的时间是系统自动生成,在任何情况下都不需填写也不能修改 2在管理员模块里添加,删除和修改后需更新一下才能显示,只需点一下别的表,在点刚修改的表即可,数据完全正确 3退票员和销售员登录时分别查询对应表的记录,因此需要在管理员模块里增加相应记录后才能登录 4此系统暂时已知还有多个缺陷,如如退票是可一张票可退多次,一个订票id可买多张车票。
由于时间因素,就不在修补了。
5train.pro是个配置文件,可用记事本打开,尽量在train下的Main_Config.java里修改其配置信息
2025/5/20 18:04:28 745KB 火车票销售系统 java web gui
1
本系统以C#+SQL2005完成了一个的简单的酒店管理系统,实现了酒店的基本的功能
2025/5/20 15:24:40 8.96MB C#的简单的酒店管理系统
1
《Java课程设计案例精编(第二版)》-黄晓东完整源代码零积分案例1骑士游历程序的开发案例2小小画图板的开发案例3俄罗斯方块游戏的开发案例4Mini人事管理系统的开发案例5校园IP查询系统的开发案例6学生信息管理系统的开发案例7超市管理系统的开发案例8高考管理系统的开发案例9雇员信息管理案例10运动会成绩管理系统
2025/5/20 15:11:11 4.22MB Java 课程设计 案例精编 完整源代码
1
【DM365_NAND启动模式解析】DM365是一款由TexasInstruments(TI)生产的数字媒体处理器,常用于视频处理和嵌入式系统。
在DM365中,NAND闪存是一种常见的非易失性存储器,用于存储固件和操作系统。
NAND启动模式是指DM365在上电或复位后从NAND闪存中加载启动代码的过程。
此过程涉及一系列复杂的步骤,确保系统能够正确地从NAND中读取和执行固件。
**NAND启动流程**1.**初始化**:系统首先初始化RAM1的高2KB栈空间(0x7800-0x7fff),避免覆盖用于存储UBL块号的最后32个字节(0x7ffc-0x8000)。
2.**禁止中断**:所有中断(IRQ和FIQ)被禁用,以确保启动过程不被打断。
3.**设置DEEPSLEEPZ/GIO0**:这个外部引脚在NAND启动时必须处于高电平。
4.**读取NANDID**:读取NAND闪存的设备ID,获取设备特性,如页面大小、块大小等。
5.**初始化NAND区域**:根据NAND的参数设置控制器和寄存器。
6.**搜索UBL描述符**:RBL(ROMBootloader)在block1的page0开始搜索UBL(UserBootLoader)的描述符。
如果未找到正确的UBL,会依次检查接下来的24个块,以防遇到坏块。
7.**处理UBL描述符**:UBL描述符包含入口点地址、占用的NAND页数、起始块和起始页等信息,用于指导UBL的加载和执行。
8.**ECC错误检测和校正**:开启硬件ECC(ErrorCorrectionCode)检测,复制UBL到IRAM(InternalRAM)。
如果检测到4位ECC错误,通过ECC算法进行纠正。
如果多次失败,RBL会尝试下一个块,直到找到有效的UBL描述符,或者在搜索完24个块后转而从SD卡启动。
9.**启动UBL**:在UBL的入口点执行代码,将控制权交给UBL。
10.**安全启动模式**:根据配置,启动模式可能包括PLL旁通模式,不使用快速EMIF、DMA或I-Cache。
在其他模式下,这些功能可以被启用以提高性能。
**NANDUBLdescriptor格式**UBL描述符是一个包含关键信息的数据结构,用于指示如何加载和执行UBL。
它可能包含如下字段:-入口点地址:UBL执行的起点。
-UBL占用的NAND页数:指示UBL的大小,必须是连续的页。
-UBL的起始块和起始页:定义UBL在NAND中的位置。
-MAGICIDs:特定的标识符,用于识别不同的启动模式。
**NAND启动详细流程**1.初始化栈空间、禁止中断、设置DEEPSLEEPZ/GIO0。
2.读取NAND设备ID,初始化NAND控制器。
3.搜索UBL描述符,最多遍历24个块。
4.复制并校验UBL到IRAM,根据UBL描述符配置启动选项。
5.转交控制权给UBL执行。
NAND启动流程图和具体的ARMNANDROMBootloader实例进一步详细说明了这个过程。
此外,支持的NAND设备ID列表确保了对多种NAND闪存设备的兼容性。
DM365的NAND启动模式解析涉及了设备识别、错误检测、固件加载和执行等多个环节,确保了系统的稳定和可靠启动。
理解这一过程对于开发和调试基于DM365的嵌入式系统至关重要。
2025/5/20 16:04:21 249KB DM365
1
###TIDM36x系列DSPNANDFlash启动过程详解####一、NANDFlash启动原理#####1.1DM365支持的NAND启动特性TI的TMS320DM365(以下简称DM365)多媒体处理芯片支持多种启动方式,包括NANDFlash启动。
在NANDFlash启动过程中,DM365具有一系列独特的启动特性:1.**不支持一次性全部固件下载启动**:DM365不支持一次性将所有固件数据从NANDFlash读入内存并启动,而是采用分阶段的方式。
首先从NANDFlash读取第二级启动代码(UserBootLoader,UBL)至ARM内存(ARMInternalMemory,AIM),然后执行UBL。
2.**支持最大4KB页大小的NAND**:支持的NANDFlash页大小可达4KB,这对于大多数常见的NANDFlash设备来说是足够的。
3.**支持特殊数字标志的错误检测**:在加载UBL时会进行错误检测,尝试最多24次在不同的block中寻找特殊数字标志,以确保数据的正确性。
4.**支持30KB大小的UBL**:DM365有32KB的内存用于存放启动代码,其中2KB用于RBL(ROMBootLoader)的堆栈,剩余的空间可用来存储UBL。
5.**用户可选的DMA与I-cache支持**:用户可以根据需要在RBL执行期间启用或禁用DMA和I-cache等功能。
6.**支持4位硬件ECC**:支持每512字节需要ECC位数小于或等于4位的NANDFlash,这有助于提高数据的可靠性。
7.**支持特定的NANDFlash类型**:支持那些需要片选信号在Tr读时间保持低电平的NANDFlash。
#####1.2NANDFlash启动流程NANDFlash启动流程是指从芯片上电到Linux操作系统启动的整个过程,主要包括以下几个步骤:1.**ROMBootLoader(RBL)阶段**:当DM365芯片上电或复位时,会根据BTSEL引脚的状态确定启动方式。
如果是NAND启动,则从ROM中的RBL开始执行。
RBL会初始化必要的硬件资源,如设置堆栈,关闭中断,并读取NANDFlash的ID信息以进行适当的配置。
2.**UserBootLoader(UBL)阶段**:RBL从NANDFlash读取UBL并将其复制到AIM中运行。
UBL负责进一步初始化硬件资源,如DDR内存,并为下一阶段准备环境。
3.**U-Boot阶段**:UBL从NANDFlash读取U-Boot并将其复制到DDR内存中运行。
U-Boot是完整的启动加载程序,它负责最终从NANDFlash读取Linux内核并将其复制到DDR内存中。
4.**Linux内核启动阶段**:U-Boot启动Linux内核,内核加载并运行,此时系统完成启动。
####二、NANDFlash启动的软件配合实现#####2.1UBL描述符的实现UBL描述符是UBL读取和执行的起点。
在NANDFlash中,UBL描述符通常位于特定的位置,包含UBL的起始地址和长度等信息。
RBL通过读取这些描述符来确定UBL的具体位置并加载到AIM中。
#####2.2U-Boot启动实现U-Boot是一种开源的启动加载程序,负责从NANDFlash读取Linux内核并将其加载到内存中。
U-Boot的实现依赖于UBL提供的环境,例如已经初始化的DDR内存。
#####2.3U-Boot更新UBL和U-Boot的原理U-Boot可以被用来更新UBL和自身的代码。
这一过程通常涉及到从NANDFlash读取新的代码版本,验证其完整性,并将其替换现有的UBL或U-Boot代码。
#####2.4NANDFlash没有坏块的情况在理想情况下,即NANDFlash没有坏块的情况下,启动流程会非常顺利。
RBL能够成功地从NANDFlash读取UBL,UBL也能正确地读取U-Boot,进而完成Linux内核的加载。
####三、结束语DM365的NANDFlash启动过程是一个复杂的多阶段过程,涉及ROMBootLoader(RBL)、UserBootLoader(UBL)和U-Boot等多个组件之间的协调工作。
通过对这些组件的理解和优化,可以有效地提高启动速度和系统的稳定性。
希望本文能帮助读者更好地理解DM365的NANDFlash启动过程及其背后的技术细节。
2025/5/20 15:59:25 439KB DSP NANDflash 启动过程分析
1
### ICETEK-DM365-LCD-43V1原理图解析

#### 原理图概述

本文档将详细介绍“ICETEK-DM365-LCD-43V1原理图”中的关键组件和技术细节。
该原理图主要用于指导ICETEK-DM365-LCD-43V1显示屏的设计与组装,涵盖了电源管理、信号传输、显示控制等核心领域。


#### 电源管理部分

- **TPS61042**: 这是一款高效的DC-DC升压转换器,用于从输入电压VIN产生稳定的5V输出VCC_5V。
其工作频率高,能够在小体积下实现高效能。

- **C8 (4.7uF/10V)**: 为TPS61042提供必要的滤波电容,确保输出电压稳定。

- **R7 (10K)**: 用于调节TPS61042的输出电压,通过外部电阻可以设定不同的输出电压值。

- **VCC_5V**: TPS61042产生的稳定5V电源输出,为整个系统提供必要的电力支持。


#### 显示屏背光驱动电路

- **L1 (4.7uH)**: 小型电感器,用于背光驱动电路中的升压转换。

- **D1**: 背光驱动电路中的二极管,通常选用高速恢复二极管或肖特基二极管,用于防止电流倒流。

- **C7 (2.2uF/50V)**: 高压滤波电容,用于稳定背光驱动电路的输出电压。

- **LED**: 指示灯或背光LED,由背光驱动电路供电。

- **BACKLIGHT_FB**: 背光反馈信号,用于调节背光亮度,通常连接至控制芯片的反馈引脚。


#### 显示控制器接口

- **DSS_HSYNC**: 水平同步信号,用于同步水平扫描周期。

- **DSS_VSYNC**: 垂直同步信号,用于同步垂直扫描周期。

- **DSS_PCLK**: 像素时钟信号,用于同步像素数据的发送。

- **DSS_ACBIAS**: AC偏置信号,用于改善显示效果,减少图像残留。


#### 显示数据接口

- **DSS_DATA0-DSS_DATA23**: 数据线接口,用于传输显示数据至显示屏。

- **DSS_HSYNC-DSS_VSYNC**: 同步信号线,用于同步显示数据的传输。


#### 显示屏驱动部分

- **U2 (NO-POP)**: 显示屏驱动芯片,负责处理从控制器接收到的数据,并驱动显示屏显示图像。

- **C1-C6 (NO-POP)**: 与U2配套使用的滤波电容,用于滤除噪声,提高信号质量。

- **R1-R5 (33R/0R/330R)**: 电阻器,用于信号线路的匹配和限流。

- **R9-R11 (NO-POP/1K)**: 用于特定功能的电阻器,如信号分压或限流等。


#### 显示屏接口

- **LCD_3V3**: 显示屏工作电压3.3V。

- **LCD_DEN**: 显示使能信号,用于控制显示屏的开启与关闭。

- **LCD_CLKIN**: 显示时钟输入信号,用于同步显示数据的传输。

- **LCD_VSHYC/LCD_HSHYC**: 显示电压调节信号,用于优化显示效果。

- **LCD_LED- / LCD_LED+**: 显示屏背光LED正负极接口。

- **R0-R7**: 显示屏数据线接口,用于传输显示数据。

- **G0-G7/B0-B7**: 显示屏地址线接口,用于定位像素位置。

- **DCLK**: 数据时钟信号,用于同步显示数据的传输。

- **DISP**: 显示信号,用于控制显示状态。

- **HSYNC/VSYNC**: 水平同步/垂直同步信号,用于同步显示刷新周期。


#### 其他重要接口

- **I2C1_SDA/I2C1_SCL**: I2C通信接口,用于与其他设备进行数据交换。

- **VCC_1V8/VCC_3V3/VCC_5V**: 提供不同电压级别的电源接口。

- **GPIO**: 通用输入输出接口,可用于扩展功能。

- **RESOUTN**: 复位信号输出,用于复位显示屏驱动芯片。

- **MCSPI1_CLK/MCSPI1_SIMO/MCSPI1_SOMI/MCSPI1_CS0**: SPI通信接口,用于与显示屏驱动芯片进行数据交互。


“ICETEK-DM365-LCD-43V1原理图”涵盖了显示屏系统的电源管理、显示控制、信号传输等多个方面,通过细致分析这些组件及其相互之间的连接方式,可以深入了解ICETEK-DM365-LCD-43V1显示屏的工作原理及设计细节。
这对于从事相关硬件开发和维护的技术人员来说是非常宝贵的参考资料。
2025/5/20 15:55:55 22KB
1
【ICETEK-DM365-KB-EZ试验手册】是针对基于TI DM365处理器的开发板设计的一份详细实验指南。
DM365是一款由德州仪器(Texas Instruments,简称TI)生产的高性能数字媒体处理器,适用于视频处理、音频处理以及网络应用等多种领域。
该手册的目标是帮助用户熟悉DM365开发环境,掌握基本的硬件接口操作和软件开发流程。


手册首先介绍了如何构建CCS(Code Composer Studio)仿真调试环境。
CCS是TI提供的一款集成开发环境,支持C/C++编程语言,用于开发和调试基于TI DSP的嵌入式应用程序。
实验一详细阐述了安装、配置CCS,以及创建和调试项目的基本步骤。


实验二至实验十六涵盖了从模拟信号采集(ADC实验)、网络通信(emac_loopback实验)、输入输出设备控制(按键和LED实验)到存储器操作(Nandflash和DDR实验)、时钟管理(RTC实验)、外设接口使用(如UART、USB电源、SD卡接口)等多个方面。
这些实验旨在帮助用户逐步了解DM365处理器的硬件资源和驱动程序开发。


例如,在ADC采集实验中,用户将学习如何利用DM365的内置模数转换器(ADC)获取模拟信号,并在CCS中进行数据分析。
而在emac_loopback实验中,用户会设置以太网控制器(EMAC)进行环回测试,验证网络接口功能。


视频和音频处理是DM365的重要应用领域。
实验十四的彩条输出试验展示了如何通过DM365的视频处理单元产生彩色条纹,验证视频输出功能。
实验十五和实验十六则涉及视频回放和音频播放,让用户了解如何处理多媒体数据流。


此外,手册还包含了对看门狗定时器的管理和Nandflash启动的UBL及u-boot烧写试验。
看门狗定时器是系统稳定性的重要保障,实验十一介绍了如何禁用看门狗以避免意外重启。
实验十五则涉及嵌入式系统的引导过程,通过烧写UBL和u-boot,用户可以学习如何设置DM365的启动流程。


手册最后提供了瑞泰创新公司的联系方式,该公司位于北京,可能为用户提供进一步的技术支持和服务。


这份【ICETEK-DM365-KB-EZ试验手册】是一份全面的实践教程,覆盖了DM365开发的多个关键环节,对于想要深入理解和应用DM365处理器的工程师来说,是一份宝贵的参考资料。
通过完成这些实验,用户不仅能够熟练掌握DM365的硬件特性,还能提升在嵌入式系统开发和调试方面的技能。
2025/5/20 15:54:54 5.3MB
1
在本文中,我们将深入探讨DM365芯片的启动流程,特别是针对NAND和UART两种启动模式。
DM365是一款基于DaVinci技术的多媒体处理器,其启动机制涉及到多个组件,包括MMU、数据缓存和指令缓存,以及不同类型的BootLoader。
MMU(内存管理单元)在启动阶段必须关闭,这意味着在这个阶段,虚拟地址与物理地址是相同的,这简化了对内存的访问。
数据缓存和指令缓存则用于提高处理器对内存数据的存取速度,它们在启动过程中起到加速代码执行的作用。
DM365的启动模式可以通过设置BTSEL[2:0]跳线来选择。
当设置为001时,系统会从外部的NORFLASH启动;
其他设置则会从内部ROM启动,执行固化在ROM中的RBL(ROMBootLoader)。
RBL是一个不可擦除的BootLoader,负责加载用户定义的UBL(UserBootLoader)到内存特定地址执行。
UBL的大小有限,不能超过14K,因此无法直接包含完整的U-BOOT。
为了启动U-BOOT,我们需要一个小于14K的小型UBL,它位于NANDFlash的前5个block内。
启动流程如下:1.RBL运行,检查NANDFlash设备ID。
2.如果设备ID匹配,RBL查找UBL的描述信息。
3.RBL将UBL复制到ARM内部RAM,并进行ECC校验。
4.UBL加载后,可以进一步加载U-BOOT和操作系统。
对于NANDBOOT模式,RBL会尝试读取NANDFlash的设备ID,然后查找并加载UBL。
如果失败,会尝试其他启动模式,如MMC/SD。
对于UARTBOOT,RBL通过串口与主机程序交互,发送BOOTME信号并等待ACK,以完成UBL的传输。
在UARTBOOT过程中,串口设置和通信协议是关键,RBL与主机程序的交互确保了UBL的正确接收。
一旦UBL通过UART传输到DM365,后续的启动流程与NANDBOOT类似。
DM365的启动涉及多层BootLoader,每层都有特定的任务,从初始化硬件到加载操作系统。
理解这些启动机制对于开发和调试基于DM365的系统至关重要,尤其是在需要自定义启动流程或优化性能时。
同时,熟悉MMU、缓存的工作原理也是优化系统性能的关键。
2025/5/20 15:52:57 326KB
1
英文版的信号与系统,比国内的详细,容易理解信号与系统是做什么的,方便初学者打好基础
2025/5/20 12:46:20 4.25MB 信号与系统
1
某大学拟开发一个计算机分房管理系统,要求系统具有分房、调房、退房和咨询统计等功能。
房产科把用户申请表输入系统后,系统首先检查申请表是否合理,对不合法申请表拒绝接受;
对合法表根据类型进行处理。
分房申请,根据申请者情况(年龄、工龄、职称、职务、家庭人口等)计算其分数,高于阀值的进行排队。
分房时,读空房文件,把好房优先分给排在分房队列前面的人,并将房屋信息与申请者一起写入住房文件中。
若为退房申请,从住房文件中删除有关信息,并将房屋信息计入空房文件。
若是调房申请,根据申请者情况计算分数,并进行以上退房和分房处理。
系统可进行房屋信息维护(输入、删除、排序),以及各种住房信息统计、查询、打印等。
2025/5/20 12:26:19 9.58MB vb
1
共 1000 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡