- CopyOnWriteArrayList源码分析
仙草不加料
javajvmCOWReentrantLock
概述CopyOnWriteArrayList是一个线程安全的集合,当我们对集合容器使用增删改操作时,并不是直接对方法进行加锁,在原集合进行操作,而是通过复制出一个新集合,然后在新集合中进行操作,操作结束后,将原集合容器的引用指向新的集合容器,所以他能实现写入时的线程安全,但不影响并发的读取操作,所以适用于读多写少的场景,是一种读写分离的思想。但是由于每个操作都需要拷贝原集合,数据较大的时候容易引起
- 【转】-Java并发编程:阻塞队列
booleandev
JUCJava转载
Java并发编程:阻塞队列该博客转载自**Matrix海子的Java并发编程:阻塞队列**Java并发编程:阻塞队列在前面几篇文章中,我们讨论了同步容器(Hashtable、Vector),也讨论了并发容器(ConcurrentHashMap、CopyOnWriteArrayList),这些工具都为我们编写多线程程序提供了很大的方便。今天我们来讨论另外一类容器:阻塞队列。在前面我们接触的队列都是非
- JAVA高并发——JDK的并发容器
布道师小羊
#网络+并发+函数式+JVMJAVA高阶java开发语言
文章目录1、超好用的工具类:并发集合简介2、线程安全的HashMap3、深入浅出ConcurrentHashMap3.1、ConcurrentHashMap的内部数据结构3.2、put()方法的实现3.3、get()方法的实现4、有关List的线程安全5、高效读写的队列:深度剖析ConcurrentLinkedQueue类6、高效读取:不变模式下的CopyOnWriteArrayList类7、数据
- 每日五道java面试题之java基础篇(八)
中北萌新程序员
java面试题java开发语言面试
第一题.CopyOnWriteArrayList的底层原理是怎样的⾸先CopyOnWriteArrayList内部也是⽤过数组来实现的,在向CopyOnWriteArrayList添加元素时,会复制⼀个新的数组,写操作在新数组上进⾏,读操作在原数组上进⾏并且,写操作会加锁,防⽌出现并发写⼊丢失数据的问题写操作结束之后会把原数组指向新数组CopyOnWriteArrayList允许在写操作时来读取数
- 多线程并发编程10-CopyOnWriteArrayList源码剖析
Demo_zfs
今天来说一说CopyOnWriteArrayList类,纵观JUC包下并发List只有CopyOnWriteArrayList类。CopyOnWriteArrayList是一个线程安全的ArrayList,从它的命名也能看出在进行写操作的时候会进行复制,这种写时复制策略会产生弱一致性问题。下面对CopyOnWriteArrayList类继续剖析。在CopyOnWriteArrayList类中都是围
- 解释Java中的并发集合类,比如ConcurrentHashMap和CopyOnWriteArrayList
顶碗冷笑话
javajava开发语言学习面试算法
解释Java中的并发集合类,比如ConcurrentHashMap和CopyOnWriteArrayList在Java中,有许多用于并发编程的集合类,它们提供了线程安全的操作,可以在多线程环境中安全地访问和修改数据。两个常见的并发集合类是ConcurrentHashMap和CopyOnWriteArrayList。ConcurrentHashMap:ConcurrentHashMap是一个线程安全
- 为啥线程安全的List推荐使用CopyOnWriteArrayList,不是Vector?
废柴程序员
为什么线程安全的List推荐使用CopyOnWriteArrayList,而不是Vector?注:本系列文章中用到的jdk版本均为java8相比很多同学在刚接触Java集合的时候,线程安全的List用的一定是Vector。但是现在用到的线程安全的List一般都会用CopyOnWriteArrayList,很少有人再去用Vector了,至于为什么,文章中会具体说到。接下来,我们先来简单分析一下Vec
- java并发集合的一些坑
十倍光速
用ScheduledExecutorService并发计算相似度,结果要放到同一个集合,然后再进行排序。试了vector,CopyOnWriteArrayList等集合,都会出现随机的数据丢失,然后写了一个ConcurrentArrayList,也是会有数据丢失。最后还是想办法换回ConcurrentHashMap,数据不丢失了,问题解决,看来还是ConcurrentHashMap比较靠谱。但是发
- 并发容器(Map、List、Set)实战及其原理
Myname_China
并发编程数据结构Java数据结构并发编程java
目录JUC包下的并发容器CopyOnWriteArrayList应用场景CopyOnWriteArrayList使用CopyOnWriteArrayList原理CopyOnWriteArrayList的缺陷扩展知识:迭代器的fail-fast与fail-safe机制ConcurrentHashMap应用场景ConcurrentHashMap使用数据结构ConcurrentSkipListMap跳表
- java-JUC并发编程学习笔记05(尚硅谷)
抹茶味的西瓜汁
多线程并发编程学习笔记
我们写一段测试代码:会出现线程不安全的问题。使用Vector解决线程不安全问题:但是这个类几乎不会被使用了,因为效率太低。方法二:通过Collections解决:但是这种方案实际中也不太会使用。我们还有第三种方法使用CopyOnWriteArrayList:HashSet线程不安全的解决方案:也会出现异常。我们要怎么解决呢?HashMap线程不安全演示:也会出现异常。
- CopyOnWriteArrayList源码分析
不随意的风
JUCjava数据结构开发语言
介绍:CopyOnWriteArrayList是一个线程安全的ArrayList,它在每次修改(add/set/remove)时创建数组的新副本,然后将修改应用到新数组上。这是它名字的由来:“CopyOnWrite”。这种设计使得它在多线程环境下能提供更好的并发性能。当一个线程修改列表时,其他线程不能访问旧数组,因此不会受到数据不一致的影响。然而,写操作的代价是创建新数组并复制所有元素,这可能在大
- Java多线程
我但行好事莫问前程
java开发语言
1.线程安全的集合有哪些?Java中提供了多种线程安全的集合类,它们位于java.util.concurrent包下。以下是一些常见的线程安全集合:ConcurrentHashMap类似于HashMap,但它是线程安全的,允许并发读写操作,并且在高并发场景下的性能优于同步HashMap。CopyOnWriteArrayList线程安全的List实现,当修改集合时(如添加、删除元素),它会创建一个新
- 24张图带你彻底理解Java中的21种锁
一叶飘舟
java开发语言
本篇主要内容锁的全家福帮你总结好的锁:序号锁名称应用1乐观锁CAS2悲观锁synchronized、vector、hashtable3自旋锁CAS4可重入锁synchronized、Reentrantlock、Lock5读写锁ReentrantReadWriteLock,CopyOnWriteArrayList、CopyOnWriteArraySet6公平锁Reentrantlock(true)7
- 线程安全的List
暴走的Aluuubbarrrr
Java线程安全List线程安全ListVector
线程安全的ListVector类的架构基本属性构造方法基本方法SynchronizedList和SynchronizedRandomAccessListCollections.synchronizedList构造方法具体方法具体使用CopyOnWriteArrayList(**)简介结构成员变量常见方法add(***)removegetCopyOnWriteArrayList总结总结在我们开发的时
- 使用多线程往LIST添加数据 线程安全list CopyOnWriteArrayList与Collections.synchronizedList的性能对比
万事俱备就差一个程序员了
列表实现有ArrayList、Vector、CopyOnWriteArrayList、Collections.synchronizedList(list)四种方式。1ArrayListArrayList是非线性安全,此类的iterator和listIterator方法返回的迭代器是快速失败的:在创建迭代器之后,除非通过迭代器自身的remove或add方法从结构上对列表进行修改,否则在任何时间以任何
- 并发编程(下)
_杨
哈希算法算法java
目录七、对象结构编辑八、synchronized锁实现当synchronized修饰方法:当synchronized修饰代码块:九、AQS(AbstractQueuedSynchronizer)十、ReentrantLock锁实现十一、JUC常用类一、ConcurrentHashMap二、CopyOnWriteArrayList三、CopyOnWriteArraySet四、辅助类CountDown
- Java并发与多线程:入门基础
星光闪闪k
Java数据库服务器java后端架构
目录1.介绍1.1多线程的概念1.2并发与并行的区别1.3为什么需要多线程2.多线程基础2.1线程的生命周期2.2线程的创建与启动2.3线程的中断与等待2.4线程的同步与互斥3.线程安全性3.1什么是线程安全性3.2共享数据与不可变性3.3同步机制与锁3.4原子性操作4.并发集合类4.1ConcurrentHashMap4.2CopyOnWriteArrayList4.3BlockingQueue
- CompletableFuture原理与实践
Raral
准备保证写入时,线程安全的List和Set结构?ConcurrentHashMap是线程安全的HashMap,CopyOnWriteArrayList是线程安全的ArrayList。CopyOnWriteArraySet是线程安全的HashSet。考虑多线程处理任务点?任务的类型:计算能力复杂,IO操作;任务是否异步:同步,异步每个子线程是否有依赖关系:有,没有(例如:使用多线程处理从1累加到1万
- Java中线程安全的集合
Willing卡卡
JAVAjava多线程queue
Java中线程安全的集合引言:本文主要分享了Collection体系集合下除了Vector以外的线程安全集合,包括:Collection中的安全工具方法、子类CopyOnWriteArrayList、CopyOnWriteArraySet、ConcurrentHashMap、Queue接口、ConcurrentLinkedQueue、BlockingQueue以及阻塞队列;相关文章:Java多线程
- 关于集合中的线程安全问题
肆〇
java数据结构集合线程安全多线程集合javajavamap
仅供参考,如有错误,请指正!集合中线程安全的类有:vector,stack,hashtable,enumeration,除此之外均是非线程安全的类与接口,简单记忆线程安全的集合类:喂!SHE!喂是指vector,S是指stack,H是指hashtable,E是指:Enumeration(转载自牛客网)线程安全的集合有:List接口下的:Vector、CopyOnWriteArrayList、Col
- 从零学Java 线程安全的集合
贰贰柒丶阿拽
从零学Javajava安全开发语言
线程安全的集合文章目录线程安全的集合1List和Set体系Collections中的工具方法1.1CopyOnWriteArrayList1.2CopyOnWriteArraySet1.3ConcurrentHashMap2CAS算法3Queue接口(队列)3.1ConcurrentLinkedQueue3.2BlockingQueue接口(阻塞队列)Collection体系集合、以及线程安全集合
- CopyOnWriteArrayList
Java小生不才
Javajava
前言CopyOnWrite简称COW机制,是一种程序优化策略(延时懒惰策略).其思路是,一开始共享同一内容,当想对此内容进行修改时,会将此内容复制一份,对复制的内容进行修改,修改之后再将原内容的引用指向修改后的内容。JDK5并发包提供使用了CopyOnWrite机制实现的并发容器(CopyOnWriteArrayList与CopyOnWriteArraySet),在并发场景中使用较多。CopyOn
- Java基础 -04 List之CopyOnWriteArrayList
Miaow.Y.Hu
javajavalist开发语言
java集合有蛮多的类型,今天我们以CopyOnWriteArrayList和Vector进行相关介绍。CopyOnWriteArrayListCopyOnWriteArrayList是Java集合框架中的一个线程安全的List实现类。它通过在修改操作时创建一个新的副本来实现线程安全性,因此称为"写时复制"。Copy-On-Write简称COW,是一种用于程序设计中的优化策略。CopyOnWrit
- 容器
吴少侠
[TOC]一、容器应用图解[图片上传失败...(image-325ddf-1639467042776)]二、Collection1、Lista、VectorVector底层是数组随机访问效率高,增删效率低。通过索引可以很快的查找到对应元素,而增删元素许多元素的位置都要改变线程安全。很多方法都是synchronized的b、CopyOnWriteArrayList-写时复制CopyOnWriteAr
- 【JAVA】哪些集合类是线程安全的
还在路上的秃头
JAVAjava开发语言笔记面试
个人博客:个人主页个人专栏:JAVA⛳️功不唐捐,玉汝于成目录前言正文Vector:HashTable:Collections.synchronizedList()、Collections.synchronizedSet()、Collections.synchronizedMap():4.ConcurrentHashMap:5.CopyOnWriteArrayList和CopyOnWriteArr
- Java总结进阶之路 (基础三)数组集合
飘风凌雪
Java系列回顾笔记javapython开发语言
文章目录@[TOC](文章目录)数组什么是数组数组的定义:数组的创建数组的初始化数组中的常见问题二维数组介绍集合框架conllectionList集合ArrayListLinkedList集合Vector集合CopyOnWriteArraylist集合Set集合HashSet集合ThreeSet集合Queue集合MapLinkedHashMap集合Hashtable集合TreeMap集合Concu
- 常用Java代码-Java中的并发集合(ConcurrentHashMap、CopyOnWriteArrayList等)
crmeb服务商-肥仔全栈开发
javawindows
在Java中,并发集合是一组为多线程环境设计的集合类,它们提供了线程安全的操作。这些集合类包括ConcurrentHashMap,CopyOnWriteArrayList等。以下是对这两个类的一个简单的代码解释。1.ConcurrentHashMapConcurrentHashMap是Java并发包java.util.concurrent中的一个类,它提供了线程安全的Map实现。与Hashtabl
- J2EE从入门到入土02.List集合解析
王真教掌门
大数据javajava-ee
目录ArrayList分析属性常用方法构造函数增加刪除修改总结ArrayList关于删除需要注意的点位LinkedList解析Vector解析CopyOnWriteArrayList解析可以从源码看出List接口继承Collection在Collection中,List集合是有序的,且可重复的可对其中每个元素的插入位置进行精确地控制,可以通过下标,foreach,迭代器来遍历List有那么几个类A
- Java刷题错题笔记-day05-集合(CopyOnWriterArrayList、HashMap)
摸魚散人
Java刷题笔记java面试
1.CopyOnWriterArrayList是强一致性列表吗?不是CopyOnWriteArrayList不提供强一致性主要是因为它的修改操作是在一个新的拷贝上进行的,而不是直接在原始数据结构上。这种设计决策带来了一些影响:读取操作不阻塞:CopyOnWriteArrayList的读取操作是在原始数组上进行的,无锁,而写入在原数组的拷贝上进行。因此,写入操作期间,读取操作不会被阻塞,允许并发读取
- 并发List源码剖析
Andy技术支援
Java多线程并发多线程并发安全java
并发包中的并发List只有CopyOnWriteArrayList。CopyOnWriteArrayList是一个线程安全的ArrayList,对其进行的修改操作都是在底层的一个复制的数组(快照)上进行的,也就是使用了写时复制策略。在CopyOnWriteArrayList的类图中,每个CopyOnWriteArrayList对象里面有一个array数组对象用来存放具体元素,ReentrantLo
- 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独立出来,数据持