目录前言1.翻译说明1.在Tomcat中快速上手1.1.开始Hibernate之旅1.2.第一个可持久化类1.3.映射cat1.4.与猫同乐1.5.结语2.体系结构2.1.总览2.2.JMX集成2.3.JCA支持3.SessionFactory配置3.1.可编程配置方式3.2.获取SessionFactory3.3.用户自行提供JDBC连接3.4.Hibernate提供的JDBC连接3.5.可选配置属性3.5.1.SQLDialectsSQL方言3.5.2.外连接抓取(OuterJoinFetching)3.5.3.二进制流3.5.4.自定义CacheProvider3.5.5.事务策略配置3.5.6.绑定SessionFactory到JNDI3.5.7.查询语言替换3.6.Logging3.7.实现NamingStrategy(命名策略)3.8.XML配置文件4.持久化类(PersistentClasses)4.1.POJO简单示例4.1.1.为持久化字段声明访问器(accessors)和是否可变的标志(mutators)4.1.2.实现一个默认的构造方法(constructor)4.1.3.提供一个标识属性(identifierproperty)(可选)4.1.4.建议使用不是final的类(可选)4.2.实现继承(Inheritance)4.3.实现equals()和hashCode()4.4.持久化生命周期(Lifecycle)中的回调(Callbacks)4.5.合法性检查(Validatable)回调4.6.XDoclet标记示例5.O/RMapping基础5.1.映射声明(Mappingdeclaration)5.1.1.Doctype5.1.2.hibernate-mapping5.1.3.class5.1.4.id5.1.4.1.generator5.1.4.2.高/低位算法(Hi/LoAlgorithm)5.1.4.3.UUID算法(UUIDAlgorithm)5.1.4.4.标识字段和序列(IdentitycolumnsandSequences)5.1.4.5.程序分配的标识符(AssignedIdentifiers)5.1.5.composite-id联合ID5.1.6.识别器(discriminator)5.1.7.版本(version)(可选)5.1.8.时间戳(timestamp)(可选)5.1.9.property5.1.10.多对一(many-to-one)5.1.11.一对一5.1.12.组件(component),动态组件(dynamic-component)5.1.13.子类(subclass)5.1.14.连接的子类(joined-subclass)5.1.15.map,set,list,bag5.1.16.引用(import)5.2.Hibernate的类型5.2.1.实体(Entities)和值(values)5.2.2.基本值类型5.2.3.持久化枚举(Persistentenum)类型5.2.4.自定义值类型5.2.5.映射到"任意"(any)类型5.3.SQL中引号包围的标识符5.4.映射文件的模块化(Modularmappingfiles)6.集合类(Collections)映射6.1.持久化集合类(PersistentCollections)6.2.映射集合(MappingaCollection)6.3.值集合和多对多关联(CollectionsofValuesandMany-To-ManyAssociations)6.4.一对多关联(One-To-ManyAssociations)6.5.延迟初始化(延迟加载)(LazyInitializa
2025/6/15 21:44:18 262KB hibernate 教程 hibernate教程
1
简介:
在.NET框架中,C#语言的类(class)属于引用类型。
这意味着当你声明一个类的实例时,实际上是在堆上创建一个对象,并在栈上创建一个引用指向这个对象。
因此,当你将对象作为参数传递给函数时,实际上是传递了这个引用的副本,而不是对象本身。
这就是所谓的"传引用"或"按引用传递"。
让我们深入探讨一下这个问题,以标题和描述中给出的代码为例:```csharpclass Program{ static void Main(string[] args) { TestClass objA = new TestClass(); objA.Name = "I am ObjA"; Console.WriteLine(String.Format("In Main:{0}", objA.Name)); TestFun(objA); Console.WriteLine(String.Format("In Main:{0}", objA.Name)); Console.Read(); } static void TestFun(TestClass obj) { obj.Name = "I am be modified in TestFun"; Console.WriteLine(String.Format("In TestFun:{0}", obj.Name)); } public class TestClass { public string Name { get; set; } }}```在这个例子中,`TestFun`函数接收到`objA`的引用副本`obj`。
当在`TestFun`中修改`obj.Name`时,实际上是修改了`objA`引用的对象,因为它们都指向同一个堆上的实例。
因此,`Main`函数中再次打印`objA.Name`时,值已经被修改为"I am be modified in TestFun"。
然而,如果我们更改`TestFun`的实现:```csharpstatic void TestFun(TestClass obj){ TestClass objB = new TestClass(); obj = objB; obj.Name = "I am ObjB"; Console.WriteLine(String.Format("In TestFun:{0}", obj.Name));}```这里我们创建了一个新的`TestClass`实例`objB`,然后让`obj`引用`objB`。
虽然在`TestFun`内部`obj`的值改变了,但这不会影响`Main`函数中的`objA`,因为`objA`仍然指向原始的`TestClass`实例。
所以,`Main`函数中的`objA.Name`输出仍然是"I am ObjA",因为`objA`并没有被修改指向新创建的`objB`。
这个现象可以用内存模型来解释,就像描述中提到的那样。
在调用`TestFun`时,`objA`的地址被复制到`obj`,但是`objA`本身并未改变。
在`TestFun`中,`obj`被重新分配给`objB`的地址,但`objA`仍然指向原始对象,所以`Main`中的`objA`不会受到影响。
C#中的对象参数传递特性对于理解和调试代码非常重要。
理解这种行为可以帮助我们避免意外地修改了原本不想修改的对象,同时也能有效地利用引用传递来共享和修改数据。
在编写函数时,要清楚地知道参数是值类型(value type,如int、struct)还是引用类型(reference type,如class),因为这将直接影响到参数的处理方式和函数的行为。
2025/6/15 20:02:36 44KB
1
简介:
### 计算机二级等级考试知识点解析#### 1. HTML 中引入外部 CSS 文件的方式在 HTML 中,可以通过 `<link>` 标签引入外部 CSS 文件。
正确的格式是使用 `rel` 属性指定链接类型为 “stylesheet”,并通过 `href` 属性指向 CSS 文件的位置。
**示例代码**:```html<link rel="stylesheet" href="mystyle.css">```正确选项为 **B**。
#### 2. Python 中列表操作与异常处理在 Python 中,列表是一个有序的元素集合,支持多种操作,如添加、删除等。
此外,Python 支持异常处理机制来捕获并处理程序运行时可能出现的错误。
**示例代码**:```pythontry: num = eval(input("请输入一个列表:")) num.reverse() print(num)except: print("输入的不是列表")```在这个例子中,用户输入了一个逗号分隔的序列(例如 `1,2,3`),但是 `eval` 函数期望得到的是一个列表。
因此,该代码会抛出异常,并输出 “输入的不是列表”。
正确选项为 **D**。
#### 3. 操作系统与语言处理系统操作系统和语言处理系统(如编译器和解释器)都属于系统软件。
操作系统负责管理计算机硬件资源,为用户提供接口;
语言处理系统则负责将高级语言转换成机器码。
**知识点**:- **操作系统**: 管理硬件资源,提供用户接口。
- **语言处理系统**: 将高级语言翻译成机器码。
**结论**: 正确。
#### 4. 数据库表的基本属性数据库表是存储数据的基本单元,具有一定的结构特征。
**知识点**:- **表的记录与实体**: 每个表代表一类实体,表中的每一行对应一个实体。
- **关键字**: 用于唯一标识表中的记录。
- **索引**: 用于提高数据检索速度。
**结论**: 每个表都要有一个关键字以确保表中记录的唯一性。
正确选项为 **D**。
#### 5. ASP.NET 验证控件的特点ASP.NET 提供了多种验证控件来简化前端数据验证过程。
**知识点**:- **客户端验证与服务器端验证**: ASP.NET 验证控件可以在客户端进行初步验证,在服务器端进行最终验证。
- **多个验证控件**: 可以在一个页面中使用多个验证控件,确保数据的有效性。
- **兼容性**: 不同的浏览器可能对 JavaScript 的支持程度不同。
**结论**: ASP.NET 的验证控件仅能在服务器端进行验证。
正确选项为 **A**。
#### 6. VB 窗体文件扩展名VB (Visual Basic) 是一种广泛使用的编程语言,用于创建 Windows 应用程序。
**知识点**:- **窗体文件**: 包含窗体设计界面。
- **扩展名**: `.frm` 用于窗体文件。
**结论**: 正确选项为 **A**。
#### 7. 计算机处理的数据类型计算机处理的数据可以根据其性质和用途进行分类。
**知识点**:- **数值型数据**: 用于表示具体的数字,如整数、浮点数等。
**结论**: 正确选项为 **B**。
#### 8. 列表框和组合框中获取选中项的方法在编程中,列表框和组合框是用来显示多个选项的控件。
**知识点**:- **Text 属性**: 返回当前选中的列表项文本。
**结论**: 正确选项为 **C**。
#### 9. C++ 源程序文件扩展名C++ 是一种广泛使用的编程语言,支持面向对象编程。
**知识点**:- **源程序文件**: 含有 C++ 代码的文件。
- **扩展名**: `.cpp` 用于 C++ 源程序文件。
**结论**: 正确选项为 **A**。
#### 10. 客户机/服务器架构在计算机网络中,客户机/服务器架构是一种常见的通信模型。
**知识点**:- **客户机**: 发起请求的一方。
- **服务器**: 响应请求的一方。
**结论**: 错误,应该是客户机发起请求,服务器响应请求。
#### 11. VFP 中 AVERAGE 命令的使用Visual FoxPro (VFP) 是一种基于 SQL 的数据库管理系统。
**知识点**:- **AVERAGE 命令**: 计算平均值。
- **COPY STRUCTURE TO**: 复制表结构。
**结论**: 正确选项为 **B**。
#### 12. 建立表之间临时关系的要求在数据库中,表可以通过关系相互关联。
**知识点**:- **主控索引**: 用于建立表间关系的主要索引。
**结论**: 子表的主控索引用于建立临时关系。
正确选项为 **D**。
#### 13. Java 类的访问控制Java 是一种面向对象的编程语言,支持类的封装和继承。
**知识点**:- **访问控制**: 控制类的可见性。
**结论**: 如果一个类没有访问控制符,默认情况下它只在同一个包中可见。
正确选项为 **错误**。
#### 14. Java 条件语句的逻辑Java 支持多种条件语句,包括 if-else 和 switch-case。
**知识点**:- **条件判断**: 根据条件的不同分支执行不同的代码块。
**结论**: x 的取值范围为 `-3`。
正确选项为 **C**。
#### 15. 循环语句的种类循环语句用于重复执行一段代码直到满足特定条件为止。
**知识点**:- **for 循环**: 用于已知循环次数的情况。
- **while 循环**: 用于未知循环次数的情况。
**结论**: for 语句和 while 语句都属于循环语句。
正确选项为 **AC**。
#### 16. Python 中 divmod 函数的使用Python 提供了多种内置函数来简化编程任务。
**知识点**:- **divmod**: 返回除法的商和余数。
**结论**: 正确选项为 **D**。
#### 17. 面向对象编程的重要概念面向对象编程 (OOP) 是一种编程范式,强调对象的概念。
**知识点**:- **继承**: 允许创建一个类来继承另一个类的特性。
**结论**: 正确选项为 **C**。
#### 18. 对象属性的存在性在编程中,对象是一组属性和方法的集合。
**知识点**:- **Caption 属性**: 显示在对象上的文本。
**结论**: Timer 控件没有 Caption 属性。
正确选项为 **D**。
#### 19. Visual FoxPro 数组的定义与使用Visual FoxPro 支持数组,用于存储一组相关的数据。
**知识点**:- **数组定义**: 使用 `DIMENSION` 或 `DECLARE` 定义数组。
- **数据类型**: 数组中的元素可以是不同数据类型。
**结论**: 数组中的元素可以有不同的数据类型。
正确选项为 **C**。
#### 20. Visual FoxPro 中 SET EXACT OFF 的用法Visual FoxPro 中的 SET EXACT OFF 用于设置字符串比较模式。
**知识点**:- **字符串比较**: 控制字符串比较时是否区分大小写。
**结论**: 最后一条命令的输出结果为 `ABCD`。
正确选项为 **D**。
#### 21. Java 异常处理中的 catch 子句Java 提供了异常处理机制来处理程序中的错误情况。
**知识点**:- **异常处理**: 使用 try-catch-finally 结构。
- **catch 子句**: 捕获特定类型的异常。
**结论**: 应该将更具体的异常类放在前面。
正确选项为 **错误**。
#### 22. 字符串处理函数在编程中,经常需要对字符串进行操作,如去除空格等。
**知识点**:- **Trim 函数**: 删除字符串前后的空格。
**结论**: 正确选项为 **D**。
#### 23. C 语言中字符串长度的计算C 语言提供了一系列字符串处理函数。
**知识点**:- **strlen**: 计算字符串长度。
**结论**: 正确选项为 **C**。
#### 24. C 语言中的函数与返回值C 语言是一种广泛使用的编程语言,支持函数定义和调用。
**知识点**:- **return 语句**: 用于退出函数并返回结果。
- **函数调用**: 可以嵌套调用函数。
**结论**: 函数不一定必须有返回值。
正确选项为 **C**。
#### 25. 综合分析以上题目涵盖了计算机基础知识、编程语言特点、数据库管理和网络通信等多个方面,旨在全面测试考生的计算机应用能力。
2025/6/15 20:02:01 42KB
1
uint8_tProgram_verify(uint8_t*buff1,uint8_t*buff2,uint32_tcount);voidWB_Serial_NAND_Pageprogram_Pattern(uint8_taddh,uint8_taddl,uint8_t*program_buffer,uint32_tcount);voidWB_Serial_NAND_Program_Excute(uint8_taddh,uint8_taddl);/*statuscheck*/uint8_tWB_Check_Embedded_ECC();uint8_tWB_Check_Program_Erase_Fail_Flag();uint8_tWB_Read_Serial_NAND_StatusRegister(uint8_tsr_sel);voidWB_Serial_NAND_ReadyBusy_Check();uint32_tWB_NAND_Read_JEDEC_ID();uint8_tWB_Serial_NAND_bad_block_check(uint32_tpage_address);voidWB_Serial_NAND_LUT_Read(uint16_t*LBA,uint16_t*PBA);/*StackfunctionforW25Mseries*/voidWB_Die_Select(uint8_tselect_die);/*statusset*/voidWB_Enable_Embedded_ECC();voidWB_Disable_Embedded_ECC();voidWB_Enable_Buffer_mode();voidWB_Disable_Buffer_mode();voidWB_Serial_NAND_StatusRegister_Write_SR1(uint8_tSR1);voidWB_Serial_NAND_StatusRegister_Write_SR2(uint8_tSR2);voidWB_Serial_NAND_StatusRegister_Write_SR3(uint8_tSR3);voidWB_NAND_Reset();voidWB_Protect();voidWB_Unprotect();voidWB_Serial_NAND_LUT_Set(uint16_tLBA,uint16_tPBA);/*erasefunction*/voidWB_Serial_NAND_BlockErase(uint8_tPA_H,uint8_tPA_L);/*readfunction*/voidWB_Serial_NAND_PageDataRead(uint8_tPA_H,uint8_tPA_L);voidWB_Serial_NAND_Normal_Read(uint8_taddh,uint8_taddl,uint8_t*buff,uint32_tcount);voidWB_Serial_NAND_Continuous_Normal_Read(uint8_t*buff,uint32_tcount);
2025/6/11 15:24:57 7KB W25N01G
1
eclipse工程(编译通过,能运行)snmp4jAPIget,getnext,set,trap,取mib值实例
2025/5/31 15:42:36 2.13MB SNMP snmp4j trap
1
//********************************************************************#include "ps2.h"//********************************************************************#define clr_ps2_clk() (ps2_clk=0)#define set_ps2_clk() (ps2_clk=1)#define clr_ps2_data() (ps2_data=0)#define set_ps2_data() (ps2_data=1)#define db (1<<3)#define cmp_db() (P2^=db)#define set_db() (P2&=~db) #define clr_db() (P2|=db)//********************************************************************#define delay_5us nop;nop;nop;nop;nop;nop;nop;nop;nop;nop;#define delay_10us delay_5us;delay_5us#define delay_15us delay_5us;delay_10us#define delay_20us delay_10us;delay_5us#define delay_40us delay_20us;delay_15us#define delay_50us delay_40us;delay_10us//************************************************************************
2025/4/20 0:18:41 59KB ps/2 at89s52 开机自检 程序
1
前几天主要看了express,今天开始接触ejs,jade还是不想看了,O(∩_∩)O哈哈~varexpress=require(express);varejs=require('ejs');//varfs=require(fs);//varbodyParser=require('body-parser');varapp=express();app.engine('html',ejs.renderFile);app.set(viewengine,html);app.use(function(req,res,next)
2025/4/17 4:09:32 27KB ejs ex expr
1
这是我自己学习oracle的时候,写的代码案例和笔记,基本上每一个知识点都写的很清楚!大家可以作为参考!该有的知识点都有!基本的sql语法,触发器,存储过程,存储函数,流程控制,游标,异常处理,记录类型,视图,控制用户权限,高级子查询,set运算符,基本的sql_Select语句运算符,多表联查,排序,组函数,序列,索引,同义词,约束,创建和管理表,单行函数,过滤数据等等
2025/4/6 2:52:56 105KB oracle 触发器 存储函数 游标
1
LINGO是用来求解线性和非线性优化问题的简易工具。
LINGO内置了一种建立最优化模型的语言,可以简便地表达大规模问题,利用LINGO高效的求解器可快速求解并分析结果。
§1LINGO快速入门当你在windows下开始运行LINGO系统时,会得到类似下面的一个窗口:外层是主框架窗口,包含了所有菜单命令和工具条,其它所有的窗口将被包含在主窗口之下。
在主窗口内的标题为LINGOModel–LINGO1的窗口是LINGO的默认模型窗口,建立的模型都都要在该窗口内编码实现。
下面举两个例子。
例1.1如何在LINGO中求解如下的LP问题:在模型窗口中输入如下代码:min=2*x1+3*x2;x1+x2>=350;x1>=100;2*x1+x2<=600;然后点击工具条上的按钮即可。
例1.2使用LINGO软件计算6个发点8个收点的最小费用运输问题。
产销单位运价如下表。
单位销地运价产地 B1 B2 B3 B4 B5 B6 B7 B8 产量A1 6 2 6 7 4 2 5 9 60A2 4 9 5 3 8 5 8 2 55A3 5 2 1 9 7 4 3 3 51A4 7 6 7 3 9 2 7 1 43A5 2 3 9 5 7 2 6 5 41A6 5 5 2 2 8 1 4 3 52销量 35 37 22 32 41 32 43 38 使用LINGO软件,编制程序如下:model:!6发点8收点运输问题;sets:warehouses/wh1..wh6/:capacity;vendors/v1..v8/:demand;links(warehouses,vendors):cost,volume;endsets!目标函数;min=@sum(links:cost*volume);!需求约束;@for(vendors(J):@sum(warehouses(I):volume(I,J))=demand(J));!产量约束;@for(warehouses(I):@sum(vendors(J):volume(I,J))<=capacity(I));!这里是数据;data:capacity=605551434152;demand=3537223241324338;cost=626742954953858252197433767392712395726555228143;enddataend然后点击工具条上的按钮即可。
为了能够使用LINGO的强大功能,接着第二节的学习吧。
§2LINGO中的集对实际问题建模的时候,总会遇到一群或多群相联系的对象,比如工厂、消费者群体、交通工具和雇工等等。
LINGO允许把这些相联系的对象聚合成集(sets)。
一旦把对象聚合成集,就可以利用集来最大限度的发挥LINGO建模语言的优势。
现在我们将深入介绍如何创建集,并用数据初始化集的属性。
学完本节后,你对基于建模技术的集如何引入模型会有一个基本的理解。
2.1为什么使用集集是LINGO建模语言的基础,是程序设计最强有力的基本构件。
借助于集,能够用一个单一的、长的、简明的复合公式表示一系列相似的约束,从而可以快速方便地表达规模较大的模型。
2.2什么是集集是一群相联系的对象,这些对象也称为集的成员。
一个集可能是一系列产品、卡车或雇员。
每个集成员可能有一个或多个与之有关联的特征,我们把这些特征称为属性。
属性值可以预先给定,也可以是未知的,有待于LINGO求解。
例如,产品集中的每个产品可以有一个价格属性;
卡车集中的每辆卡车可以有一个牵引力属性;
雇员集中的每位雇员可以有一个薪水属性,也可以有一个生日属性等等。
LINGO有两种类型的集:原始集(primitive set)和派生集(derivedset)。
一个原始集是由一些最基本的对象组成的。
一个派生集是用一个或多个其它集来定义的,也就是说,它的成员来自于其它已存在的集。
2.3模型的集部分集部分是LINGO模型的一个可选部分。
在LINGO模型中使用集之前,必须在集部分事先定义。
集部分以关键字“sets:”开始,以“endsets”结束。
一个模型可以没有集部分,或有一个简单的集部分,或有多个集部分。
一个集部分可以放置于模型的任何地方,但是一个集及其属性
1
题目:7.集合运算(单循环链表)1.问题描述:设有两个带头结点的单循环链表存储的集合A、B,其元素类型为字符或者整形,且以非递减方式存储,其头结点分别为ha、hb。
要求下面各问题中的结果集合同样以非递减方式存储,结果集合不影响原集合。
2.实现要求:⑶编写集合元素测试函数IN_SET,如果元素已经在集合中返回0,否则返回1;
⑷编写集合元素输入并插入到单链表中的函数INSERT_SET,保证所输入的集合中的元素是唯一且以非递减方式存储在单循环链表中;
⑶编写求集合A、B的交C=A∩B的函数,并输出集合C的元素;
⑷编写求集合A、B的并D=A∪B的函数,并输出集合D的元素;
⑸求集合A与B的对称差E=(A-B)∪(B-A)的函数,并输出集合D的元素;
⑹设计一个菜单,具有输入集合元素、求集合A、B的交C、求集合A、B的并D、求集合A与B的对称差E、退出等基本的功能。
3.测试数据:字符型和整形由同学们自定,但集合A、B的元素个数不得少于15个。
2025/3/20 4:44:03 374KB 数据结构
1
共 98 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡