- RK3568平台(camera篇)opencv处理图像
嵌入式_笔记
瑞芯微opencv人工智能计算机视觉
一.颜色转换cv2.cvtColor()函数功能:将一幅图像从一个色彩空间转换到另一个色彩空间。函数原型:cv2.cvtColor(src,code,dst=None,dstCn=None)参数定义:src:要转换的源文件code,转换的色彩空间,在opencv中有超过150种颜色空间转换方法,但是经常用的只有BGR-灰度图和BGR-HSVBGR和灰度图的转换使用cv2.COLOR_BGR2GRA
- PyQt5窗口背景设置全攻略:三种方法实现精美界面
QSS样式表法(最常用)特点:声明式语法、支持CSS特性、子控件自动继承样式1.纯色背景设置创建主窗口并设置黄色背景win=QMainWindow()win.setObjectName("MainWindow")win.setStyleSheet("#MainWindow{background-color:yellow}")2.背景图片设置(自适应尺寸)使用border-image实现背景图平铺w
- python学习(六)字典
August________
字典学习如何访问和修改字典中的信息学习如何遍历字典中的数据学习储存字典的列表,存储列表中的字典和存储字典中的字典。理解字典,可以更准确的为各种真实物体建模。一个简单的字典alien_0={'color':'green','points':5}print(alien_0['color'])print(alien_0['points'])green5使用字典字典就是一系列的键-值对,每个键都有一个值相
- 2018-11-29作业 翻页
沦陷_99999
翻页.box1{width:960px;height:42px;border:1pxsolid#8f8f8f;margin:200pxauto;}.box2{width:100%;height:42px;margin:0auto;}.box3,.box13{width:42px;background-color:gold;padding:5px10px;margin-top:5px;}.box3a
- ESP32+MicroPython随机颜色生成器
sunsunyu03
pythonMicroPythonESP32ESP8266WS2812B
概述本文档将介绍一个基于MicroPython环境下,为ESP32(基本含有MicroPython环境中都可以使用)开发板上的WS2812B灯珠设计的随机颜色生成器。此生成器包括了一个自定义的随机数生成器Random类和一个用于生成随机颜色的RandomColor类。该方案特别适合于那些固件中未包含标准随机数生成功能的情况。优点独立性:由于集成了自定义的随机数生成器,使得代码在缺乏系统级随机数支持
- 【Python】Pillow 2
宅男很神经
python开发语言
3.2.1色彩空间(ColorSpace)与色彩模型(ColorModel)基础色彩模型(ColorModel):色彩模型是一种抽象的数学模型,用一组数值(通常是三个或四个分量)来描述颜色。常见的色彩模型有:RGB(Red,Green,Blue):加色模型,常用于显示器、扫描仪、数码相机。通过混合不同强度的红、绿、蓝三原色光来产生各种颜色。CMY(Cyan,Magenta,Yellow):减色模型
- qpython pillow_Python Pillow 模块
安装Pillow模块pipinstallpillowImage模块PIL最重要的类是Imageclass,你可以通过多种方法创建这个类的实例;你可以从文件加载图像,或者处理其他图像,或者从scratch创建。Image类属性mode:图片模式size:图片大小width:图片长度height:图片宽度创建1个张图片Image.new(mode,size,color)mode:颜色模式size:(长
- iOS 解决 veiw 之间 因为父view alpha 等于0 导致全部透明的问题
村雨灬龑
首先先看一段代码,矛盾的起因,因为父view的alpha=0,而又想让子view能够显示出来,不受父view的alpha=0的影响。UIView*view=[[UIViewalloc]init];view.backgroundColor=[UIColorredColor];//因为下面的label没有显示是因为父view的alpha=0view.alpha=0;view.frame=CGRectM
- 前端,元素的层级和背景
沦陷_99999
z-index.box1{width:200px;height:200px;background-color:#0bcd96;position:relative;z-index:3;}.box2{width:200px;height:200px;background-color:#1e389a;position:absolute;left:100px;top:100px;}.box3{width:
- iOS使用UIAppearance
培根芝士
iOS
iOS5及其以后提供了一个比较强大的工具UIAppearance,我们通过UIAppearance设置一些UI的全局效果,这样就可以很方便的实现UI的自定义效果又能最简单的实现统一界面风格,它提供如下两个方法。+(id)appearance//这个方法是统一全部改,比如你设置UINavBar的tintColor,你可以这样写:[[UINavigationBarappearance]setTintC
- 【CSS-6】深入理解CSS复合选择器:提升样式表的精确性与效率
AllenBright
#CSScss前端
CSS选择器是前端开发的基石,而复合选择器则是其中最强大且实用的工具之一。本文将全面解析CSS复合选择器的类型、用法、优先级规则以及最佳实践,帮助你编写更高效、更精确的样式表。1.什么是复合选择器?复合选择器是通过组合多个简单选择器来创建更具体的选择规则。它们允许开发者精确地定位文档树中的特定元素,而无需添加过多的类或ID。/*简单选择器*/p{color:blue;}/*复合选择器*/artic
- css :root 选择器
:rootcss伪类匹配文档的根元素。对于HTML来说,:root表示元素,除了优先级更高之外,与html选择器相同。在声明全局css变量时:root会很有用::root{--ck-highlight-pen-red:#e91314;--ck-highlight-pen-blue:dodgerblue;}.pen-black{color:var(--ck-highlight-pen-black);
- 伪类选择器:root的妙用
weixin_33921089
javascriptViewUI
css3的元素旋转功能非常强大,也非常吸引人,但是很多时候因为浏览器使用率的问题,我们必需要想办法兼容一些低版本的浏览器,特别是ie这朵奇葩。想要实现元素旋转本来很简单的一个属性就能实现,那就是transform:rotate(xxdeg)。举个例子:实现一个层旋转270deg。#demo{width:300px;height:200px;background-color:#FF80C0;marg
- CSS动画实例
隆海博客
web前端#CSScsscss3
CSS动画实例一、进度条二、涨水三、纯CSS实现轮番播图一、进度条html代码css代码.d1{width:400px;height:20px;background-color:gray;}.bar{width:10%;height:20px;background-color:blue;animation-name:jindu;animation-duration:3s;}@keyframesji
- css设置背景图片透明度
.demo{position:relative;width:500px;height:300px;line-height:50px;text-align:center;color:red;}.demo::before{content:"";position:absolute;left:0;top:0;z-index:-1;/*放在内容背后*/width:500px;height:300px;bac
- CSS半透明效果实现方案详解
芜青
笔记前端开发css3css前端
HTML/CSS半透明效果实现指南半透明效果是现代网页设计中常用的视觉技术,可以创建层次感、焦点引导和美观的界面。本文介绍几种优雅的实现方式,并提供一个综合的演示页面。实现半透明效果的常用方法1.RGBA/HSLA颜色模式.rgba-example{background-color:rgba(255,0,0,0.5);/*红色,50%透明度*/}.hsla-example{background-c
- echarts实现两个饼图嵌套
js_user
echarts前端javascriptcsshtmlvue.js
效果展示需求:内层饼图为一级分类,外层饼图为二级分类。内外层一级分类和多属的二级分类颜色一样,且悬浮二级分类,一级分类同样有高亮效果。一级分类和二级分类悬浮有释义说明(解释这个分类的含义)由于二级分类只展示其中一部分,所以一级分类和二级分类所占角度不一样。关键代码展示**定义option**constcolors=["#fc8251","#5470c6","#91cd77","#ef6567","
- html+css实战64-综合案例3-图片完成
前端大歌谣
htmlcss前端
Documentbody{background-color:#f5f5f5;}.goods{width:234px;height:300px;background-color:#fff;/*样式居中*/margin:0auto;text-align:center;}img{width:160px;}运行结果
- JavaWeb之Html-Css
孤独套餐
javawebhtmlcss前端
标题标签标题标签(到)是HTML中用于定义标题和子标题的元素。它们按照重要性从h1到h6递减,是最高级别的标题,通常用于页面主标题,是最低级别的标题。羊村守护者CSS选择器用来选取需要设置样式的元素标签元素选择器通过HTML元素名称选择元素/*选择所有的元素*/p{color:blue;}类选择器通过元素的class属性选择元素.navbar{background-color:rgb(125,15
- allegro artwork设置和颜色设置的导入导出
allegroartwork设置和颜色设置的导入导出2013-07-1213:17:36分类:WINDOWSallegro使用artwork出gerber的关键就是每张底片的颜色输出,所以能够导出颜色和artwork的设置对于提高工作效率而言是很有帮助的。首先是配置top层的颜色设置,然后view->colorviewsave=>把颜色设置保存下来。使用相同的办法可以把其他所以需要出gerber的
- Flutter 提取图像主色调 ColorScheme.fromImageProvider
愿天深海
flutter
从图像中提取主色调,用于动态适配颜色主题或者界面颜色。之前在Flutter应用里一直用的palette_generator插件,可以分析图像颜色,从中提取一系列主要的色调。最近发现这个谷歌官方的插件竟然不维护了,后续没有更新计划了。查找了一系列资料之后,才发现原来在Material3设计规范中有ColorScheme.fromImageProvider这么一个功能,用于从图像的主色调生成配色方案,
- Flutter控件归纳总结
Bryce李小白
flutter
Flutter的控件(Widget)是构建UI的基础,分为无状态(StatelessWidget)和有状态(StatefulWidget)两大类。以下是Flutter核心控件的系统归纳:一、基础布局控件Container通用容器:支持装饰(颜色、边框、阴影)、内外边距、尺寸约束。示例:Container(color:Colors.blue,padding:EdgeInsets.all(16))Ro
- 2024信友队智灵班春季 Test1 总结
4月模考死亡回放模考时间线1:30比赛开始,读T1宇宙爆炸的题1:50自己手模了几组样例,得出了一个错误结论,打出了第一版错误代码,然后上交(WrongAnswer20\color{red}\text{Wrong\Answer\20}WrongAnswer20)中间拿了T2逃狱风云的部分分(WrongAnswer10\color{red}\text{Wrong\Answer\10}WrongAns
- 壁纸上传测试
壁纸上传测试body{font-family:Arial,sans-serif;max-width:800px;margin:0auto;padding:20px;background-color:#f5f5f5;}.container{background:white;padding:30px;border-radius:10px;box-shadow:02px10pxrgba(0,0,0,0.
- 微信小程序之自定义模态弹窗(带动画)实例-——-微信小程序实战系列(8)
.btn{width:80%;padding:20rpx0;border-radius:10rpx;text-align:center;margin:40rpx10%;background:#000;color:#fff;}/mask/.drawer_screen{width:100%;height:100%;position:fixed;top:0;left:0;z-index:1000;bac
- 初级网安作业笔记3
内容:自行搭建前端页面并分析运行成功界面:代码:用户登录|系统名称/*全局样式重置与基础设置*/:root{--primary-color:#1a73e8;--primary-hover:#1557b0;--error-color:#d93025;--text-color:#5f6368;--border-color:#dadce0;--bg-color:#f0f2f5;--transition-
- 设计模式——原型模式
舟景辞雾枝
软件设计模式设计模式原型模式java
原型模式1.克隆羊问题现在有一只羊tom,姓名为:tom,年龄为:1,颜色为:白色,请编写程序创建和tom羊属性完全相同的10只羊。2.传统方式解决克隆羊问题思路分析通过构造器手动new够需要数量的对象代码//Sheep类publicclassSheep{privateStringname;privateintage;privateStringcolor;publicSheep(Stringnam
- C++基础:enum class作用域枚举 (C++11)
坎坎坷坷.
C++基础知识c++
C++基础:enumclass作用域枚举介绍特点作用域强类型默认底层类型介绍enumclass是C++11引入的一种改进的枚举机制,主要改进了传统的enum类型的作用域控制问题,故也被称为作用域枚举(scopedenumerations)。那么,他到底解决了什么问题呢?看下面的代码:#includeenumColor{write,red,green,};intwrite=1;intmain(){s
- C++枚举:enum与enum class
qq_38196982
C++
1.enumC++中enum提供了另一种创建符号常量的方法,这种方式可以替代const。enum也允许定义新类型,使用enum的语法与使用结构相似。如对下述示例:enumcolor{red,orange,yellow,black};有2个含义:1)color称为新类型的名称,color被称为枚举,如同struct被称为结构体一个道理2)red,orange,yellow,black等为符号常量,默
- C++ 打印enum class枚举类
L-Super
C++细枝末节c++开发语言
前言C++11中引入了强类型的enumclass类型(或称为枚举类),但是有一点比较尴尬的是,std::cout标准流不支持输出enumclass类型。比如以下代码:#includeintmain(){enumclassColor{red,green=20,blue};Colorr=Color::blue;std::cout'}and'main()::Color')8|std::cout}MSVC
- tomcat基础与部署发布
暗黑小菠萝
Tomcat java web
从51cto搬家了,以后会更新在这里方便自己查看。
做项目一直用tomcat,都是配置到eclipse中使用,这几天有时间整理一下使用心得,有一些自己配置遇到的细节问题。
Tomcat:一个Servlets和JSP页面的容器,以提供网站服务。
一、Tomcat安装
安装方式:①运行.exe安装包
&n
- 网站架构发展的过程
ayaoxinchao
数据库应用服务器网站架构
1.初始阶段网站架构:应用程序、数据库、文件等资源在同一个服务器上
2.应用服务和数据服务分离:应用服务器、数据库服务器、文件服务器
3.使用缓存改善网站性能:为应用服务器提供本地缓存,但受限于应用服务器的内存容量,可以使用专门的缓存服务器,提供分布式缓存服务器架构
4.使用应用服务器集群改善网站的并发处理能力:使用负载均衡调度服务器,将来自客户端浏览器的访问请求分发到应用服务器集群中的任何
- [信息与安全]数据库的备份问题
comsci
数据库
如果你们建设的信息系统是采用中心-分支的模式,那么这里有一个问题
如果你的数据来自中心数据库,那么中心数据库如果出现故障,你的分支机构的数据如何保证安全呢?
是否应该在这种信息系统结构的基础上进行改造,容许分支机构的信息系统也备份一个中心数据库的文件呢?
&n
- 使用maven tomcat plugin插件debug关联源代码
商人shang
mavendebug查看源码tomcat-plugin
*首先需要配置好'''maven-tomcat7-plugin''',参见[[Maven开发Web项目]]的'''Tomcat'''部分。
*配置好后,在[[Eclipse]]中打开'''Debug Configurations'''界面,在'''Maven Build'''项下新建当前工程的调试。在'''Main'''选项卡中点击'''Browse Workspace...'''选择需要开发的
- 大访问量高并发
oloz
大访问量高并发
大访问量高并发的网站主要压力还是在于数据库的操作上,尽量避免频繁的请求数据库。下面简
要列出几点解决方案:
01、优化你的代码和查询语句,合理使用索引
02、使用缓存技术例如memcache、ecache将不经常变化的数据放入缓存之中
03、采用服务器集群、负载均衡分担大访问量高并发压力
04、数据读写分离
05、合理选用框架,合理架构(推荐分布式架构)。
- cache 服务器
小猪猪08
cache
Cache 即高速缓存.那么cache是怎么样提高系统性能与运行速度呢?是不是在任何情况下用cache都能提高性能?是不是cache用的越多就越好呢?我在近期开发的项目中有所体会,写下来当作总结也希望能跟大家一起探讨探讨,有错误的地方希望大家批评指正。
1.Cache 是怎么样工作的?
Cache 是分配在服务器上
- mysql存储过程
香水浓
mysql
Description:插入大量测试数据
use xmpl;
drop procedure if exists mockup_test_data_sp;
create procedure mockup_test_data_sp(
in number_of_records int
)
begin
declare cnt int;
declare name varch
- CSS的class、id、css文件名的常用命名规则
agevs
JavaScriptUI框架Ajaxcss
CSS的class、id、css文件名的常用命名规则
(一)常用的CSS命名规则
头:header
内容:content/container
尾:footer
导航:nav
侧栏:sidebar
栏目:column
页面外围控制整体布局宽度:wrapper
左右中:left right
- 全局数据源
AILIKES
javatomcatmysqljdbcJNDI
实验目的:为了研究两个项目同时访问一个全局数据源的时候是创建了一个数据源对象,还是创建了两个数据源对象。
1:将diuid和mysql驱动包(druid-1.0.2.jar和mysql-connector-java-5.1.15.jar)copy至%TOMCAT_HOME%/lib下;2:配置数据源,将JNDI在%TOMCAT_HOME%/conf/context.xml中配置好,格式如下:&l
- MYSQL的随机查询的实现方法
baalwolf
mysql
MYSQL的随机抽取实现方法。举个例子,要从tablename表中随机提取一条记录,大家一般的写法就是:SELECT * FROM tablename ORDER BY RAND() LIMIT 1。但是,后来我查了一下MYSQL的官方手册,里面针对RAND()的提示大概意思就是,在ORDER BY从句里面不能使用RAND()函数,因为这样会导致数据列被多次扫描。但是在MYSQL 3.23版本中,
- JAVA的getBytes()方法
bijian1013
javaeclipseunixOS
在Java中,String的getBytes()方法是得到一个操作系统默认的编码格式的字节数组。这个表示在不同OS下,返回的东西不一样!
String.getBytes(String decode)方法会根据指定的decode编码返回某字符串在该编码下的byte数组表示,如:
byte[] b_gbk = "
- AngularJS中操作Cookies
bijian1013
JavaScriptAngularJSCookies
如果你的应用足够大、足够复杂,那么你很快就会遇到这样一咱种情况:你需要在客户端存储一些状态信息,这些状态信息是跨session(会话)的。你可能还记得利用document.cookie接口直接操作纯文本cookie的痛苦经历。
幸运的是,这种方式已经一去不复返了,在所有现代浏览器中几乎
- [Maven学习笔记五]Maven聚合和继承特性
bit1129
maven
Maven聚合
在实际的项目中,一个项目通常会划分为多个模块,为了说明问题,以用户登陆这个小web应用为例。通常一个web应用分为三个模块:
1. 模型和数据持久化层user-core,
2. 业务逻辑层user-service以
3. web展现层user-web,
user-service依赖于user-core
user-web依赖于user-core和use
- 【JVM七】JVM知识点总结
bit1129
jvm
1. JVM运行模式
1.1 JVM运行时分为-server和-client两种模式,在32位机器上只有client模式的JVM。通常,64位的JVM默认都是使用server模式,因为server模式的JVM虽然启动慢点,但是,在运行过程,JVM会尽可能的进行优化
1.2 JVM分为三种字节码解释执行方式:mixed mode, interpret mode以及compiler
- linux下查看nginx、apache、mysql、php的编译参数
ronin47
在linux平台下的应用,最流行的莫过于nginx、apache、mysql、php几个。而这几个常用的应用,在手工编译完以后,在其他一些情况下(如:新增模块),往往想要查看当初都使用了那些参数进行的编译。这时候就可以利用以下方法查看。
1、nginx
[root@361way ~]# /App/nginx/sbin/nginx -V
nginx: nginx version: nginx/
- unity中运用Resources.Load的方法?
brotherlamp
unity视频unity资料unity自学unityunity教程
问:unity中运用Resources.Load的方法?
答:Resources.Load是unity本地动态加载资本所用的方法,也即是你想动态加载的时分才用到它,比方枪弹,特效,某些实时替换的图像什么的,主张此文件夹不要放太多东西,在打包的时分,它会独自把里边的一切东西都会集打包到一同,不论里边有没有你用的东西,所以大多数资本应该是自个建文件放置
1、unity实时替换的物体即是依据环境条件
- 线段树-入门
bylijinnan
java算法线段树
/**
* 线段树入门
* 问题:已知线段[2,5] [4,6] [0,7];求点2,4,7分别出现了多少次
* 以下代码建立的线段树用链表来保存,且树的叶子结点类似[i,i]
*
* 参考链接:http://hi.baidu.com/semluhiigubbqvq/item/be736a33a8864789f4e4ad18
* @author lijinna
- 全选与反选
chicony
全选
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>全选与反选</title>
- vim一些简单记录
chenchao051
vim
mac在/usr/share/vim/vimrc linux在/etc/vimrc
1、问:后退键不能删除数据,不能往后退怎么办?
答:在vimrc中加入set backspace=2
2、问:如何控制tab键的缩进?
答:在vimrc中加入set tabstop=4 (任何
- Sublime Text 快捷键
daizj
快捷键sublime
[size=large][/size]Sublime Text快捷键:Ctrl+Shift+P:打开命令面板Ctrl+P:搜索项目中的文件Ctrl+G:跳转到第几行Ctrl+W:关闭当前打开文件Ctrl+Shift+W:关闭所有打开文件Ctrl+Shift+V:粘贴并格式化Ctrl+D:选择单词,重复可增加选择下一个相同的单词Ctrl+L:选择行,重复可依次增加选择下一行Ctrl+Shift+L:
- php 引用(&)详解
dcj3sjt126com
PHP
在PHP 中引用的意思是:不同的名字访问同一个变量内容. 与C语言中的指针是有差别的.C语言中的指针里面存储的是变量的内容在内存中存放的地址 变量的引用 PHP 的引用允许你用两个变量来指向同一个内容 复制代码代码如下:
<?
$a="ABC";
$b =&$a;
echo
- SVN中trunk,branches,tags用法详解
dcj3sjt126com
SVN
Subversion有一个很标准的目录结构,是这样的。比如项目是proj,svn地址为svn://proj/,那么标准的svn布局是svn://proj/|+-trunk+-branches+-tags这是一个标准的布局,trunk为主开发目录,branches为分支开发目录,tags为tag存档目录(不允许修改)。但是具体这几个目录应该如何使用,svn并没有明确的规范,更多的还是用户自己的习惯。
- 对软件设计的思考
e200702084
设计模式数据结构算法ssh活动
软件设计的宏观与微观
软件开发是一种高智商的开发活动。一个优秀的软件设计人员不仅要从宏观上把握软件之间的开发,也要从微观上把握软件之间的开发。宏观上,可以应用面向对象设计,采用流行的SSH架构,采用web层,业务逻辑层,持久层分层架构。采用设计模式提供系统的健壮性和可维护性。微观上,对于一个类,甚至方法的调用,从计算机的角度模拟程序的运行情况。了解内存分配,参数传
- 同步、异步、阻塞、非阻塞
geeksun
非阻塞
同步、异步、阻塞、非阻塞这几个概念有时有点混淆,在此文试图解释一下。
同步:发出方法调用后,当没有返回结果,当前线程会一直在等待(阻塞)状态。
场景:打电话,营业厅窗口办业务、B/S架构的http请求-响应模式。
异步:方法调用后不立即返回结果,调用结果通过状态、通知或回调通知方法调用者或接收者。异步方法调用后,当前线程不会阻塞,会继续执行其他任务。
实现:
- Reverse SSH Tunnel 反向打洞實錄
hongtoushizi
ssh
實際的操作步驟:
# 首先,在客戶那理的機器下指令連回我們自己的 Server,並設定自己 Server 上的 12345 port 會對應到幾器上的 SSH port
ssh -NfR 12345:localhost:22
[email protected]
# 然後在 myhost 的機器上連自己的 12345 port,就可以連回在客戶那的機器
ssh localhost -p 1
- Hibernate中的缓存
Josh_Persistence
一级缓存Hiberante缓存查询缓存二级缓存
Hibernate中的缓存
一、Hiberante中常见的三大缓存:一级缓存,二级缓存和查询缓存。
Hibernate中提供了两级Cache,第一级别的缓存是Session级别的缓存,它是属于事务范围的缓存。这一级别的缓存是由hibernate管理的,一般情况下无需进行干预;第二级别的缓存是SessionFactory级别的缓存,它是属于进程范围或群集范围的缓存。这一级别的缓存
- 对象关系行为模式之延迟加载
home198979
PHP架构延迟加载
形象化设计模式实战 HELLO!架构
一、概念
Lazy Load:一个对象,它虽然不包含所需要的所有数据,但是知道怎么获取这些数据。
延迟加载貌似很简单,就是在数据需要时再从数据库获取,减少数据库的消耗。但这其中还是有不少技巧的。
二、实现延迟加载
实现Lazy Load主要有四种方法:延迟初始化、虚
- xml 验证
pengfeicao521
xmlxml解析
有些字符,xml不能识别,用jdom或者dom4j解析的时候就报错
public static void testPattern() {
// 含有非法字符的串
String str = "Jamey친ÑԂ
- div设置半透明效果
spjich
css半透明
为div设置如下样式:
div{filter:alpha(Opacity=80);-moz-opacity:0.5;opacity: 0.5;}
说明:
1、filter:对win IE设置半透明滤镜效果,filter:alpha(Opacity=80)代表该对象80%半透明,火狐浏览器不认2、-moz-opaci
- 你真的了解单例模式么?
w574240966
java单例设计模式jvm
单例模式,很多初学者认为单例模式很简单,并且认为自己已经掌握了这种设计模式。但事实上,你真的了解单例模式了么。
一,单例模式的5中写法。(回字的四种写法,哈哈。)
1,懒汉式
(1)线程不安全的懒汉式
public cla