前端技术
HTML
CSS
Javascript
前端框架和UI库
VUE
ReactJS
AngularJS
JQuery
NodeJS
JSON
Element-UI
Bootstrap
Material UI
服务端和客户端
Java
Python
PHP
Golang
Scala
Kotlin
Groovy
Ruby
Lua
.net
c#
c++
后端WEB和工程框架
SpringBoot
SpringCloud
Struts2
MyBatis
Hibernate
Tornado
Beego
Go-Spring
Go Gin
Go Iris
Dubbo
HessianRPC
Maven
Gradle
数据库
MySQL
Oracle
Mongo
中间件与web容器
Redis
MemCache
Etcd
Cassandra
Kafka
RabbitMQ
RocketMQ
ActiveMQ
Nacos
Consul
Tomcat
Nginx
Netty
大数据技术
Hive
Impala
ClickHouse
DorisDB
Greenplum
PostgreSQL
HBase
Kylin
Hadoop
Apache Pig
ZooKeeper
SeaTunnel
Sqoop
Datax
Flink
Spark
Mahout
数据搜索与日志
ElasticSearch
Apache Lucene
Apache Solr
Kibana
Logstash
数据可视化与OLAP
Apache Atlas
Superset
Saiku
Tesseract
系统与容器
Linux
Shell
Docker
Kubernetes
[JavaScript对象属性赋值陷阱 ]的搜索结果
这里是文章列表。热门标签的颜色随机变换,标签颜色没有特殊含义。
点击某个标签可搜索标签相关的文章。
点击某个标签可搜索标签相关的文章。
转载文章
...提供了Promise对象。 特点 1.对象的状态不受外界影响 (3种状态) Pending状态(进行中) Fulfilled状态(已成功) Rejected状态(已失败) 2.一旦状态改变就不会再变 (两种状态改变:成功或失败) Pending -> Fulfilled Pending -> Rejected 用法 创建Promise实例 let promise = new Promise(function(resolve, reject){// 你自己的异步逻辑代码if (/ 异步操作成功 /) {resolve(value);} else { // 异步操作失败reject(error);} }) Promise构造函数接受一个函数作为参数,该函数的两个参数分别是resolve和reject。它们是两个函数,由JavaScript引擎提供,不用自己部署。 resolve作用是将Promise对象状态由“未完成”变为“成功”,也就是Pending -> Fulfilled,在异步操作成功时调用,并将异步操作的结果作为参数传递出去; 而reject函数则是将Promise对象状态由“未完成”变为“失败”,也就是Pending -> Rejected,在异步操作失败时调用,并将异步操作的结果作为参数传递出去。 then Promise实例生成后,可用then方法指定一种状态回调参数: 1.Promise对象状态改为Resolved时调用 (必选) 备注:通俗的讲 resolve => then catch Promise实例生成后,可用catch方法指定一种状态回调参数: 1.Promise对象状态改为Rejected时调用 (可选) 备注:通俗的讲 reject => catch 基本用法示例 function sleep(num) {return new Promise(function(resolve, reject) {if (num>10){resolve('成功') } else {reject('失败') } })}sleep(500).then( res=> console.log(res)).catch(err => console.log(err)); 这段代码定义了一个函数sleep,调用后,如果传入的实参大于10,你会发现他会触发then的回调函数,并且打印出成功,如果传入的实参小于10,你会发现他会触发catch的回调函数,并且打印出失败。 执行顺序 接下来我们探究一下它的执行顺序,看以下代码: let promise = new Promise(function(resolve, reject){console.log("AAA");resolve()});promise.then(() => console.log("BBB"));console.log("CCC")// AAA// CCC// BBB 执行后,我们发现输出顺序总是 AAA -> CCC -> BBB。表明,在Promise新建后会立即执行,所以 首先输出 AAA。然后,then方法指定的回调函数将在当前脚本所有同步任务执行完后才会执行,所以BBB 最后输出。 与定时器混用 首先看一个下面的代码: let promise = new Promise(function(resolve, reject){console.log("1");resolve();});setTimeout(()=>console.log("2"), 0);promise.then(() => console.log("3"));console.log("4");// 1// 4// 3// 2 可以看到,结果输出顺序总是: 1 -> 4 -> 3 -> 2。1与4的顺序不必再说,而2与3先输出Promise的then,而后输出定时器任务。原因则是Promise属于JavaScript引擎内部任务,而setTimeout则是浏览器API,而引擎内部任务优先级高于浏览器API任务,所以有此结果。 本篇文章为转载内容。原文链接:https://blog.csdn.net/scc0413/article/details/125090843。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-06-05 22:54:38
115
转载
Apache Pig
...和操作同一份资源(如对象或变量)时,能够确保程序运行结果正确无误的一种属性。在本文语境下,Apache Pig基于Java开发,如果其内部实现的代码逻辑未考虑到线程安全问题,在高并发执行时可能会出现数据不一致、状态混乱等状况,导致性能下降。解决线程安全问题的方法包括使用synchronized关键字进行同步控制,或者利用ReentrantLock等高级锁机制来协调多线程对共享资源的访问顺序和权限。 资源竞争 , 资源竞争是指在计算机系统中,多个进程或线程同时请求使用同一有限资源而产生的冲突现象。在高并发执行Apache Pig任务时,资源竞争可能涉及到内存资源、CPU资源等关键系统资源。若无法有效管理和调度这些资源,可能导致部分任务等待资源释放而阻塞,进而影响整个系统的执行效率,甚至引发系统崩溃。解决资源竞争问题的策略包括合理分配和限制并发任务数量,运用线程池管理技术,以及动态调整内存使用状况以优化资源利用率。
2023-01-30 18:35:18
410
秋水共长天一色-t
Tomcat
...如HTML、CSS、JavaScript等)、配置文件以及其他依赖项(如JAR文件)压缩为一个单一的.AR文件。在实际应用中,开发人员可以将WAR文件部署到支持Java EE的应用服务器(如Apache Tomcat)上,从而运行和管理Web应用程序。 Tomcat , Apache Tomcat是一款开源的Servlet容器,实现了Java Servlet和JavaServer Pages(JSP)规范,用于托管和运行Java Web应用程序。作为轻量级应用服务器,Tomcat主要用于处理基于HTTP协议的请求,解析并执行WAR文件中的内容,从而提供动态Web服务。在文章中,Tomcat是WAR文件部署的主要目标环境之一,需要对它的配置进行适当的调整以确保能够正确部署WAR文件。 Context元素 , 在Apache Tomcat的server.xml配置文件中,Context元素是用来定义特定Web应用程序的配置信息的一种XML元素。它包含了与某个Web应用程序相关的一系列属性,例如appBase(应用程序基础路径),unpackWARs(是否自动解压WAR文件),autoDeploy(是否自动部署新上传或修改的WAR文件)等。通过配置Context元素,管理员可以灵活地控制每个应用程序的部署细节,比如指定应用程序的上下文路径、数据源连接、安全管理器等。在文章中,作者举例说明了如何在server.xml中添加一个新的Context元素来实现WAR文件的部署和管理。
2023-10-09 14:20:56
290
月下独酌-t
Lua
...同时也限制了变量只能赋值为预定义的枚举成员。 metatable , 在Lua语言中,metatable是一个特殊的table,用于关联到另一个table上,从而控制其行为和属性。metatable中的元方法(如__index、__newindex)可以定制 Lua 中表的行为,例如当尝试访问或修改表中不存在的键时执行的操作。在模拟枚举约束性的场景中,metatable被用来实现只读效果,防止对枚举值的意外修改。 模块 , 在软件开发中,模块是一种组织代码的方式,将相关功能封装在一起并对外提供接口。在Lua中,模块是通过返回局部变量或者函数来隐藏内部实现细节,仅公开需要外部访问的部分,从而实现信息隐藏和代码复用。通过创建私有枚举模块,可以在全局环境中避免暴露枚举的具体实现,同时提供安全、可控的方式来访问和使用枚举数据。
2023-12-25 11:51:49
189
夜色朦胧
AngularJS
...指令,用于遍历数组或对象,并将它们显示在HTML页面上。 然而,在实际应用中,“ng-repeat”可能会遇到一些性能瓶颈。这是因为当我们上网时,如果一个网页塞满了大量的数据,浏览器就像个忙得团团转的小蜜蜂,需要耗费不少时间和精力去处理这些信息,这样一来,网页打开的速度就会变慢,咱们用户浏览网页的体验自然也就大打折扣啦。 为了解决这个问题,我们可以采取以下几种措施: 1. 数据分页 在处理大量数据时,我们可以将其分成多个部分,并在每个部分之间添加分页器。这样一来,用户每次瞧见的就只是一部分数据,而不是满满当当全部数据,这样一来,浏览器的压力也就减轻了,网页加载的速度自然就像火箭升空一样噌噌噌地提高了。 html { {item} } Next Page 2. 缓存数据 如果我们知道某个数据不会经常改变,我们可以将其缓存在浏览器中,以便下次访问时直接从缓存中读取,而不需要重新计算。 javascript var cachedData = {}; $http.get('data.json').then(function(response) { cachedData = response.data; }); $scope.items = cachedData; 3. 使用虚拟滚动 对于长列表,我们可以使用虚拟滚动来减少浏览器的负担。虚拟滚动是指只显示可见区域的数据,而不是全部数据。这种方法可以大大减少浏览器的负担,提高网页的加载速度。 css .scrollable { overflow-y: scroll; } .scrollable::-webkit-scrollbar { width: 8px; } .scrollable::-webkit-scrollbar-track { background-color: f1f1f1; } .scrollable::-webkit-scrollbar-thumb { background-color: 888; } .scrollable::-webkit-scrollbar-thumb:hover { background-color: 555; } 通过以上几种方法,我们可以有效地解决“ng-repeat”中的性能瓶颈问题,提高网页的加载速度和用户体验。同时,咱们也得留心优化代码这块儿,别让那些不必要的计算和内存消耗拖慢了网页速度,这样一来,咱就能更上一层楼,把网页性能提上去啦! 总的来说, AngularJS 是一个非常强大的前端框架,它可以让我们轻松地创建出动态、交互式的网页应用程序。不过在实际用起来的时候,咱们也得留心优化代码这件事儿,别让性能瓶颈这类问题冒出来绊住咱们的脚。这样一来,才能更好地提升用户体验,让大家用得更顺溜、更舒心。希望通过这篇文章,能对你有所帮助!
2023-03-17 22:29:55
397
醉卧沙场-t
ReactJS
...ctJS是一个强大的JavaScript库,它可以帮助我们快速构建复杂的用户界面。不过在搞大型项目的时候,如果用ReactJS这玩意儿,由于它那堆得跟山一样高的代码和绕来绕去的设计模式,常常会让团队成员间的沟通协作变得像挤牙膏一样费劲儿。所以,本文打算聊聊在大型项目中使用ReactJS时,团队成员如何更好地沟通协作这个接地气的问题。 二、ReactJS的基本概念 1. ReactJS是什么? ReactJS是Facebook开源的一款JavaScript库,用于构建用户界面。它的主要目标是提高开发效率和用户体验。 2. ReactJS的工作原理是什么? ReactJS通过虚拟DOM(Virtual DOM)来提高渲染性能。当你在ReactJS里修改组件状态时,它会立马算出一个新的虚拟DOM树。然后呢,就像找茬游戏一样,React会把这个新的DOM树跟之前的旧DOM树进行对比,找出哪些地方有变化,进而只更新那些真正需要重新画的部分。 三、ReactJS的团队沟通和协作问题 1. 部署问题 在大型项目中,ReactJS的应用可能会导致部署问题。由于ReactJS的庞大代码量和复杂的设计模式,使得部署变得更加困难。为了搞定这个问题,我们可以尝试用模块化的方式来开发,就像把一本厚厚的书分成几个章节一样,把代码分割成多个独立的小模块,再逐个进行部署,这样就轻松多了。 2. 维护问题 在大型项目中,ReactJS的维护也是一个大问题。由于ReactJS的庞大代码量和复杂的设计模式,使得维护变得更加困难。为了解决这个问题,我们可以采用版本控制工具进行管理,如Git等。同时,我们也需要定期进行代码审查,以便及时发现和修复错误。 3. 文档问题 在大型项目中,ReactJS的文档也是一个大问题。由于ReactJS那浩如烟海的代码量和错综复杂的设计模式,真让人感觉编写和维护文档就像在走迷宫一样费劲儿。为了解决这个问题,我们可以采用自动化工具进行文档生成,如JSDoc等。同时,我们也需要定期更新文档,以便及时反映最新的情况。 四、ReactJS的团队沟通和协作解决方案 1. 使用版本控制工具 版本控制工具可以帮助我们更好地管理代码。咱们可以利用Git这个神器来管理代码版本,这样一来,甭管是想瞅瞅之前的旧版代码,还是想一键恢复到之前的某个版本,都变得轻而易举。就像有个时光机,随时带你穿梭在各个版本之间,贼方便! 2. 使用自动化工具 自动化工具可以帮助我们更好地生成和维护文档。嘿,你知道吗?咱们完全可以借助像JSDoc这类神器,一键生成API文档,这样一来,咱们就能省下大把的时间和精力,岂不是美滋滋? 3. 建立有效的团队沟通机制 建立有效的团队沟通机制是非常重要的。我们可以使用Slack等工具来进行实时的团队沟通,也可以使用Trello等工具来进行任务管理和进度跟踪。此外,我们还需要定期进行团队会议,以便及时解决问题和调整计划。 五、结论 ReactJS是一款非常强大的JavaScript库,它可以帮助我们快速构建复杂的用户界面。不过在搞大型项目的时候,如果用ReactJS这玩意儿,由于它那堆得跟山一样高的代码和绕来绕去的设计模式,常常会让团队成员间的沟通协作变得像挤牙膏一样费劲儿。所以呢,咱们得动手搞点事情来解决这些问题。比如,可以试试版本控制工具这玩意儿,还有自动化工具这些高科技,再者就是构建一套真正能打的团队沟通系统,让大家伙儿心往一处想、劲儿往一处使。只有这样,我们才能更好地利用ReactJS的优势,打造出高质量的项目。 六、附录 ReactJS示例代码 javascript import React from 'react'; import ReactDOM from 'react-dom'; class HelloWorld extends React.Component { render() { return ( Hello, World! Welcome to my React application. ); } } ReactDOM.render(, document.getElementById('root')); 以上是一段简单的ReactJS示例代码,用于渲染一个包含标题和段落的页面。通过这段代码,我们可以看到ReactJS是如何工作的,以及它是如何处理组件的状态和事件的。
2023-07-11 17:25:41
455
月影清风-t
Shell
...时,开发者可以定义并赋值给变量,然后通过变量名在脚本中引用这些值。如果尝试访问一个未被定义过的Shell变量,通常会返回空字符串或引发错误。 declare命令 , declare是Bash Shell和其他兼容Shell中的一种内建命令,用于声明、显示或修改变量的属性。在本文语境下,declare -v选项用来检查某个特定变量是否已定义。若该变量已定义,无论其值是否为空,declare -v命令都会输出该变量的信息;否则,命令执行将产生错误提示。 管道(Pipeline) , 管道是一种Linux/Unix shell中的通信机制,允许将一个命令的标准输出(stdout)直接连接到另一个命令的标准输入(stdin)。在文章中,使用了set | grep的形式构建了一个管道,其中set命令列出所有环境变量,并将其输出通过管道传递给grep命令,后者用于查找是否存在指定名称的变量。 nameref特性 , 这是Bash 5.1版本引入的新特性,它允许创建一个特殊的引用型变量,这种变量的值实际上是另一个变量的名字。在实际应用中,nameref变量可以动态地改变或引用其他变量,增强了Shell脚本处理复杂逻辑时对变量的控制能力。但在本文讨论的内容中并未涉及这一特性,这里提供作为扩展阅读理解。
2023-07-08 20:17:42
34
繁华落尽
Hibernate
...我们创建一个Java对象并将其持久化到数据库中时,Hibernate会将这个对象映射到数据库中的一个表。不过,有时候我们可能会遇到这么个情况:得对实体类做点调整,但又不想动那个数据库表结构一分一毫。这就产生了实体类与数据库表不匹配的问题。 三、问题原因分析 首先,我们要明白为什么会出现这种问题。通常,这有两个原因: 1. 数据库设计 在早期的项目开发过程中,我们可能没有对数据库进行详细的设计,或者因为各种原因(如时间限制、技术选择等),数据库的设计并不完全符合我们的业务需求。这就可能导致实体类与数据库表不匹配。 2. 重构需求 随着项目的持续发展,我们可能会发现原来的实体类有一些不足之处,需要进行一些修改。但是这些修改可能会导致实体类与数据库表不匹配。 四、解决方法 面对实体类与数据库表不匹配的问题,我们可以采取以下几种解决方案: 1. 手动更新数据库 这是最直接也是最简单的方法。查了查数据库,我获取到了实体类所对应的表格结构信息,接着亲自手动对数据库的表结构进行了更新。这种方法虽然可行,但缺点是工作量大,且容易出错。 2. 使用Hibernate的工具类 Hibernate提供了一些工具类,可以帮助我们自动更新数据库的表结构。例如,我们可以使用org.hibernate.tool.hbm2ddl.SchemaExport类来生成DDL脚本,然后执行这个脚本来更新数据库的表结构。这种方法的优点是可以减少工作量,缺点是如果表结构比较复杂,生成的DDL脚本可能会比较长。 3. 使用JPA的特性 如果我们正在使用Java Persistence API(JPA)来操作数据库,那么可以考虑使用JPA的一些特性来处理实体类与数据库表不匹配的问题。比如,我们可以通过在实体类上贴个@Table标签,告诉系统这个类对应的是哪张数据表;给属性打上@Column标签,就好比在说“这个属性就是那张表里的某列”;而给主键字段标记上@Id注解,就类似在强调“瞧,这是它的身份证号”。这样的方式,是不是感觉更加直观、接地气了呢?这样一来,我们就能轻松实现一个目标:无需对数据库表结构动手脚,也能确保实体类和数据库表完美同步、保持一致。就像是在不重新装修房间的前提下,让家具布局和设计图纸完全匹配一样。 五、总结 总的来说,实体类与数据库表不匹配是一个常见的问题,我们需要根据实际情况选择合适的解决方案。甭管你是手把手更新数据库,还是使唤Hibernate那些工具娃,甚至玩转JPA的各种骚操作,都得咱们肚子里有点数据库的墨水和技术上的两把刷子才行。因此,我们应该不断提升自己的技术水平,以便更好地应对各种技术挑战。
2023-03-09 21:04:36
545
秋水共长天一色-t
Bootstrap
...一系列CSS样式表和JavaScript插件,用于快速创建美观、响应式的界面元素。 下拉菜单 , 下拉菜单是网页或应用程序中常见的交互组件,通常表现为一个按钮或者链接,当用户点击时会展开隐藏的子菜单项供用户选择。在Bootstrap 5中,通过特定的HTML结构和数据属性(如data-bs-toggle=dropdown),可以方便地创建功能完备且具有良好跨设备兼容性的下拉菜单。
2023-12-02 15:43:55
558
彩虹之上_t
Saiku
...就像魔法师一样,通过JavaScript这门神秘的语言,灵活地给报表的各种元素穿上不同的“外衣”。当我们将报表导出为 Excel 时,由于 Excel 并不支持动态加载的 CSS 类,所以这些类会丢失,从而导致样式被删除。 三、解决方法 既然知道了问题的原因,那么如何解决它呢?下面我们将介绍几种可能的方法: 3.1 方法一:使用 Saiku 的导出功能 Saiku 自带了一个名为“Export to Excel”的功能,可以方便地将报表导出为 Excel 文件。在这一整个过程中,Saiku这家伙可机灵了,它会主动帮咱们把所有和样式有关的小细节都给妥妥地搞定,这样一来,我们就完全不必为丢失样式的问题而头疼啦! 以下是使用 Saiku 导出报表的代码示例: javascript saiku.model.exportToXLSX(); 这个函数会直接将当前报表导出为一个名为“report.xlsx”的 Excel 文件,文件中包含了所有的数据和样式。 3.2 方法二:手动修改 Excel 文件 如果我们必须使用 Excel 进行导出,那么我们可以尝试手动修改 Excel 文件,使其包含正确的样式信息。 以下是一个简单的示例,展示了如何通过 VBA 宏来修复样式丢失的问题: vba Sub FixStyle() ' 找到所有丢失样式的单元格 Dim rng As Range Set rng = ActiveSheet.UsedRange For Each cell In rng If cell.Font.Bold Then cell.Font.Bold = False End If If cell.Font.Italic Then cell.Font.Italic = False End If ' 添加其他样式... Next cell End Sub 这段代码会在 Excel 中遍历所有已使用的单元格,然后检查它们是否缺少某些样式。如果发现了缺失的样式,那么就将其添加回来。 四、结论 总的来说,Saiku 报表导出为 Excel 格式时丢失样式设置,主要是因为 Excel 不支持动态加载的 CSS 类。不过呢,咱其实有办法解决这个问题的。要么试试看用 Saiku 的那个导出功能,它能帮上忙;要么就亲自操刀,手动修改一下 Excel 文件,这样也行得通。这两种方法各有优缺点,具体选择哪种方法取决于我们的需求和实际情况。
2023-10-07 10:17:51
74
繁华落尽-t
Hadoop
...与HDFS相关的各种属性,如存储空间限额、命名空间限制等。在解决“HDFS Quota exceeded”问题时,可以通过修改此文件中的相关属性值来调整HDFS的空间分配策略和命名空间限额。 动态持久卷声明(Persistent Volume Claim,PVC) , 在Kubernetes等容器编排平台中,Persistent Volume Claim是一种抽象资源对象,允许用户请求特定大小和访问模式的存储资源。在大数据存储场景下,当HDFS存储空间不足时,可以利用PVC实现存储容量的弹性扩展,即根据应用需求自动挂载合适的持久卷(Persistent Volume),从而应对数据增长带来的存储压力。
2023-05-23 21:07:25
531
岁月如歌-t
Hibernate
...Hibernate的属性级联同步:通过cascade属性实现 1. 引言 嗨,朋友们!今天我要跟大家聊聊一个在Hibernate框架中非常实用但又容易被忽视的功能——属性级联同步。我第一次接触到这个概念时,简直是如获至宝。这东西能让我们的代码逻辑变得超级简单,省去很多重复劳动,写出的代码看起来干净利落,赏心悦目。今天,我想用一些接地气的例子,带你一起玩转这个超赞的功能,保证你学会后也能秀翻天! 2. 什么是级联? 首先,让我们来明确一下什么是级联(Cascade)。在Hibernate中,级联是指当一个对象的状态发生改变时,是否需要自动更新与之关联的其他对象的状态。这听起来可能有点抽象,但其实我们日常生活中有很多类似的概念。比如,当你把一本书放在书架上时,书架上自然就多了一本书。在这种情况下,放一本书上去,书架上就多了一本书,这就像在数据库里做了个操作,引起了一系列连锁反应。 3. cascade属性详解 现在我们知道了级联的基本概念,接下来就来看一看如何在Hibernate中实现级联操作。Hibernate有个叫cascade的设置,它能决定当你保存、删除或更新某个东西时,跟它相关的其他东西是不是也跟着一起变。cascade属性主要有以下几个值: - none:默认值,表示不进行任何级联操作。 - save-update:在保存或更新主对象时,同时保存或更新与之关联的对象。 - delete:在删除主对象时,同时删除与之关联的对象。 - all:包含了save-update和delete,即在所有情况下都进行级联操作。 - persist:在调用persist()方法时,同时执行级联操作。 - merge:在调用merge()方法时,同时执行级联操作。 - remove:在调用remove()方法时,同时执行级联操作。 4. 实战演练 现在,让我们通过几个具体的例子来演示如何使用cascade属性。假设我们有一个简单的用户系统,其中用户可以拥有多个地址信息。 4.1 示例一:一对一关联 首先,我们来看一个一对一关联的例子。这里有一个User类和一个Address类,每个用户只能有一个地址。 java @Entity public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String name; @OneToOne(cascade = CascadeType.ALL) private Address address; // Getters and Setters } @Entity public class Address { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String street; private String city; private String state; private String zipCode; // Getters and Setters } 在这个例子中,我们设置了cascade = CascadeType.ALL,这意味着当我们保存一个User对象时,Hibernate会自动保存其关联的Address对象。同样地,如果我们删除一个User对象,Hibernate也会自动删除其关联的Address对象。 4.2 示例二:一对多关联 接下来,我们再来看一个一对多关联的例子。这次,我们假设一个用户可以有多个地址。 java @Entity public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String name; @OneToMany(mappedBy = "user", cascade = CascadeType.ALL, orphanRemoval = true) private List addresses = new ArrayList<>(); // Getters and Setters } @Entity public class Address { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String street; private String city; private String state; private String zipCode; @ManyToOne @JoinColumn(name = "user_id") private User user; // Getters and Setters } 在这个例子中,我们设置了cascade = CascadeType.ALL,这意味着当我们保存一个User对象时,Hibernate会自动保存其关联的所有Address对象。如果我们想删掉一个地址,只需要从User对象的addresses列表里把它去掉就行了,Hibernate会自动搞定删除的事儿。 5. 总结与反思 通过上述两个例子,我们可以看到,级联操作极大地简化了我们在处理复杂对象关系时的工作量。不过呢,用级联操作的时候得小心点儿,因为它有时候会搞出些意外的麻烦,比如说让数据重复出现,或者不小心删掉不该删的东西。所以,在用级联操作的时候,咱们得好好琢磨每个对象之间的关系,然后根据实际情况挑个合适的级联策略。 总的来说,级联操作是一个非常强大的工具,可以帮助我们更好地管理和维护数据库中的对象关系。希望大家在实际开发中能够灵活运用这一功能,提高代码的质量和效率。
2025-01-27 15:51:56
80
幽谷听泉
Scala
...的编程语言,它将面向对象编程和函数式编程完美结合,提供了强大的并行处理能力。今天我们要讨论的是如何在Scala中使用Enumeratum库来实现枚举类型。 二、什么是枚举类型? 枚举类型是编程中的一种数据类型,它可以用来表示一组有限的值。这些值通常具有固定的顺序和描述,使得程序更容易理解和维护。例如,在Java中,我们可以定义一个名为Color的枚举类型: java public enum Color { RED, GREEN, BLUE; } 三、Scala中的枚举类型 在Scala中,我们也可以通过定义类来创建枚举类型。但是,这种方式并不直观,并且不能保证所有的值都被定义。这时,我们就需要使用到Enumeratum库了。 四、使用Enumeratum库创建枚举类型 Enumeratum是一个用于定义枚举类型的库,它提供了一种简单的方式来定义枚举,并且能够生成一些有用的工具方法。首先,我们需要在项目中添加Enumeratum的依赖: scala libraryDependencies += "com.beachape" %% "enumeratum-play-json" % "2.9.0" 然后,我们就可以开始定义枚举了: scala import enumeratum._ import play.api.libs.json.Json sealed trait Color extends EnumEntry { override def entryName: String = this.name.toLowerCase } object Color extends Enum[Color] with PlayJsonEnum[Color] { case object Red extends Color case object Green extends Color case object Blue extends Color } 在这里,我们首先导入了Enums模块和PlayJsonEnum模块,这两个模块分别提供了定义枚举类型和支持JSON序列化的功能。然后,我们定义了一个名为Color的密封抽象类,这个类继承自EnumEntry,并实现了entryName方法。然后,我们在这Color对象里头捣鼓了三个小家伙,这三个小家伙都是从Color类那里“借来”的枚举值,换句话说,它们都继承了Color类的特性。最后,我们给Enum施展了个小魔法,让它的apply方法能够大显身手,这样一来,这个对象就能摇身一变,充当构造器来使啦。 五、使用枚举类型 现在,我们已经成功地创建了一个名为Color的枚举类型。我们可以通过以下方式来使用它: scala val color = Color.Red println(color) // 输出 "Red" val json = Json.toJson(Color.Green) println(json) // 输出 "{\"color\":\"green\"}" 在这里,我们首先创建了一个名为color的变量,并赋值为Color.Red。然后,我们打印出这个变量的值,可以看到它输出了"Red"。接着,我们将Color.Green转换成JSON,并打印出这个JSON字符串,可以看到它输出了"{\"color\":\"green\"}"。 六、总结 通过本文的介绍,你已经学会了如何在Scala中使用Enumeratum库来创建枚举类型。你知道吗,使用枚举类型就像是给代码世界创建了一套专属的标签或者目录。它能够让我们把相关的选项分门别类地管理起来,这样一来,不仅能让我们的代码看起来更加井然有序、一目了然,还大大提升了代码的可读性和维护性,就像整理房间一样,东西放得整整齐齐,想找啥一眼就能看到,多方便呐!另外,使用Enumeratum这个库可是好处多多啊,它能让我们有效避开一些常见的坑,还自带了一些超级实用的小工具,让我们的开发工作就像开了挂一样高效。
2023-02-21 12:25:08
204
山涧溪流-t
c#
对null对象执行方法调用:C中的挑战与解决方案 1. 引言 在编程的世界里,我们经常需要处理各种类型的对象,并对他们执行方法调用。但在C中,尝试对一个null对象执行方法无疑会引发NullReferenceException,这是每个开发者都不愿遇到的噩梦。本文将深入探讨这一问题,通过生动的示例代码和探索性的讨论,让我们一起理解这个问题,并找出有效的解决之道。 2. 问题阐述 什么是null对象方法调用? 在C中,当引用类型变量未被初始化或已被赋值为null时,如果我们试图对该变量执行任何方法调用,系统就会抛出NullReferenceException异常。例如: csharp string someString = null; Console.WriteLine(someString.Length); // 这将抛出 NullReferenceException 上述代码中,尝试获取null字符串的长度会导致程序崩溃,因为实际的对象不存在,无法完成方法调用。 3. 理解错误 从人类思考过程出发 当我们面对这样的错误时,首先,作为程序员的我们会疑惑:“为什么我不能像对待其他正常对象那样,对null对象执行方法?”这其实源于C设计上的严谨性,它不允许对不存在的对象进行操作,以防止产生不可预知的结果。这就像是要求你从空口袋中掏出物品一样,显然是不可能的。 4. 避免“恶魔” 防御式编程策略 - 条件检查:最直接的方法是在调用方法前检查对象是否为null。 csharp if (someString != null) { Console.WriteLine(someString.Length); } - Null-Conditional Operator(?.):C 6引入了null条件运算符,它可以优雅地处理可能为null的对象。 csharp Console.WriteLine(someString?.Length); // 如果someString为null,这里将输出null而不是抛出异常 - Null Object Pattern:在设计阶段,可以使用空对象模式创建一个行为类似于默认或空实例的对象,这样即使对象是null,也能安全地执行方法调用。 5. C 8.0 及更高版本的新特性 可空引用类型(Nullable Reference Types) C 8.0引入了一种新的类型系统特性——可空引用类型。咱们现在能够亲自动手,明确告诉编译器一个引用类型能不能接受null值。这样一来,这个聪明的编译器就会依据这些提示,在编写代码阶段就帮咱们揪出那些潜在的、可能会引发null引用错误的小恶魔,让程序运行前就能把问题给解决了。 csharp string? nullableString = null; // 编译器会提示警告,因为可能访问了可能为null的成员 Console.WriteLine(nullableString.Length); 并且,结合?.和??运算符,我们可以更安全地处理这类情况: csharp Console.WriteLine(nullableString?.Length ?? 0); // 如果nullableString为null,则输出0 6. 结论与探讨 面对对null对象执行方法调用的问题,C提供了多种策略来避免这种异常的发生。从最基础的条件检测,到现代编程语言那些炫酷的功能,比如null安全运算符、空对象设计模式,再到可空引用类型等等,都为我们装备了一套超级给力的工具箱。作为一名有经验的开发者,理解并灵活运用这些策略,不仅能够提升代码质量,更能有效减少运行时错误,让我们的程序更加健壮稳定。在我们每天敲代码的时候,可千万不能打盹儿,得时刻保持十二分的警觉性,像个小侦探一样善于观察和琢磨。每遇到个挑战,都得用心总结,积攒经验,这样才能不断让我们的编程技术更上一层楼,变得越来越溜。
2023-04-15 20:19:49
540
追梦人
Lua
...使得Lua能支持面向对象编程、操作符重载等功能。 面向对象编程(OOP) , 面向对象编程是一种软件开发范式,它将程序结构组织为对象,每个对象封装了数据(属性)和操作这些数据的方法。在Lua中,通过metatable和元方法可以模拟类和继承等面向对象特性。例如文章中的“Player”类,通过创建一个table表示玩家,并为其添加属性(如name)和方法(如getName),实现了面向对象的编程风格,从而更好地组织代码逻辑并提高代码复用率。
2024-01-08 11:28:51
90
春暖花开
HTML
...吭哧吭哧地捣鼓出那段JavaScript滚动监听代码,可结果呢,这功能就像个沉睡的湖面,无论你怎么上下滑动页面,愣是激不起半点儿波澜,真是让人捉急。 html 这个简单的示例中,我们试图在页面滚动超过100px时,为导航栏添加一个fixed-top类以使其固定在顶部。如果这段代码并未按预期工作,那可能是由多种原因导致的,例如jQuery库未正确引入、DOM元素加载完成前执行了滚动监听等。 3. 排查步骤与解决方案 (1) 确保jQuery已正确引入 Bootstrap的部分功能依赖于jQuery,因此首先需要确保jQuery库已经被成功引入到项目中。检查HTML头部是否包含如下引用: html (2) 使用DOMContentLoaded事件 确保在DOM完全加载完成后才执行滚动监听事件绑定,可以避免因元素未加载完毕而导致的监听失效问题: javascript document.addEventListener("DOMContentLoaded", function(event) { $(window).scroll(function() { // ... 后续滚动监听逻辑 }); }); (3) 检查CSS样式冲突 有时候滚动监听功能看似无效,实际上可能是CSS样式覆盖导致的视觉效果不符预期。对于上述例子中的.fixed-top,请确认Bootstrap CSS文件已被正确引入,并且没有其他CSS规则影响其行为。 4. 进一步讨论与思考 即使以上所有步骤都已正确执行,仍然可能因为某些特定环境或场景下出现滚动监听失效的情况。这就需要我们深入理解Bootstrap的工作原理,并结合具体的项目需求进行细致排查。 例如,如果你在一个复杂的单页面应用中使用Bootstrap,由于页面内容是异步加载的,那么可能需要在每次内容更新后重新绑定滚动事件。或者这样来说,假如你在捣鼓移动端开发,你得留心一个情况,那就是滚动容器可能不是我们通常认为的那个大环境window,而是某个具有“滚屏”特性的div小家伙。这时候,你就得找准目标,给这个div元素好好调教一番,让它成为你的监听对象啦。 5. 结语 面对Bootstrap滚动监听无效的问题,我们需要有耐心地逐层剥茧,从基础的库引用、DOM状态到更复杂的样式冲突和异步加载场景,逐一排查并尝试解决方案。在解决各种问题的实战过程中,我们不仅像健身一样锻炼了自身的技术肌肉,更是对Bootstrap这个工具有了接地气、透彻骨髓的理解和掌握,仿佛它已经成了我们手中的得力助手,随心所欲地运用自如。希望本文能为你带来启示,助你在前端开发的道路上越走越稳!
2023-01-14 23:09:39
594
清风徐来_
JSON
...解和实践 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,广泛应用于Web服务和API接口中。平常我们在对付时间数据这玩意儿的时候,往往得把它变个身,变成特定格式的字符串模样,这样才能方便我们进行传输或者存储。这篇文儿呢,咱们就掰开了揉碎了,好好唠唠怎么把JSON里的时间字符串整得格式规规矩矩的输出来。咱会手把手,通过几个实实在在的代码例子,一步一步带你领略这个过程,保准你理解透彻、掌握牢固! 1. 时间戳与JSON 在JSON中,时间通常以Unix时间戳(从1970年1月1日UTC零点开始所经过的秒数)的形式表示,例如: json { "eventTime": 1577836800 } 然而,在实际应用中,我们需要将其转换成更易读、更具语义的时间字符串,如“2020-01-01T00:00:00Z”。 2. 格式化JSON中的时间字符串 在JavaScript中,我们可以使用Date对象来处理时间戳,并利用其内置的方法进行格式化输出。下面是一个简单的示例: javascript let json = { "eventTime": 1577836800 }; // 解析时间戳为Date对象 let eventTime = new Date(json.eventTime 1000); // 注意要乘以1000,因为JavaScript的Date对象接受的是毫秒 // 使用toISOString()方法格式化为ISO 8601格式 let formattedTime = eventTime.toISOString(); console.log(formattedTime); // 输出:"2020-01-01T00:00:00.000Z" 但是,toISOString()方法生成的字符串并不一定符合所有场景的需求,比如我们可能希望得到"YYYY-MM-DD HH:mm:ss"这种格式的字符串,这时可以自定义格式化函数: javascript function formatTimestamp(timestamp) { let date = new Date(timestamp 1000); let year = date.getFullYear(); let month = ("0" + (date.getMonth() + 1)).slice(-2); let day = ("0" + date.getDate()).slice(-2); let hours = ("0" + date.getHours()).slice(-2); let minutes = ("0" + date.getMinutes()).slice(-2); let seconds = ("0" + date.getSeconds()).slice(-2); return ${year}-${month}-${day} ${hours}:${minutes}:${seconds}; } let formattedCustomTime = formatTimestamp(json.eventTime); console.log(formattedCustomTime); // 输出:"2020-01-01 00:00:00" 3. 进一步探讨 使用第三方库Moment.js 处理复杂的时间格式化需求时,推荐使用强大的日期处理库Moment.js。以下是如何用它来格式化JSON中的时间戳: 首先,引入Moment.js库: html 然后,格式化JSON中的时间戳: javascript let json = { "eventTime": 1577836800 }; let momentEventTime = moment(json.eventTime 1000); // 使用format()方法按照指定格式输出 let formattedTime = momentEventTime.format("YYYY-MM-DD HH:mm:ss"); console.log(formattedTime); // 输出:"2020-01-01 00:00:00" 在这里,moment.js不仅提供了丰富的日期格式化选项,还能处理各种复杂的日期运算和比较,极大地提升了开发效率。 总结一下,JSON时间字符串格式化输出是一项常见且重要的任务。当你真正搞懂并灵活运用以上这些方法,甭管你是直接玩转JavaScript自带的那个Date对象,还是借力于像Moment.js这样的第三方工具库,都能让你在处理时间数据问题时,轻松得就像切豆腐一样。每一个开发者,就像咱们身边那些爱捣鼓、爱钻研的极客朋友,得在实际操作中不断挠头琢磨、勇闯技术丛林,才能真正把那些工具玩转起来,打造出一套既高效又精准的数据处理流水线。
2023-08-03 22:34:52
392
岁月如歌
Logstash
...式 , JSON (JavaScript Object Notation) 和 XML (eXtensible Markup Language) 是两种广泛应用于数据交换的结构化数据格式。在Logstash的上下文中,配置文件可以采用这两种格式之一编写,要求用户严格遵循各自的语法规则。如果配置文件没有按照规定的JSON或XML格式编写,将会导致Logstash无法解析并加载配置信息。
2023-01-22 10:19:08
258
心灵驿站-t
Java
...le、char,还是对象的引用,都是按值传递的。简单来说,你传递的是它们的“副本”,而不是它们本身。这就意味着,当我们把一个变量的值交给一个方法时,其实是在给它一个新的“复制品”。就像你把你的玩具分享给朋友,但你还是保留着自己的那个一样。 代码示例1: java public class ValuePassingExample { public static void main(String[] args) { int num = 5; System.out.println("Before method call: " + num); changeValue(num); System.out.println("After method call: " + num); } public static void changeValue(int x) { x = 10; System.out.println("Inside method: " + x); } } 在这个例子中,num 的初始值是5。当你把 num 传给 changeValue 方法时,其实是在给方法里的 x 复制了一个 num 的值,就是那个5。所以呢,就算我们在方法里面把 x 的值改来改去,外面的 num 还是会稳如老狗,一点变化都没有。 输出结果: Before method call: 5 Inside method: 10 After method call: 5 3. 地址传递 指向更深层次的探索 接下来,我们要探讨的是地址传递。在Java里,我们其实是把对象的引用当成了值来传递,但这并不等于说它完全按照传统的地址传递方式来工作。Java中的对象引用传递更像是值传递的一种变体。当你传递一个对象引用时,你实际上是在传递该引用的副本。这就意味着,你没法改变引用指向的那个对象的“家”,但是你可以去改动这个对象本身的“样子”。 代码示例2: java public class AddressPassingExample { public static void main(String[] args) { Person person = new Person("Alice"); System.out.println("Before method call: " + person.getName()); changeName(person); System.out.println("After method call: " + person.getName()); } public static void changeName(Person p) { p.setName("Bob"); System.out.println("Inside method: " + p.getName()); } } class Person { private String name; public Person(String name) { this.name = name; } public String getName() { return name; } public void setName(String name) { this.name = name; } } 在这个例子中,我们创建了一个名为 Person 的类,并定义了 name 属性。在 main 方法中,我们创建了一个 Person 对象并将其名字设为 "Alice"。当我们调用 changeName 方法时,我们将 person 对象的引用传递给了这个方法。虽然我们没法换个新的 p,但我们可以用 setName 这个方法来修改 person 这个对象的信息。 输出结果: Before method call: Alice Inside method: Bob After method call: Bob 4. 深入理解 值传递 vs 地址传递 现在我们已经了解了值传递和地址传递的基本概念,但它们之间的区别和联系仍然值得进一步探讨。值传递意味着我们传递的是数据的副本,而不是数据本身。而地址传递则允许我们通过引用访问和修改数据。不过在Java里,这种情况其实更像是把引用的复制品传来传去,所以它既不是传统的值传递,也不是真正的地址传递,挺特别的。 理解这一点可以帮助我们更好地设计和调试程序。比如说,当我们想确保某个方法不会搞乱传入的数据时,就可以考虑用值传递。这样就相当于给数据复制了一份,原数据还是干干净净的。而当我们需要修改传入的数据时,则应该考虑使用地址传递。 5. 总结 通过今天的讨论,我们不仅掌握了Java中值传递和地址传递的基本概念,还通过具体例子加深了对这两种传递方式的理解。希望这篇文章能够帮助你在编程过程中更加得心应手地处理数据传递问题。记住,编程不仅是技术的较量,更是思维的碰撞。希望你在未来的编程旅程中,不断探索,不断进步! --- 希望这篇技术文章能为你提供一些有价值的见解和灵感。如果你有任何疑问或想了解更多细节,请随时提问!
2024-12-20 15:38:42
104
岁月静好
转载文章
...x的DrawMode属性设置为OwnerDrawVariable或OwnerDrawFixed。ListBox有个ItemHeight属性,在DrawMode设置为Normal时,这个属性是不可设置的,并且其值是根据当前字体进行计算获得的。只有当DrawMode设置为OwnerDrawVariable或OwnerDrawFixed时,设置ItemHeight才生效。 属性 说明 Normal 组件的所有元素都由操作系统绘制,并且元素大小都相等。 OwnerDrawFixed 组件的所有元素都是手动绘制的,并且元素大小都相等。 OwnerDrawVariable 组件的所有元素都由手动绘制,元素大小可能不相等。 表01:枚举DrawMode中的成员及其说明 设置完DrawMode属性之后,通过ListBox的DrawItem事件可以绘制自己想要的个性化控件。先看一下自己绘制的ListBox控件的效果图: (这是选中“英语”的效果) 从图中可以看出,针对不同的行绘制了不同的背景色,选中项的背景色设置为蓝色,并且还绘制了一个边框。确实比系统绘制的ListBox好看多了。下面我们来看看代码,也就是DrawItem事件处理方法。 代码 private void listBox1_DrawItem(object sender, DrawItemEventArgs e) { int index = e.Index;//获取当前要进行绘制的行的序号,从0开始。 Graphics g = e.Graphics;//获取Graphics对象。 Rectangle bound = e.Bounds;//获取当前要绘制的行的一个矩形范围。 string text = listBox1.Items[index].ToString();//获取当前要绘制的行的显示文本。 if ((e.State & DrawItemState.Selected) == DrawItemState.Selected) {//如果当前行为选中行。 //绘制选中时要显示的蓝色边框。 g.DrawRectangle(Pens.Blue, bound.Left, bound.Top, bound.Width - 1, bound.Height - 1); Rectangle rect = new Rectangle(bound.Left 2, bound.Top 2, bound.Width - 4, bound.Height - 4); //绘制选中时要显示的蓝色背景。 g.FillRectangle(Brushes.Blue, rect); //绘制显示文本。 TextRenderer.DrawText(g, text, this.Font, rect, Color.White, TextFormatFlags.VerticalCenter | TextFormatFlags.Left); } else { //GetBrush为自定义方法,根据当前的行号来选择Brush进行绘制。 using (Brush brush = GetBrush(e.Index)) { g.FillRectangle(brush, bound);//绘制背景色。 } TextRenderer.DrawText(g, text, this.Font, bound, Color.White, TextFormatFlags.VerticalCenter | TextFormatFlags.Left); } } OwnerDrawVariable 设置DrawMode属性为OwnerDrawVariable后,可以任意改变每一行的ItemHeight和ItemWidth。通过ListBox的MeasureItem事件,可以使每一行具有不同的大小。 (奇偶行的行高不同) private void listBox1_MeasureItem(object sender, MeasureItemEventArgs e) { //偶数行的ItemHeight为20 if (e.Index % 2 == 0) e.ItemHeight = 20; //奇数行的ItemHeight为40 else e.ItemHeight = 40; } 总结 这里最重要的是DrawItem事件和MeasureItem事件,以及MeasureItemEventArgs事件数据类和DrawItemEventArgs事件数据类。在System.Windows.Forms命名空间中,具有DrawItem事件的控件有ComboBox、ListBox、ListView、MenuItem、StatusBar、TabControl,具有MeasureItem事件的控件有ComboBox、ListBox、MenuItem。所以,这些控件可以采用和ListBox相同的方法进行自定义绘制。 本篇文章为转载内容。原文链接:https://blog.csdn.net/mosangbike/article/details/54341295。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-10-22 22:21:02
667
转载
转载文章
...结构,并计算满足特定属性的对象数量的方法。这为理解和解决此类涉及整数序列限制及组合优化的问题提供了坚实的理论基础。 此外,当前AI领域中的一些研究也在探索利用机器学习技术解决复杂的组合优化问题,例如通过深度学习模型预测可能的最优解分布,辅助或取代传统的枚举和搜索策略。这种跨学科的研究方向为我们处理大规模、高维度的组合问题提供了新的视野和手段。 总之,从经典的数学理论到现代的计算机科学与人工智能前沿,对于限定条件下三角形边长组合计数问题的深入理解与解决,不仅能够提升我们在各类竞赛中的实战能力,更能帮助我们掌握一系列通用的分析问题和解决问题的策略,具有很高的教育价值和实际意义。
2023-07-05 12:21:15
45
转载
Maven
...意,我们将scope属性设置为import,这样就可以把dependencyManagement作为一个独立的依赖来引用了。 然后,在子项目中只需要添加对应的依赖即可,不需要再手动指定版本: xml org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-web 通过上述步骤,我们就成功地在dependencyManagement中替换了springboot相关的所有组件的版本。你瞧,dependencyManagement这个东西可了不得,它不仅能让我们开发工作变得轻松简单,还能让整个项目的维护和稳定性噌噌噌地往上蹿,简直是一大神器。 四、总结 dependencyManagement是Maven的一个强大工具,可以帮助我们有效地管理和控制项目的依赖版本。在日常开发工作中,我们常常会碰到这样一种情况:某个组件的版本需要更新换代。这时候,有一个超级实用的功能——dependencyManagement,它就能像救星一样,帮我们迅速搞定这个问题,省时又省力。一旦你熟练掌握了dependencyManagement的常规操作,就能轻轻松松地对项目中各个依赖项的版本进行有效管理,这样一来,不仅开发效率嗖嗖往上涨,项目的整体质量也能更上一层楼。
2023-01-31 14:37:14
71
红尘漫步_t
站内搜索
用于搜索本网站内部文章,支持栏目切换。
知识学习
实践的时候请根据实际情况谨慎操作。
随机学习一条linux命令:
du -sh *
- 在当前目录下查看所有文件和目录的大致大小。
推荐内容
推荐本栏目内的其它文章,看看还有哪些文章让你感兴趣。
2023-04-28
2023-08-09
2023-06-18
2023-04-14
2023-02-18
2023-04-17
2024-01-11
2023-10-03
2023-09-09
2023-06-13
2023-08-07
2023-03-11
历史内容
快速导航到对应月份的历史文章列表。
随便看看
拉到页底了吧,随便看看还有哪些文章你可能感兴趣。
时光飞逝
"流光容易把人抛,红了樱桃,绿了芭蕉。"