- 【Electron】vue+electron应用设置菜单
姑老爷呀
electronvue.jsjavascript
一、前言本文主要介绍electron应用如何自定义菜单,以及在哪些地方可以使用Menu模块。一般情况menu只是设置给mac系统的,因为windows系统在应用做了无边框之后,是不会显示应用菜单的(这里Linux暂时不考虑)。点击查看Menu详情二、适用场景及实施1.应用内菜单自定义这个菜单是指的这里这里主要用到Menu的两个Api,分别是Menu.buildFromTemplate(templa
- vue+electron将项目打包为exe程序---成功跨过所有坑,完美打包
suoh's Blog
✿✿--electron❤️❤️--vue2核心技术栈electron打包打包为exevue项目打包为exe
公司的一个项目需求,需要技术上采用C/S的技术架构,因此我就开始了将vue项目打包为exe程序的旅途~~~exe文件是C/S桌面应用程序,web项目是B/S结构,服务器/客户端程序,它们是两个不同的东西此文章针对于有一定基础的vue前端工作者。打包初体验第一步将自己的vue项目进行打包npmrunbuild可以看到打包后的dist文件第二步安装electronnpminstallelectron安
- vue+electron IPC+sql相关开发(一)
香蕉可乐荷包蛋
vue+electronvue.jselectron前端
IPC(Inter-ProcessCommunication,进程间通信)是主进程和渲染进程之间进行通信的核心机制。electron+vue+sql本地数据交互开发1.IPC基本概念Electron应用由两个主要进程组成:主进程:负责管理应用的生命周期、窗口创建等。渲染进程:负责运行网页内容(即Vue或React等前端代码)。由于主进程和渲染进程运行在不同的环境中,它们之间需要通过ipcMain和
- vue+electron ipc+sql相关开发(三)
香蕉可乐荷包蛋
vue+electronvue.jselectronsql
在Electron中使用IPC(Inter-ProcessCommunication)与SQLite数据库进行通信是一个常见的模式,特别是在需要将数据库操作从渲染进程(Vue.js)移到主进程(Electron)的情况下。这样可以更好地管理数据库连接和提高安全性。下一篇介绍结合axios写成通用接口形式,虽然没啥卵用(个人觉得),只是前端调用好看╮(╯▽╰)╭建议将读取固定安装路径的数据改成,在运
- vue+electron IPC+sql相关开发(二)
香蕉可乐荷包蛋
vue+electronsqlvue.jselectronsql
在Electron应用中,使用IPC(进程间通信)来控制SQL数据库是一个常见的做法。主进程通常负责数据库操作,而渲染进程通过IPC请求这些操作。在这里以SQLite数据库为例,介绍怎么使用IPC来结合SQL的相关开发。其他SQL开发大同小异。1.安装必要的依赖首先,您需要安装sqlite3模块来操作SQLite数据库。您可以在主进程中安装这个模块。npminstallsqlite32.设置Ele
- vue+electron 打包发布
myang,就这样
vue+electronelectron学习javascript前端vue
一、Electron简介Electron是什么?Electron是GitHub开发的一个开源框架,是网页应用(webapps)的一个原生包装层,它允许使用Node.js(作为后端)和Chromium(作为前端)完成桌面GUI应用程序的开发。Electron可以用于构建具有HTML、CSS、JavaScript的跨平台桌面应用程序,它通过将Chromium和node.js合同一个运行的环境中来实现这
- Vue+Electron项目学习(一)(electron-builder + electron-updater + electron-log)
那年的人和事
Electron学习记录笔记vue.jselectron前端javascript
创建Vue项目这里使用vueui创建项目我选择使用yarn作为包管理器,各位看官按自己的喜好来~我选择自己预定的模板,大家可根据自己喜好选择。创建项目,完成vue项目创建。创建好的项目结构如下添加electron-builder插件使用VSCode打开项目,如下图:打开终端,输入以下命令,等待执行完成,安装electron-builder插件。yarnaddelectron-chromedrive
- Vue+Electron下Vuex的Dispatch没有效果的解决方案
jxtxzzw
这个问题是解决基于vue和electron的开发中使用vuex的dispatch无效的问题,即解决了Please,don'tusedirectcommit's,usedispatchinsteadofthis.问题。先允许我梳理一下目录结构,以便阅读的时候不会一头雾水,你到底说的这个文件是哪个……1558185192156其中/src/main是存放主配置文件的,/src/render下面有sto
- 【Electron】vue+electron实现无边框窗口
前端码农小王
electronvue.jsui
一、前言无边框窗口是不带外壳(包括窗口边框、工具栏等),只含有网页内容的窗口。对于一个产品来讲,桌面应用带边框的很少,因为丑(我们的UI觉得–与我无关-.-)。因此我们就来展开说下,在做无边框窗口时候需要注意的事项以及我踩过的坑。二、实现方案1.创建无边框窗口要创建无边框窗口,只需在BrowserWindow的options中将frame设置为false:const{BrowserWindow}=
- vue+electron问题汇总
一万种可能-码农
vue.jselectron前端
1.Vue_BugFailedtofetchextension,trying4moretimes描述:项目启动时报错解决:注释图片中内容2.Modulenotfound:Error:Can’tresolve‘fs’in描述:项目启动报错解决:vue.config.js中添加图中数据3.导入electron.remote后,remote为undefined解决:开启remote模块enableRem
- vue3+ts+vite+electron搭建桌面应用
Bennett_G
electronvue.js
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档vue3+ts+vite+electron搭建桌面应用前言一、版本背景介绍二、过程1.搭建vite+vue-ts的项目2.接入electron3.electron启动4.electron打包5.项目目录梳理三、打包首页加载空白问题(补充)前言提示:开发桌面应用,就不得不提Electron,之前使用vue+electron,官方提供了V
- Vue2.6.11+electron13.0.0在渲染进程中使用remote,报错:“TypeError: fs.existsSync is not a function“。
模范生-
前端node.jsvue.js前端
Vue2.6.11+electron13.0.0在渲染进程中使用remote,报错:"TypeError:fs.existsSyncisnotafunction"。前言错误原因解决前言Vue+electron项目,当在渲染进程中调用remote时导致页面空白,控制台报错TypeError:fs.existsSyncisnotafunction错误原因渲染进程没有集成node环境因此无法使用fs包,
- vuerequire不存在页面_vue+electron中的app.vue中使用require,导致页面空白
勃斯丶李 mkq0.~
vuerequire不存在页面
代码MyAPPlet{remote}=require('electron');exportdefault{methods:{close(){remote.getCurrentWindow().close();},minisize(){remote.getCurrentWindow().minimize();},restore(){remote.getCurrentWindow().restore(
- Vue+Electron学习系列 (三) -- 自动更新
Bennett_G
vueElectronvueelectron
Vue+Electron学习系列1️⃣Vue+Electron学习系列(一)--初识2️⃣Vue+Electron学习系列(二)--打包发布3️⃣Vue+Electron学习系列(三)--自动更新4️⃣Vue+Electron学习系列(四)--自动更新进阶文章目录目录Vue+Electron学习系列前言一、修改配置文件二、主进程监听前言默认已安装如下扩展:vue:3.0.0-rc.12electr
- Vue+Electron打包桌面应用(从零到一完整教程)
萧寂173
electronvuevue.jselectronarcgis
文章目录一.使用vite+vue3+js方式一.构建桌面应用1.创建项目2.安装依赖运行项目3.配置Electron4.修改配置文件1)vite.config.js2)main.js(项目根目录新增)3)preload.js(项目根目录下新增)4)package.json5.打包vue项目6.运行electron二.热更新开发环境1.编辑main.js2.同时开启vite和electron服务3.
- vue+electron
HONEYMOOM
1.安装/升级vue-cli首先确认vue-cli版本:vue–V如果本地使用的是vue-cli2.x或者更早版本,可先卸载:cnpmuninstallvue-cli–g之后执行cnpminstall@vue/cli–g2.创建vue项目vuecreateelectron-vue-demo按照步骤一步一步确认安装3.自动安装electronvueaddelectron-buildera.在安装过程
- vue+electron开发踩坑记录
feiniao8651
electronvueelectron
文章目录背景框架选型开发过程踩坑记录问题1vue-cli2无法使用vueclipluginelectronbuilder问题2vuecomponent调用ipcRenderer注意!!!补充:vue-cli2和vue-cli3/4的一些区别参考资料背景最近由于项目上的要求,需要开发一个基于数据展示页面。同时保证数据访问有可控性和安全性,需要对设备进行验证,保证非认证设备不会访问到数据。框架选型因为
- 最简洁Vue+Electron项目搭建教程
Annun
开发环境node:v14.19.3npm:6.14.17VueCLI:v5.0.8创建Vue项目正常创建vue项目,并能成功运行#创建项目vuecreateproject#检查项目cdprojectnpmrunserve配置Electron安装依赖##添加electron构建工具vueaddelectron-builder#添加electronnpminstallelectron配置package
- js axios vue 带身份验证的图片加载转base64(二进制文件资源处理)
1999笃行
javascriptvue.js前端
版本信息"vue":"^2.6.14""axios":"^0.27.2"背景vue+electron需要相应信息列表的缩略图;服务器端对所有请求都要求携带登录身份信息。使用独立接口加载缩略图。代码//此处的http是axios的简单封装,在封装的http中做了登录凭证获取//responseType:'blob'重要http.post(url,{imageid:1},{responseType:'
- vue+electron桌面
猪八戒1.0
前端Vuevue.js前端javascript
node.js安装cnpm下载npminstall-gcnpm--registry=https://registry.npmmirror.comvue脚手架安装cnpminstall-g@vue/cli安装electron脚手架npminstallelectron-g创建项目vuecreate项目名一顿选择添加vue+electron脚手架vueaddelectron-builder运行npmru
- vue+electron一键入门
An_s
vue.jselectron前端
前言帮公司弄了一个vue+electron项目,里面用到了axios、element-ui、ue-router、js-md5、sqlite3这些依赖库,其中sqlite3比较难搞下面会详细展开来讲,同时也涉及打包(window包、mac包)开始其实项目整体没啥好讲,我就讲一下数据库的封装、打包配置注意事项即可sqlite3数据库使用ps:你要有python2.7版本npminstallsqlite
- vue+electron踩坑吐血整理
瓜田猹
1.报错:'cannotuseimportstatementoutsideamodule'以上错误来看node不支持ES6的import写法,所以目的是想如何将ES6转换成ES5,我们只需执行下图的命令2而非命令1,vue-cli-serve脚手架会提前编译ES61.png2.Tray配置的托盘图标不显示问题leticonPath=path.join(__static,'images/logo.p
- vue+electron开发桌面应用程序.exe
一入坑不回头
vuevue+electronvue.jsvue
vue+electron开发桌面应用程序.exe1、安装vue2、安装electron3、安装electron-builder1、安装vuevuecreateelectron-vue2、安装electroncnpmielectron-g3、安装electron-buildervueaddelectron-builder会让你选择版本,选择最新的即可。最后运行:npmrunelectron:serv
- vue+electron 跨平台桌面应用开发实战教程
chendawen2014
工具的使用Vue.jsnode.jsvue.jselectron前端
链接vue+electron跨平台桌面应用开发实战教程_家有喜娟儿的博客-CSDN博客_vue+electron操作过程中遇到的Failedtoloadpluginimport:Cannotfindmodule'eslint-plugin-import'问题的解决方法node.js-无法加载插件导入:'eslint-plugin-import'-Thinbug打包的时候才会遇到一些报错,然后百度了
- vue+electron 打包,自动更新,修改默认安装目录
Code鱼
vue桌面应用前端electron桌面应用
electron打包,自动更新,修改默认安装目录使用克隆项目安装依赖开发环境启动正式打包技术栈文档应用自动更新1.配置`vue.config.js`中的应用更新服务器地址2.在主进程写更新应用逻辑3.打包一个应用(v1.0.0)4.打包一个升级版的应用(v1.1.0)其他打包打包配置vue.config.js完整示例安装时修改默认目录1.在nsis添加`include`属性:2.根目录新建`ins
- vue+electron中实现文件下载打开wps预览
Vivqst
vue.jselectronjavascript
下载事件win.webContents.downloadURL(url)触发session的will-download事件win.webContents.session.on('will-download',(event,downloadItem,webContents)=>{//设置文件保存路径//如果用户没有设置保存路径,Electron将使用默认方式来确定保存路径(通常会提示保存对话框)it
- 2022年最新Vue+electron项目创建
web13618542420
面试学习路线阿里巴巴vue.jselectron前端开发语言数据库
一、前言大多数文章都停留在electron-vue中,但是这个库不怎么更新了,最近的更新是九月前,看了很多文章都换其他的工具来构建了,这里推荐GITHUB一个大佬写的基于vue-cli的插件,构建项目非常简单!插件的GITHUB源代码话不多说,开始创建项目!二、环境说明首先确保你的Node、vue-cli、cnpm安装好,具体安装可以查看官网。需要:Node环境,我的是16.x版本vue-cli3
- electron 生成 arm64 的包
xiaguangbo
electronjavascript前端
vue+electron:https://blog.csdn.net/qq1195566313/article/details/131713875打包配置修改如下electronBuilder.build({config:{appId:'com.example.app',productName:'vite-electron',directories:{output:path.join(proces
- 从零搭建vue+electron桌面应用
程鹏;
vue.jselectron前端
从零搭建vue+electron桌面应用一、准备工作1.全局下载electron2.全局下载vue脚手架3.创建vue项目(这里用的是vue2版本)4.安装打包插件5.安装electron-builder,安装后可以直接生成主进程的配置文件6.在vue.config.js中添加以下配置二、运行项目三、打包四、渲染进程和主进程通信1.在background.js中引入ipcMain并书写监听代码2.
- vue+electron项目实战总结(遇到了哪些问题,是如何解决的,哪个阶段需要做什么,附带一些常用方法)
阿波次嘚
vue.jselectron前端
electron作为一个将网页打包成桌面应用的工具非常强大,在使用electron的时候要相信它可以实现所有现代软件能够支撑的功能,下面我总结一下我在vue+electron经过4次大版本更新才趋于稳定的开发经验。一、开发套路:消息通信+数据驱动使用vue+electron开发分为主进程(main.js)和渲染进程(vue网页)消息通信通过主进程和渲染进程间通信机制可以将功能划分,网页能够实现的功
- 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