- Verilator 的文件目录结构(腾讯元宝)
dadaobusi
verilator
当然可以!我们来详细分析Verilator的Git仓库(GitHub上的官方仓库:https://github.com/verilator/verilator)的文件目录结构,帮助你理解它的代码组织方式以及各个部分的功能。一、Verilator的Git仓库概览Verilator是一个用C++编写的高性能Verilog/SystemVerilogRTL仿真器,其源代码仓库结构清晰,模块化程度较高。整
- verilator如何实现RTL的仿真(腾讯混元)
Verilator是一个用于将Verilog或SystemVerilogRTL(寄存器传输级)代码转换为C++或SystemC模型的工具,主要用于高性能的功能仿真和验证。它不是像ModelSim或VCS那样的传统事件驱动仿真器,而是通过静态编译的方式将RTL转换为可执行的C++代码,从而实现高效仿真。下面详细介绍Verilator实现RTL仿真的流程与实现细节。一、Verilator的基本工作流程
- SystemVerilog LRM 学习笔记 -- clocking块
1clocking...endclocking块clocking块是SV新feature,主要是为了更好解决testbench和DUT之间的timing和同步建模的问题,可以使user基于clockcycle在更高的抽象层次上写testbench(如“##3”,表示三个clock)。clocking只能在module/interface/checker/program中声明,不能在function
- system Verilog:clocking中定义信号为input和output的区别
加载-ing
systemverilog
在SystemVerilog中,clocking块用于定义时钟块,这通常用于描述时钟边缘和同步的输入/输出行为,特别是在测试平台和硬件接口描述中。在下述两个代码示例中,主要区别在于a被定义为一个input还是output。当a被定义为input时:systemverilogclockingcb@(posedgeclk);inputa;endclocking这意味着a是一个从被测试设计(DUT)到测
- [SystemVerilog] Clocking
S&Z3463
SystemVerilogfpga开发
SystemVerilogClocking用法详解SystemVerilog的clocking块(ClockingBlock)是一种专门用于定义信号时序行为的构造,主要用于验证环境(如UVM)中,以精确控制信号的采样和驱动时序。clocking块通过将信号与特定时钟关联,简化了测试环境中对时序敏感信号的处理,减少了手动时序管理的复杂性。本文将详细介绍SystemVerilog中clocking块的
- 【数字IC前端笔试真题精刷(2022.7.28)】芯动——数字IC验证工程师(1号卷-验证)
ReRrain
#数字IC笔试
声明:本专栏所收集的数字IC笔试题目均来源于互联网,仅供学习交流使用。如有侵犯您的知识产权,请及时与博主联系,博主将会立即删除相关内容。笔试时间:2022-7-28;题目类型:不定项(10x1’=10’)【错选不得分,少选得1/3分】问答(9x10’=90’)文章目录不定项1、(单选)在verilog语言中,a=4'b1011,那么&a=()2、(单选)SystemVerilog中类默认的成员属性
- 实现SystemVerilog动态进程的互斥访问
iccnewer
在计算机系统设计中,多个并行进程之间共享内存资源是一个经典问题。就像生活中多个人同时使用一个厨房一样,如果没有合理的协调机制,很容易造成混乱。SystemVerilog标准提供了内置的semaphore类来实现互斥访问,看起来是个不错的解决方案。但这个方案有个明显的缺点:缺乏内建的安全检查机制,开发者可能会无意中向semaphore创建更多的keys,这种不安全的使用方式可能导致系统的不稳定。利用
- System-Verilog 实现DE2-115 流水灯
qwert_qqq
物联网学习fpga开发
文章目录一、什么是SystemVerilog二、代码实现实现结果一、什么是SystemVerilogSystemVerilog是一种硬件描述语言(HDL),它用于设计和验证电子系统,特别是在集成电路(IC)和系统级芯片(SoC)的设计过程中。SystemVerilog是Verilog语言的一个超集,它添加了许多新的特性和增强功能,使得设计者可以更高效地进行工作。应用领域:集成电路设计:System
- 实验报告:在DE2-115开发板上使用SystemVerilog编写流水灯程序
追寻自己521
fpga开发单片机嵌入式硬件
在DE2-115开发板上使用SystemVerilog编写流水灯程序1.实验目标本实验旨在通过使用SystemVerilog重新设计和实现流水灯程序,并在DE2-115开发板上进行验证。同时,使用testbench进行仿真以确保设计的正确性。2.实验器材DE2-115开发板QuartusPrime开发软件ModelSim仿真软件3.SystemVerilog代码3.1流水灯设计systemveri
- FPGA基础 -- Verilog函数
sz66cm
FPGA基础fpga开发
Verilog函数(function)目标:让具备一般RTL经验的工程师,系统掌握Verilog函数的语法、约束、可综合写法以及在实际项目中的高效用法,为后续SystemVerilog及HLS设计奠定基础。1为什么要用函数?设计痛点函数带来的价值重复逻辑:CRC、Parity、优先编码等往往在多个模块出现将共用运算封装为函数,避免复制粘贴,减少Bug概率可读性差:长表达式嵌套写在连线或always
- new()和new[]有什么区别?
new()和new[]有什么区别?1、new[]的使用较为简单,一般用来开辟内存并初始化,常用于设置动态数组的大小。inta[];//声明动态数组initialbegina=new[3];//为动态数组分配3个元素foreach(a[i])a[i]=i;//元素初始化end2、new()用在systemverilog中OOP的构造函数;构造函数除了分配内存外,还初始化变量,在默认情况下,将变量设置
- FPGA基础 -- Verilog语言要素之数组
sz66cm
fpga开发
Verilog是一种用于硬件建模的硬件描述语言(HDL),其数组机制不同于软件语言,须考虑硬件资源映射、综合约束、位宽优化等硬件特性。以下是对Verilog中数据类型的数组使用的全面讲解,分为一维数组、二维数组、memory数组、reg与wire中数组的差异、packed与unpacked数组(SystemVerilog)等方面,并指出综合注意事项与最佳实践。一、Verilog数组的分类1.一维数
- 【SystemVerilog 2023 Std】第5章 词法约定 Lexical conventions (1)
绫韵枫汐
SystemVerilog2023标准中译本笔记学习开发语言
参考资料:IEEEStd1800-2023标准《IEEEStandardforSystemVerilog—UnifiedHardwareDesign,Specification,andVerificationLanguage》文章目录5.1General5.2Lexicaltokens5.3Whitespace5.4Comments5.5Operators5.6Identifiers,keywor
- AES-GCM和SM4-GCM工作原理及数据加解密验证方案详解
元直数字电路验证
PCIe/UCIe学习笔记国密算法数据加解密PCIe加密传输
AES-GCM和SM4-GCM工作原理及数据加解密验证方案详解下面分三部分给出:AES-GCM/SM4-GCM原理梳理基于OpenSSL的C语言ReferenceModel(可编译成DPI-C动态库)SystemVerilogDPI调用示例1.AES-GCM与SM4-GCM工作原理1.1GCM模式总体架构GCM(Galois/CounterMode)是一种同时提供加密(Confidentialit
- SystemVerilog—semaphore和mailbox为什么要使用new?
余大大.
UVM验证开发语言笔记
SystemVerilog中semaphore(旗语)和mailbox(信箱)需要通过new()方法进行实例化的原因,主要与其面向对象的设计特性、动态内存管理及线程安全需求相关。一、面向对象特性与动态内存分配内置类(Built-inClass)的实例化需求semaphore和mailbox是SystemVerilog的内置类(类似于C++的类),必须通过new()构造函数创建对象实例后才能使用。这
- AMBA_APB_SRAM 项目常见问题解决方案
仰书唯Elise
AMBA_APB_SRAM项目常见问题解决方案AMBA_APB_SRAMAMBAv.3APBv.1SpecificationComplaintSlaveSRAMCoredesignandtestbench.ThetestbenchisdevelopedusingSystemVerilogandUVMandcanbeusedasstandaloneVerificationIP(VIP).项目地址:h
- 数字FPGA开发方向,该如何做好职业规划?
IC与FPGA设计
FPGAfpga开发
近年来,随着国产化浪潮和AI、边缘计算等新兴应用的兴起,FPGA行业热度持续上升,越来越多的工程师转向FPGA方向发展。我们也发现有不少同学对职业规划非常迷茫。作为FPGA行业多年的从业者,在此希望能够给大家一些经验建议。掌握好基本技能作为一个真正合格的FPGA开发工程师,你永远都需要不断学习更加先进的知识和技术。语言类Verilog/VHDLSystemVerilog(主要用于设计而非验证)Tc
- 关于systemverilog中在task中使用force语句的注意事项
一只迷茫的小狗
Systemverilogsystemverilog
先看下面的代码moduletop(data);logicclk;inoutdata;logictemp;logicsampale_data;logic[7:0]data_rec;tasksend_data(input[7:0]da);begin@(posedgeclk);#1;forcedata=da[7];$display(data);@(posedgeclk);#1;forcedata=da[
- SystemVerilog中的断言(Assertion)
请叫我去学习5555
SystemVerilog数据库前端
1.简介SystemVerilog断言(SVA)主要是用于验证设计的行为,其主要功能有两点:在特定条件或事件序列的故障上生成警告或错误;收集功能覆盖率的数据。2.立即断言(ImmediateAssertion)立即断言执行时如同过程语句,她在程序执行到这个程序块使立即执行,并且可以结合$fatal,$error,$warning和$info函数给出不同级别的消息提示。断言比if语句更加紧凑,且断言
- System Verilog 断言, SVA
范吉民(DY Young)
芯片设计java前端数据库
一、引言1.1研究背景与目的在当今的数字集成电路设计领域,随着芯片规模和复杂度的飞速增长,硬件设计验证面临着前所未有的挑战。传统的验证方法在面对复杂的设计时,往往难以确保设计的正确性和可靠性。SystemVerilogAssertion(SVA)作为一种强大的硬件验证技术应运而生,它为硬件设计验证提供了一种高效、准确的方式。本研究旨在深入探讨SystemVerilogAssertion的概念、原理
- 【systemverilog】学习笔记--断言篇
跛子拜
systemverilogsystemverilog
【systemverilog】学习笔记--断言篇断言1:判断信号值断言1:判断信号值CHECK_VALUE:assertproperty(@(posedgeclk)disableiff(!rst_n)\\屏蔽复位前的不定态(a!==1'bx))else$fatal("ERROR:detectedaXvalue!!\n");
- CPU0 verilog代码全注释
silenci
llvmcpu0verilogllvmllvm后端
//https://www.francisz.cn/download/IEEE_Standard_1800-2012%20SystemVerilog.pdf//configuablevaluebelow/*加入延迟槽,比如if(a>b+c)这条语句,只有执行到的时候才能判断是否跳转,但是CPU又是流水线执行的,所以要在这条指令之前加入延迟槽,防止后续的指令提前执行,等到if中的判断执行之后,确定了
- TestBench激励与待测
谢谢~谢先生
FPGAfpga开发
TestBench激励与待测✅一、TestBench的作用✅二、例化的目的✅三、TestBench中的信号类型选择输入端口(input)→在TestBench中声明为`reg`输出端口(output)→在TestBench中声明为`wire`✅四、例化方式示例✅五、总结✅六、附加建议你的这段内容描述了在Verilog或SystemVerilog中编写TestBench(测试平台)时,如何正确地对待
- Emacs Verilog-mode 核心功能与使用指南
yang_20250429
emacs编辑器
一、基本概念与背景1、功能定位Verilog-mode是Emacs专门为Verilog/SystemVerilog开发设计的插件12,支持包括UVM验证框架在内的硬件设计语言特性。其核心功能包括:语法高亮:区分关键字、注释、端口等元素自动缩进与格式化:根据代码层级智能调整缩进AUTO宏系统:自动生成模块端口、信号连接等重复代码2、开发者背景由MichaelMcNamara和WilsonSnyder
- [SystemVerilog] Functions
S&Z3463
SystemVerilogfpga开发SystemVerilog
SystemVerilogFunctions用法详解SystemVerilog的function是一种过程性构造,用于封装一组无时间延迟的计算或操作逻辑,返回单一结果。function与task相比不支持时间控制(如#或@),适合执行快速、确定性的计算。function在硬件设计和验证中广泛使用,特别是在需要计算值、转换数据或检查条件的场景。本文将详细介绍SystemVerilog中functio
- [SystemVerilog] Struct
S&Z3463
SystemVerilogfpga开发
SystemVerilogStruct用法详解SystemVerilog的struct是一种复合数据类型,用于将多个不同类型的变量(成员)组织成一个单一的实体。struct在硬件设计和验证中广泛使用,特别适合表示复杂的数据结构,如数据包、配置寄存器或状态信息。与联合体(union)和类(class)相比,struct提供了静态、紧凑的数据组织方式,并且支持综合。本文将详细介绍SystemVeril
- SystemVerilog语法之内建数据类型
cucoder
SystemVerilog语法fpga开发
简介:SystemVerilog引进了一些新的数据类型,具有以下的优点:(1)双状态数据类型,更好的性能,更低的内存消耗;(2)队列、动态和关联数组,减少内存消耗,自带搜索和分类功能。(3)类和结构:支持抽象数据结构。(4)联合和合并结构:允许对同一数据有多种视图。(5)字符串:支持内建的字符序列。(6)枚举类型:方便代码编写,增加可读性。1.1内建数据类型Verilog-1995有两种基本数据类
- FPGA(现场可编程门阵列)笔记
睡觉然后上课
fpga开发笔记嵌入式硬件
*编程语言-[Verilog]:硬件描述语言,语法风格类似于C语言,用于数字电路的设计。-[SystemVerilog]:扩展自Verilog,增加了面向对象编程等特性,语法更接近于C++,适用于复杂系统设计。-[VHDL]:另一种硬件描述语言,其语法结构与Pascal相似。*与软件的区别-软件使用语言写流程,主要关注算法和流程控制,FPGA用语言写逻辑电路。*FPGA厂商-[Altera(Int
- SystemVerilog之线程间通信
青春猪头ic少年梦不到兔女郎师姐
开发语言
SystemVerilog中的线程(Thread)是仿真过程中并发执行的基本单元,用于描述硬件或验证平台的并发行为。在复杂的数字系统验证中,多线程协同工作是实现高效验证的关键。SystemVerilog提供了强大的线程控制机制和多种线程间通信(Inter-ProcessCommunication,IPC)方法,能够有效解决并发执行中的同步与数据交换问题。本文深入探讨SystemVerilog中的事
- #SVA语法滴水穿石# (004)关于 ended 和 triggered 用法
那么菜
SVASVA
在SystemVerilog断言(SVA,SystemVerilogAssertions)中,ended是一个用于序列(sequence)的关键字,它表示某个序列(sequence)在特定时间点已经成功匹配(即“结束”)。ended主要用于同步不同序列的时间关系,尤其是在多序列组合或属性(property)中需要对齐时序的场景。1.基本定义sequence.ended:表示指定的序列(sequen
- PHP,安卓,UI,java,linux视频教程合集
cocos2d-x小菜
javaUIPHPandroidlinux
╔-----------------------------------╗┆
- 各表中的列名必须唯一。在表 'dbo.XXX' 中多次指定了列名 'XXX'。
bozch
.net.net mvc
在.net mvc5中,在执行某一操作的时候,出现了如下错误:
各表中的列名必须唯一。在表 'dbo.XXX' 中多次指定了列名 'XXX'。
经查询当前的操作与错误内容无关,经过对错误信息的排查发现,事故出现在数据库迁移上。
回想过去: 在迁移之前已经对数据库进行了添加字段操作,再次进行迁移插入XXX字段的时候,就会提示如上错误。
&
- Java 对象大小的计算
e200702084
java
Java对象的大小
如何计算一个对象的大小呢?
 
- Mybatis Spring
171815164
mybatis
ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
CustomerService userService = (CustomerService) ac.getBean("customerService");
Customer cust
- JVM 不稳定参数
g21121
jvm
-XX 参数被称为不稳定参数,之所以这么叫是因为此类参数的设置很容易引起JVM 性能上的差异,使JVM 存在极大的不稳定性。当然这是在非合理设置的前提下,如果此类参数设置合理讲大大提高JVM 的性能及稳定性。 可以说“不稳定参数”
- 用户自动登录网站
永夜-极光
用户
1.目标:实现用户登录后,再次登录就自动登录,无需用户名和密码
2.思路:将用户的信息保存为cookie
每次用户访问网站,通过filter拦截所有请求,在filter中读取所有的cookie,如果找到了保存登录信息的cookie,那么在cookie中读取登录信息,然后直接
- centos7 安装后失去win7的引导记录
程序员是怎么炼成的
操作系统
1.使用root身份(必须)打开 /boot/grub2/grub.cfg 2.找到 ### BEGIN /etc/grub.d/30_os-prober ### 在后面添加 menuentry "Windows 7 (loader) (on /dev/sda1)" { 
- Oracle 10g 官方中文安装帮助文档以及Oracle官方中文教程文档下载
aijuans
oracle
Oracle 10g 官方中文安装帮助文档下载:http://download.csdn.net/tag/Oracle%E4%B8%AD%E6%96%87API%EF%BC%8COracle%E4%B8%AD%E6%96%87%E6%96%87%E6%A1%A3%EF%BC%8Coracle%E5%AD%A6%E4%B9%A0%E6%96%87%E6%A1%A3 Oracle 10g 官方中文教程
- JavaEE开源快速开发平台G4Studio_V3.2发布了
無為子
AOPoraclemysqljavaeeG4Studio
我非常高兴地宣布,今天我们最新的JavaEE开源快速开发平台G4Studio_V3.2版本已经正式发布。大家可以通过如下地址下载。
访问G4Studio网站
http://www.g4it.org
G4Studio_V3.2版本变更日志
功能新增
(1).新增了系统右下角滑出提示窗口功能。
(2).新增了文件资源的Zip压缩和解压缩
- Oracle常用的单行函数应用技巧总结
百合不是茶
日期函数转换函数(核心)数字函数通用函数(核心)字符函数
单行函数; 字符函数,数字函数,日期函数,转换函数(核心),通用函数(核心)
一:字符函数:
.UPPER(字符串) 将字符串转为大写
.LOWER (字符串) 将字符串转为小写
.INITCAP(字符串) 将首字母大写
.LENGTH (字符串) 字符串的长度
.REPLACE(字符串,'A','_') 将字符串字符A转换成_
- Mockito异常测试实例
bijian1013
java单元测试mockito
Mockito异常测试实例:
package com.bijian.study;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import org.junit.Assert;
import org.junit.Test;
import org.mockito.
- GA与量子恒道统计
Bill_chen
JavaScript浏览器百度Google防火墙
前一阵子,统计**网址时,Google Analytics(GA) 和量子恒道统计(也称量子统计),数据有较大的偏差,仔细找相关资料研究了下,总结如下:
为何GA和量子网站统计(量子统计前身为雅虎统计)结果不同?
首先:没有一种网站统计工具能保证百分之百的准确出现该问题可能有以下几个原因:(1)不同的统计分析系统的算法机制不同;(2)统计代码放置的位置和前后
- 【Linux命令三】Top命令
bit1129
linux命令
Linux的Top命令类似于Windows的任务管理器,可以查看当前系统的运行情况,包括CPU、内存的使用情况等。如下是一个Top命令的执行结果:
top - 21:22:04 up 1 day, 23:49, 1 user, load average: 1.10, 1.66, 1.99
Tasks: 202 total, 4 running, 198 sl
- spring四种依赖注入方式
白糖_
spring
平常的java开发中,程序员在某个类中需要依赖其它类的方法,则通常是new一个依赖类再调用类实例的方法,这种开发存在的问题是new的类实例不好统一管理,spring提出了依赖注入的思想,即依赖类不由程序员实例化,而是通过spring容器帮我们new指定实例并且将实例注入到需要该对象的类中。依赖注入的另一种说法是“控制反转”,通俗的理解是:平常我们new一个实例,这个实例的控制权是我
- angular.injector
boyitech
AngularJSAngularJS API
angular.injector
描述: 创建一个injector对象, 调用injector对象的方法可以获得angular的service, 或者用来做依赖注入. 使用方法: angular.injector(modules, [strictDi]) 参数详解: Param Type Details mod
- java-同步访问一个数组Integer[10],生产者不断地往数组放入整数1000,数组满时等待;消费者不断地将数组里面的数置零,数组空时等待
bylijinnan
Integer
public class PC {
/**
* 题目:生产者-消费者。
* 同步访问一个数组Integer[10],生产者不断地往数组放入整数1000,数组满时等待;消费者不断地将数组里面的数置零,数组空时等待。
*/
private static final Integer[] val=new Integer[10];
private static
- 使用Struts2.2.1配置
Chen.H
apachespringWebxmlstruts
Struts2.2.1 需要如下 jar包: commons-fileupload-1.2.1.jar commons-io-1.3.2.jar commons-logging-1.0.4.jar freemarker-2.3.16.jar javassist-3.7.ga.jar ognl-3.0.jar spring.jar
struts2-core-2.2.1.jar struts2-sp
- [职业与教育]青春之歌
comsci
教育
每个人都有自己的青春之歌............但是我要说的却不是青春...
大家如果在自己的职业生涯没有给自己以后创业留一点点机会,仅仅凭学历和人脉关系,是难以在竞争激烈的市场中生存下去的....
&nbs
- oracle连接(join)中使用using关键字
daizj
JOINoraclesqlusing
在oracle连接(join)中使用using关键字
34. View the Exhibit and examine the structure of the ORDERS and ORDER_ITEMS tables.
Evaluate the following SQL statement:
SELECT oi.order_id, product_id, order_date
FRO
- NIO示例
daysinsun
nio
NIO服务端代码:
public class NIOServer {
private Selector selector;
public void startServer(int port) throws IOException {
ServerSocketChannel serverChannel = ServerSocketChannel.open(
- C语言学习homework1
dcj3sjt126com
chomework
0、 课堂练习做完
1、使用sizeof计算出你所知道的所有的类型占用的空间。
int x;
sizeof(x);
sizeof(int);
# include <stdio.h>
int main(void)
{
int x1;
char x2;
double x3;
float x4;
printf(&quo
- select in order by , mysql排序
dcj3sjt126com
mysql
If i select like this:
SELECT id FROM users WHERE id IN(3,4,8,1);
This by default will select users in this order
1,3,4,8,
I would like to select them in the same order that i put IN() values so:
- 页面校验-新建项目
fanxiaolong
页面校验
$(document).ready(
function() {
var flag = true;
$('#changeform').submit(function() {
var projectScValNull = true;
var s ="";
var parent_id = $("#parent_id").v
- Ehcache(02)——ehcache.xml简介
234390216
ehcacheehcache.xml简介
ehcache.xml简介
ehcache.xml文件是用来定义Ehcache的配置信息的,更准确的来说它是定义CacheManager的配置信息的。根据之前我们在《Ehcache简介》一文中对CacheManager的介绍我们知道一切Ehcache的应用都是从CacheManager开始的。在不指定配置信
- junit 4.11中三个新功能
jackyrong
java
junit 4.11中两个新增的功能,首先是注解中可以参数化,比如
import static org.junit.Assert.assertEquals;
import java.util.Arrays;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runn
- 国外程序员爱用苹果Mac电脑的10大理由
php教程分享
windowsPHPunixMicrosoftperl
Mac 在国外很受欢迎,尤其是在 设计/web开发/IT 人员圈子里。普通用户喜欢 Mac 可以理解,毕竟 Mac 设计美观,简单好用,没有病毒。那么为什么专业人士也对 Mac 情有独钟呢?从个人使用经验来看我想有下面几个原因:
1、Mac OS X 是基于 Unix 的
这一点太重要了,尤其是对开发人员,至少对于我来说很重要,这意味着Unix 下一堆好用的工具都可以随手捡到。如果你是个 wi
- 位运算、异或的实际应用
wenjinglian
位运算
一. 位操作基础,用一张表描述位操作符的应用规则并详细解释。
二. 常用位操作小技巧,有判断奇偶、交换两数、变换符号、求绝对值。
三. 位操作与空间压缩,针对筛素数进行空间压缩。
&n
- weblogic部署项目出现的一些问题(持续补充中……)
Everyday都不同
weblogic部署失败
好吧,weblogic的问题确实……
问题一:
org.springframework.beans.factory.BeanDefinitionStoreException: Failed to read candidate component class: URL [zip:E:/weblogic/user_projects/domains/base_domain/serve
- tomcat7性能调优(01)
toknowme
tomcat7
Tomcat优化: 1、最大连接数最大线程等设置
<Connector port="8082" protocol="HTTP/1.1"
useBodyEncodingForURI="t
- PO VO DAO DTO BO TO概念与区别
xp9802
javaDAO设计模式bean领域模型
O/R Mapping 是 Object Relational Mapping(对象关系映射)的缩写。通俗点讲,就是将对象与关系数据库绑定,用对象来表示关系数据。在O/R Mapping的世界里,有两个基本的也是重要的东东需要了解,即VO,PO。
它们的关系应该是相互独立的,一个VO可以只是PO的部分,也可以是多个PO构成,同样也可以等同于一个PO(指的是他们的属性)。这样,PO独立出来,数据持