- Linux学习笔记:PCIe内核篇(1):初始化与枚举流程
ZH_2025
嵌入式协议篇PCIE
根据system.map查看内核中PCIe加载流程:root@zh-vm:~#cat/boot/System.map-5.15.0-130-generic|greppci|grepinitcallffffffff8350ff68d__initcall__kmod_pci__453_6907_pci_realloc_setup_params0ffffffff83510098d__initcall__
- 深入了解数据库领域行式存储的架构设计
数据库管理艺术
数据库专家之路大数据AI人工智能MCP&AgentSQL实战数据库ai
深入了解数据库领域行式存储的架构设计关键词:行式存储、数据库架构、OLTP、存储引擎、行记录格式摘要:本文将以“行式存储”为核心,从生活场景切入,逐步拆解数据库行式存储的底层架构设计。我们将通过“图书馆藏书”的趣味比喻、具体代码示例和真实数据库(如MySQLInnoDB)的实践案例,深入理解行式存储的核心原理、适用场景及未来趋势,帮助读者建立对数据库存储架构的系统认知。背景介绍目的和范围数据库是现
- InnoDB的页分裂、页合并及优化策略
flydroid
mysql数据库
文章目录B+树结构1.非叶子节点(索引节点)2.叶子节点(数据节点)3.层级关系4.B+树vsB树的核心区别5.B+树查询流程示例1.页分裂(PageSplit)触发条件分裂过程分裂类型性能影响2.页合并(PageMerge)触发条件合并过程性能影响3.页分裂与合并的根因B+树的平衡性要求动态数据操作的必然结果4.页分裂与合并的优化策略减少页分裂减少页合并5.示例分析页分裂场景页合并场景总结Inn
- mysql 页分裂_Innodb页面分裂
zhuyuejituan
mysql页分裂
何时进行页面分裂插入操作时首先调用乐观插入函数btr_cur_optimistic_insert,若发现此次空间不足,进行悲观插入,函数btr_cur_pessimistic_insert,在这里会触发页面分裂。dberr_tbtr_cur_optimistic_insert(...){...if(leaf&&page_size.is_compressed()&&(page_get_data_si
- 揭秘MySQL索引下推(ICP)的底层原理与高并发场景性能调优
Minxinbb
数据库mysql数据库dba
引言在千万级数据量的OLTP场景中,索引下推(IndexConditionPushdown,ICP)作为MySQL5.6引入的核心优化技术,可将特定场景的查询性能提升10倍以上。本文将从InnoDB存储引擎的索引结构出发,结合B+树遍历原理,深入解析ICP的工作机制,并通过压力测试对比验证优化效果。一、索引下推的核心原理剖析1.1传统索引查询的瓶颈未启用ICP时的查询流程(以复合索引(a,b,c)
- 三七互娱GO面经及参考答案
大模型大数据攻城狮
golangepollB树原理幻读go面试go面经mysql性能
MySQL有哪些存储引擎?MyISAM如何存储数字类型数据?MySQL拥有多种存储引擎,每种都有其独特的特性和适用场景。常见的存储引擎包括InnoDB、MyISAM、Memory、CSV、Archive、Federated等。InnoDB是MySQL5.5版本之后的默认存储引擎,它支持事务、外键、行级锁和崩溃恢复功能,适合处理高并发事务型应用。MyISAM是早期MySQL的默认存储引擎,不支持事务
- ESP32与SD卡交互实现:文件读写实战与初始化详解及引脚定义
本代码实现ESP32与SD卡的交互,包括定义SPI引脚、创建自定义SPI类实例、编写WriteFile与ReadFile函数进行文件读写。setup函数初始化串口、SPI、SD卡,向“/test.txt”写入“myfirstmessage”,读取并打印其内容。loop函数留空待扩展。1.需要准备的软硬件:1.1硬件:ESP32开发板SD卡模块(如下图),可以是单独的TF卡模块也可以是集成到TFT屏
- #Vue3篇: vue3梳理 :&ref自动解包&key使用
程序员xiaolibao
Vue3篇vue
vue3Attribute绑定同名简写如果attribute的名称与绑定的JavaScript值的名称相同,那么可以进一步简化语法,省略attribute值在模板中使用ref时,我们不需要附加.value。为了方便起见,当在模板中使用时,ref会自动解包(有一些注意事项)。import{ref}from'vue'exportdefault{setup(){constcount=ref(0)func
- 布线后优化(PostRoute Optimization)解析
weixin_45371279
innovus
AboutPostRouteOptimization一、PostRoute优化的核心功能与默认行为在PostRoute模式下,软件默认执行以下操作(除非手动指定其他目标):违规修复优先级:首先处理寄存器到寄存器(Reg2Reg)路径及寄存器到时钟(Reg2Clock)路径组。其次处理默认路径组的建立时间(Setup)违规和设计规则违规(DRV)。技术流程:RC参数提取:计算布线后的寄生电阻(R)和
- 【innovus基础】- 最基本的timing工具自动修复方法
一个小白向的timing修复方法就是,完全交给工具有gui界面和命令2种方式:1、gui操作ECO>>optdesign>>勾选fanout修复一轮后,发现hold完全没问题,但setup仍有少量问题。重新再修复一轮。下图中的glitchvio指的是毛刺持续时间或幅度超出允许范围的时序违例。可能造成亚稳态导致逻辑错误等问题。发现一次没有修好,现在只剩下setup的问题,我们可以在gui界面使用in
- Cadence Design Systems EDA介绍(五)--Innovus
小蘑菇二号
笔记
目录Innovus的主要功能1.初始布局规划(Floorplanning)2.详细布局(Placement)3.布线(Routing)4.时序分析与优化(TimingAnalysisandOptimization)5.功耗分析与优化(PowerAnalysisandOptimization)6.面积优化(AreaOptimization)7.签核(Sign-off)Innovus的特点1.高性能2
- Vue 3 的 <script setup> 语法糖与 TypeScript 的深度整合
前端熊猫
vue.jstypescriptscript前端
在Vue单文件组件中,标签除了lang、async、defer、src和name属性外,还有一些其他重要属性和用法值得关注。以下是补充说明及优化建议:一、setup属性(CompositionAPI核心)作用:通过setup属性启用Vue3的CompositionAPI,简化逻辑组织和复用。代码示例:import{ref,onMounted}from'vue'constcount=ref(0)on
- <script setup> 语法糖
前端岳大宝
前端框架Vuevue.js前端javascript
下面,我们来系统的梳理关于Vue3语法糖的基本知识点:一、核心概念1.1什么是?是Vue3中CompositionAPI的编译时语法糖,它通过简化组件声明方式,显著减少样板代码,提供更符合直觉的开发体验。1.2设计目标与优势目标实现方式优势减少样板代码自动暴露顶层绑定代码更简洁提升开发体验更自然的响应式写法开发更高效更好的类型支持原生TypeScript集成类型安全编译时优化编译阶段处理运行时更高
- Anaconda插件开发
lyh1344
数据库开发
开发环境准备安装Anaconda或Miniconda,确保conda命令可用。推荐使用Python3.7及以上版本。创建独立的开发环境以避免依赖冲突:condacreate-nplugin_devpython=3.8condaactivateplugin_dev插件结构设计Anaconda插件通常采用Python包的标准结构。核心文件包括__init__.py和setup.py。典型目录结构如下:
- Windows 下使用 nvm 管理 Node.js 多版本 —— 完整指南
爱宇阳
WindowNPMwindowsnode.js
Node.js版本更新频繁,不同项目可能依赖不同的版本,手动切换极为麻烦。nvm-windows是专为Windows用户开发的Node.js多版本管理工具,可以轻松地安装、切换、卸载Node.js版本。本篇将从下载到实际使用,手把手带你玩转nvm-windows。一、下载nvm-windows安装包进入GitHub项目地址:nvm-windowsReleases下载最新版的nvm-setup.zi
- MySQL索引分类有哪些?
java1234_小锋
mysqlmysql
大家好,我是锋哥。今天分享关于【MySQL索引分类有哪些?】面试题。希望对大家有帮助;MySQL索引分类有哪些?超硬核AI学习资料,现在永久免费了!MySQL中的索引可以根据不同的分类标准分为以下几种类型:1.根据存储方式分类聚集索引(ClusteredIndex):表中的数据行会按照索引顺序存储,即数据的物理顺序和索引顺序一致。每个表最多只能有一个聚集索引。在InnoDB存储引擎中,主键就是聚集
- InnoDB引擎 (上)
阿亮爱学代码
MYSQLmysqlInnoDB存储引擎sql
目录1.1逻辑存储结构1.2架构1.3磁盘结构1.4后台线程1.5事务原理1.1逻辑存储结构表空间(ibd文件):一个mysql实例可以对应多个表空间,用于存储记录,索引等数据。段:数据段,索引段,回滚段,InnoDB是索引组织表,数据段是B+树的叶子节点,索引段即为B+树的非叶子节点。区:表空间的单元结构,每个区的大小为1M。页:是InnoDB存储引擎磁盘管理的最小单元,每个页的大小默认为16K
- 配置Cuttlefish 虚拟 Android 设备
liuzl_2010
androidandroid
google参考资料:https://source.android.com/docs/setup/start?hl=zh-cnhttps://source.android.com/docs/devices/cuttlefish/get-started?hl=zh-cnCuttlefish开始验证KVM可用性Cuttlefish是一种虚拟设备,依赖于宿主机上可用的虚拟化。在宿主机上的终端中,确保可以
- Python包分发终极指南:深入掌握setuptools打包技术
Yant224
pythonpython打包setuptoolsPyPI发布Python分发wheel打包Python库开发
一、现代打包工具链架构1.打包生态系统演进现代标准旧版兼容源代码setuptools构建工具分发格式wheeleggpip安装2.核心组件关系#pyproject.toml声明构建系统(PEP518)[build-system]requires=["setuptools>=61.0.0","wheel"]build-backend="setuptools.build_meta"#setup.cfg
- python 升级setuptools_PIP无法升级setuptools
weixin_39792519
python升级setuptools
尝试在CentOS上运行此问题:$sudopipinstallsetuptools--no-use-wheel--upgradeDEPRECATION:Python2.6isnolongersupportedbythePythoncoreteam,pleaseupgradeyourPython.AfutureversionofpipwilldropsupportforPython2.6DEPREC
- import setuptools.version遇到pkg_resource异常
Pianist Of Keyboard
python
背景在自己写的包中使用到joblib和setuptools,在导入的时候经常容易卡主,一次严重影响到了生产,故尝试解决。File"/root/xxxx/xxxx/util/dependencies.py",line25,infromjoblibimportdelayed,load,dumpFile"/root/miniconda/envs/py39/lib/python3.9/site-packa
- MySQL为什么默认引擎是InnoDB?
java1234_小锋
mysqlmysql数据库
大家好,我是锋哥。今天分享关于【MySQL为什么默认引擎是InnoDB?】面试题。希望对大家有帮助;MySQL为什么默认引擎是InnoDB?超硬核AI学习资料,现在永久免费了!MySQL默认使用InnoDB引擎主要是因为以下几个原因:事务支持:InnoDB支持事务处理,具备ACID(原子性、一致性、隔离性、持久性)特性,这对于大多数现代应用程序至关重要。事务支持使得数据操作更加可靠,特别是在多用户
- setup.py 如何安装
先进入CMD,然后输入DOS命令进入setup.py文件所在目录,然后输入(python)setup.pyinstall就搞定了。但是我尝试时没有加python这个词,说是找不到,直接setup.py就安装成功了
- Python——基于setup.py安装库
William.csj
编程语言python
一、方法一路径切换到安装目录pythonsetup.pybuildpythonsetup.pyinstall二、方法二路径切换到安装目录pipinstall.
- 用大白话和日常比喻给你讲清楚 Arduino 中 setup() 外面和里面的区别
yifa20160404
arduinoc++
就像准备做饭和真正开火一样:voidsetup()外面(全局区):准备食材和工具就像做饭前,把要用到的东西都摆在台面上这里是你一次性声明所有要用到的东西,告诉Arduino:“这些调料(常量)固定不变!”#defineLED_PIN13//比如:盐罐子就放灶台左边constint按钮=2;//酱油瓶放右边,位置定死!“这些菜(变量)全程都能用!”int温度;//比如:切好的青菜放碗里,随时取Str
- Arduino 编程超清晰总结
yifa20160404
arduino
Arduino编程超清晰总结(厨房比喻版)1.全局区(setup()外面)→厨房台面作用:摆放所有食材和工具调料罐(常量):#defineLED13食材碗(变量):int温度;智能厨具(对象):Servo我的舵机;特点:▶️全程可用:setup()和loop()都能随手拿▶️只摆不操作:不能在这里炒菜(不能执行函数)2.voidsetup()→开火前准备作用:一次性开机动作插电器:我的舵机.att
- STA之RC Corner拾遗
diedai7174
后端
Q:还有一种RCcorner带后缀『_T』,只用于setupsignoff,T指的是什么?A:T代表tighten,在rc的variation上的sigma分布比不带T的更紧,因此只能用于setup,hold不推荐。AppletoApple地比较,T的variation更小,理论看到的rc变化更小,单从setup产生violation的可能性更小。至于悲观还是乐观,除非自己定criteria,其余
- Vue3 组合式 API:生命周期钩子(三)
**之火
vue3vue.js前端前端框架Vue3
1、onMounted()onMounted()会在组件挂载到DOM后立即调用,此时DOM已经渲染完毕,可以进行相关的DOM操作或发起网络请求。exportdefault{setup(){//可以在这里定义响应式状态、计算属性等onMounted(()=>{//组件挂载到DOM后执行的代码console.log('组件已挂载到DOM');//在这里可以进行DOM操作或发起网络请求等});//返回需
- Linux SPI子系统初始化与运行流程详解
进击的程序汪
linux服务器网络
LinuxSPI子系统初始化与运行流程详解以下是LinuxSPI子系统从设备树解析到驱动匹配、数据传输的完整流程,包含详细调用链和树状结构:一、SPI子系统初始化整体流程图[系统启动阶段]└───>[内核初始化]└───start_kernel()└───rest_init()└───kernel_init()└───init_post()└───do_basic_setup()└───drive
- 终止分区表变更操作时误删数据字典缓存导致MySQL崩溃分析
数据库mysql
终止分区表变更操作时误删数据字典缓存导致MySQL崩溃分析1.问题简述在MySQL中,当终止一个处于committingaltertabletostorageengine阶段的分区表操作时,InnoDB会尝试进行回滚并清理数据字典缓存。不幸的是,过程中发生了误删表缓存对象的情况——InnoDB错误地移除了另一张非目标表的缓存条目,导致引用计数不为0,触发断言失败并导致MySQL崩溃。2.复现步骤环
- java类加载顺序
3213213333332132
java
package com.demo;
/**
* @Description 类加载顺序
* @author FuJianyong
* 2015-2-6上午11:21:37
*/
public class ClassLoaderSequence {
String s1 = "成员属性";
static String s2 = "
- Hibernate与mybitas的比较
BlueSkator
sqlHibernate框架ibatisorm
第一章 Hibernate与MyBatis
Hibernate 是当前最流行的O/R mapping框架,它出身于sf.net,现在已经成为Jboss的一部分。 Mybatis 是另外一种优秀的O/R mapping框架。目前属于apache的一个子项目。
MyBatis 参考资料官网:http:
- php多维数组排序以及实际工作中的应用
dcj3sjt126com
PHPusortuasort
自定义排序函数返回false或负数意味着第一个参数应该排在第二个参数的前面, 正数或true反之, 0相等usort不保存键名uasort 键名会保存下来uksort 排序是对键名进行的
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8&q
- DOM改变字体大小
周华华
前端
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml&q
- c3p0的配置
g21121
c3p0
c3p0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。c3p0的下载地址是:http://sourceforge.net/projects/c3p0/这里可以下载到c3p0最新版本。
以在spring中配置dataSource为例:
<!-- spring加载资源文件 -->
<bean name="prope
- Java获取工程路径的几种方法
510888780
java
第一种:
File f = new File(this.getClass().getResource("/").getPath());
System.out.println(f);
结果:
C:\Documents%20and%20Settings\Administrator\workspace\projectName\bin
获取当前类的所在工程路径;
如果不加“
- 在类Unix系统下实现SSH免密码登录服务器
Harry642
免密ssh
1.客户机
(1)执行ssh-keygen -t rsa -C "
[email protected]"生成公钥,xxx为自定义大email地址
(2)执行scp ~/.ssh/id_rsa.pub root@xxxxxxxxx:/tmp将公钥拷贝到服务器上,xxx为服务器地址
(3)执行cat
- Java新手入门的30个基本概念一
aijuans
javajava 入门新手
在我们学习Java的过程中,掌握其中的基本概念对我们的学习无论是J2SE,J2EE,J2ME都是很重要的,J2SE是Java的基础,所以有必要对其中的基本概念做以归纳,以便大家在以后的学习过程中更好的理解java的精髓,在此我总结了30条基本的概念。 Java概述: 目前Java主要应用于中间件的开发(middleware)---处理客户机于服务器之间的通信技术,早期的实践证明,Java不适合
- Memcached for windows 简单介绍
antlove
javaWebwindowscachememcached
1. 安装memcached server
a. 下载memcached-1.2.6-win32-bin.zip
b. 解压缩,dos 窗口切换到 memcached.exe所在目录,运行memcached.exe -d install
c.启动memcached Server,直接在dos窗口键入 net start "memcached Server&quo
- 数据库对象的视图和索引
百合不是茶
索引oeacle数据库视图
视图
视图是从一个表或视图导出的表,也可以是从多个表或视图导出的表。视图是一个虚表,数据库不对视图所对应的数据进行实际存储,只存储视图的定义,对视图的数据进行操作时,只能将字段定义为视图,不能将具体的数据定义为视图
为什么oracle需要视图;
&
- Mockito(一) --入门篇
bijian1013
持续集成mockito单元测试
Mockito是一个针对Java的mocking框架,它与EasyMock和jMock很相似,但是通过在执行后校验什么已经被调用,它消除了对期望 行为(expectations)的需要。其它的mocking库需要你在执行前记录期望行为(expectations),而这导致了丑陋的初始化代码。
&nb
- 精通Oracle10编程SQL(5)SQL函数
bijian1013
oracle数据库plsql
/*
* SQL函数
*/
--数字函数
--ABS(n):返回数字n的绝对值
declare
v_abs number(6,2);
begin
v_abs:=abs(&no);
dbms_output.put_line('绝对值:'||v_abs);
end;
--ACOS(n):返回数字n的反余弦值,输入值的范围是-1~1,输出值的单位为弧度
- 【Log4j一】Log4j总体介绍
bit1129
log4j
Log4j组件:Logger、Appender、Layout
Log4j核心包含三个组件:logger、appender和layout。这三个组件协作提供日志功能:
日志的输出目标
日志的输出格式
日志的输出级别(是否抑制日志的输出)
logger继承特性
A logger is said to be an ancestor of anothe
- Java IO笔记
白糖_
java
public static void main(String[] args) throws IOException {
//输入流
InputStream in = Test.class.getResourceAsStream("/test");
InputStreamReader isr = new InputStreamReader(in);
Bu
- Docker 监控
ronin47
docker监控
目前项目内部署了docker,于是涉及到关于监控的事情,参考一些经典实例以及一些自己的想法,总结一下思路。 1、关于监控的内容 监控宿主机本身
监控宿主机本身还是比较简单的,同其他服务器监控类似,对cpu、network、io、disk等做通用的检查,这里不再细说。
额外的,因为是docker的
- java-顺时针打印图形
bylijinnan
java
一个画图程序 要求打印出:
1.int i=5;
2.1 2 3 4 5
3.16 17 18 19 6
4.15 24 25 20 7
5.14 23 22 21 8
6.13 12 11 10 9
7.
8.int i=6
9.1 2 3 4 5 6
10.20 21 22 23 24 7
11.19
- 关于iReport汉化版强制使用英文的配置方法
Kai_Ge
iReport汉化英文版
对于那些具有强迫症的工程师来说,软件汉化固然好用,但是汉化不完整却极为头疼,本方法针对iReport汉化不完整的情况,强制使用英文版,方法如下:
在 iReport 安装路径下的 etc/ireport.conf 里增加红色部分启动参数,即可变为英文版。
# ${HOME} will be replaced by user home directory accordin
- [并行计算]论宇宙的可计算性
comsci
并行计算
现在我们知道,一个涡旋系统具有并行计算能力.按照自然运动理论,这个系统也同时具有存储能力,同时具备计算和存储能力的系统,在某种条件下一般都会产生意识......
那么,这种概念让我们推论出一个结论
&nb
- 用OpenGL实现无限循环的coverflow
dai_lm
androidcoverflow
网上找了很久,都是用Gallery实现的,效果不是很满意,结果发现这个用OpenGL实现的,稍微修改了一下源码,实现了无限循环功能
源码地址:
https://github.com/jackfengji/glcoverflow
public class CoverFlowOpenGL extends GLSurfaceView implements
GLSurfaceV
- JAVA数据计算的几个解决方案1
datamachine
javaHibernate计算
老大丢过来的软件跑了10天,摸到点门道,正好跟以前攒的私房有关联,整理存档。
-----------------------------华丽的分割线-------------------------------------
数据计算层是指介于数据存储和应用程序之间,负责计算数据存储层的数据,并将计算结果返回应用程序的层次。J
&nbs
- 简单的用户授权系统,利用给user表添加一个字段标识管理员的方式
dcj3sjt126com
yii
怎么创建一个简单的(非 RBAC)用户授权系统
通过查看论坛,我发现这是一个常见的问题,所以我决定写这篇文章。
本文只包括授权系统.假设你已经知道怎么创建身份验证系统(登录)。 数据库
首先在 user 表创建一个新的字段(integer 类型),字段名 'accessLevel',它定义了用户的访问权限 扩展 CWebUser 类
在配置文件(一般为 protecte
- 未选之路
dcj3sjt126com
诗
作者:罗伯特*费罗斯特
黄色的树林里分出两条路,
可惜我不能同时去涉足,
我在那路口久久伫立,
我向着一条路极目望去,
直到它消失在丛林深处.
但我却选了另外一条路,
它荒草萋萋,十分幽寂;
显得更诱人,更美丽,
虽然在这两条小路上,
都很少留下旅人的足迹.
那天清晨落叶满地,
两条路都未见脚印痕迹.
呵,留下一条路等改日再
- Java处理15位身份证变18位
蕃薯耀
18位身份证变15位15位身份证变18位身份证转换
15位身份证变18位,18位身份证变15位
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 201
- SpringMVC4零配置--应用上下文配置【AppConfig】
hanqunfeng
springmvc4
从spring3.0开始,Spring将JavaConfig整合到核心模块,普通的POJO只需要标注@Configuration注解,就可以成为spring配置类,并通过在方法上标注@Bean注解的方式注入bean。
Xml配置和Java类配置对比如下:
applicationContext-AppConfig.xml
<!-- 激活自动代理功能 参看:
- Android中webview跟JAVASCRIPT中的交互
jackyrong
JavaScripthtmlandroid脚本
在android的应用程序中,可以直接调用webview中的javascript代码,而webview中的javascript代码,也可以去调用ANDROID应用程序(也就是JAVA部分的代码).下面举例说明之:
1 JAVASCRIPT脚本调用android程序
要在webview中,调用addJavascriptInterface(OBJ,int
- 8个最佳Web开发资源推荐
lampcy
编程Web程序员
Web开发对程序员来说是一项较为复杂的工作,程序员需要快速地满足用户需求。如今很多的在线资源可以给程序员提供帮助,比如指导手册、在线课程和一些参考资料,而且这些资源基本都是免费和适合初学者的。无论你是需要选择一门新的编程语言,或是了解最新的标准,还是需要从其他地方找到一些灵感,我们这里为你整理了一些很好的Web开发资源,帮助你更成功地进行Web开发。
这里列出10个最佳Web开发资源,它们都是受
- 架构师之面试------jdk的hashMap实现
nannan408
HashMap
1.前言。
如题。
2.详述。
(1)hashMap算法就是数组链表。数组存放的元素是键值对。jdk通过移位算法(其实也就是简单的加乘算法),如下代码来生成数组下标(生成后indexFor一下就成下标了)。
static int hash(int h)
{
h ^= (h >>> 20) ^ (h >>>
- html禁止清除input文本输入缓存
Rainbow702
html缓存input输入框change
多数浏览器默认会缓存input的值,只有使用ctl+F5强制刷新的才可以清除缓存记录。
如果不想让浏览器缓存input的值,有2种方法:
方法一: 在不想使用缓存的input中添加 autocomplete="off";
<input type="text" autocomplete="off" n
- POJO和JavaBean的区别和联系
tjmljw
POJOjava beans
POJO 和JavaBean是我们常见的两个关键字,一般容易混淆,POJO全称是Plain Ordinary Java Object / Pure Old Java Object,中文可以翻译成:普通Java类,具有一部分getter/setter方法的那种类就可以称作POJO,但是JavaBean则比 POJO复杂很多, Java Bean 是可复用的组件,对 Java Bean 并没有严格的规
- java中单例的五种写法
liuxiaoling
java单例
/**
* 单例模式的五种写法:
* 1、懒汉
* 2、恶汉
* 3、静态内部类
* 4、枚举
* 5、双重校验锁
*/
/**
* 五、 双重校验锁,在当前的内存模型中无效
*/
class LockSingleton
{
private volatile static LockSingleton singleton;
pri