- zobovision随谈H.265/HEVC编码FPGA实现(一)
zobovision
视频图像编解码FPGAIPfpga开发视频编解码
zobovision随谈H.265/HEVC编码FPGA实现(一)H.265/HEVC出来已有10年,但市场应用难言巅峰,正如古董级的H.264现在仍然大行其道,H.265的全面应用仍有待市场发酵,至少在硬件产品端应用,值得期待。一来H.265相对H.264而言,压缩技术确实要先进不少,不管是理论上还是实际效果方面;二是H.265相对后来者H.266/VVC等而言,实用性更强,性价比更高,产品端的
- 【视频编码\VVC】变换编码基础知识及标准设计相关参数
鴒凰
视频编码音视频视频编解码视频编码h.266VVC笔记
变化编码的基础知识定义:变换编码是将以空间域像素形式描述的图像转换至变换域,以变换系数的形式加以表示。大部分图像都包含较多平坦区域和内容变化缓慢的区域,使得图像能量在空间域的分散转换为变换域的相对集中分布,从而达到空间去冗余的目的。变换概述选用DCT变换的原因:DCT形式与输入信号无关并且存在快速实现算法,并且性能接近K-L变换。H.264第一次使用了整数DCTH.265沿用了整数DCT,进行了不
- 视频编码结构
一箭辰空
音视频
VVCVVC标准对应的参考软件平台是VTM(VVCTestModel)两个基本目标1.高压缩性能,定义一套视频编码技术,其压缩性能要远优于以往的同类标准。2.宽应用领域,能够有效地用于比先前标准更广阔的范围。编码过程图像分块、预测、变换、量化、熵编码、环路滤波1.图像分块如图1所示,VVC在编码原理和基本结构方面没有突破,仍沿用从H.261就开始的基于块的混合视频编码框架,即预测加变换的分块编码方
- H266/VVC多样化视频编码工具概述
DogDaoDao
H266(VVC)标准H266VVC全景视频编码视频编解码屏幕内容编码
全景视频编码全景视频:具有360度全包围视角的球面视频。全景视频编码:包括H266在内的视频编码算法都是以平面视频为对象的,为了采用传统的视频编码编码算法,全景视频需要转换为平面视频,其中经纬图等角映射(ERP)、立方体映射(CMP)是常用的格式。水平环绕运动补偿:普通平面视频编码算法的运动补偿中,当运动矢量指向参考图像边界区域外的像素时,会对参考图像边界进行填充以获取参考像素值,填充方法是用距离
- H266/VVC率失真优化与速率控制概述
DogDaoDao
H266(VVC)标准H266VVC率失真视频编解码实时音视频拉格朗日
率失真优化技术率失真优化:视频编码的主要目的是在保证一定视频质量的条件下尽量降低视频的编码比特率,或者在一定编码比特率限制条件下尽量地减小编码失真。在固定的编码框架下,为了应对不同的视频内容,往往有多种候选的编码方式,编码器的一个主要工作就是在某种策略选择最优的编码参数,以实现最优的编码性能。基于率失真理论的编码参数优化被称为率失真优化,率失真优化技术是保证编码器效率的主要手段。率失真理论:在允许
- H266/VVC环路滤波技术概述
DogDaoDao
H266(VVC)标准H266VVC环路滤波SAO编码失真视频编解码音视频
环路滤波环路滤波:是提高编码视频主客观质量的有效工具,不同于图像增强处理中的滤波技术,环路滤波是在视频编码过程进行滤波,滤波后的图像用于后续图像的编码,即位于“环路”中。环路滤波的作用:一方面提高了编码图像的质量,一方面为后续编码图像提供了高质量的参考图像。常见的编码失真:方块效应、振铃效应、颜色偏差、图像模糊等常见编码失真效应。H266环路滤波技术:如下图,H266标准的环路滤波技术包括亮度映射
- H266/VVC网络适配层概述
DogDaoDao
H266(VVC)标准H266视频编解码NALUVVC网络适配层实时音视频
视频编码标准的分层结构视频数据分层的必要性:网络类型的多样性、不同的应用场景对视频有不同的需求。编码标准的分层结构:为了适应不同网络和应用需求,视频编码数据根据其内容特性被分成若干NAL单元(NALUnit,NALU),并对NALU的内容特性进行标识。网络只需要根据NALU及其标识就可以优化视频传输性能,不再需要亲自分析视频数据的内容特性。如下图就是典型的分层结构。H266中NAL的作用机制:原始
- H.266/VVC帧间预测技术学习:几何划分模式(Geometric partitioning mode, GPM)
涵小呆
VVC/H.266视频编码H.266/VVC
几何划分模式(Geometricpartitioningmode,GPM)原理针对图像中运动物体的边界部分,VVC采用了几何划分模式进行帧间预测。如下图所示,GPM模式在运动物体的边界处进行了更精细的划分。划分类型使用GPM模式时,通过几何定位的直线将CU划分为两部分(下图所示)。分割线的位置从数学上是根据特定分区的角度参数φ和偏移参数ρ得出的,如下图所示。VVC标准中的GPM规定将360°不等间
- H266/VVC变换编码技术概述
DogDaoDao
H266(VVC)标准人工智能机器学习H266VVC变换编码视频编解码DCT
视频变换编码变换编码:是指将以空间域像素形式描述的图像转换至变换域。以变换系数的形式加以表示。适当的变换可使图像能量在空间域的分散分布转换为在变换域的相对集中分布,从而达到去除空间冗余的目的。DCT:离散余弦变换(DiscreteCosineTransform,DCT)与去相关性性能最优的K-L变换相比,与输入信号无关且存在快速实现算法,性能接近K-L变换,广泛应用在图像视频编码中。H264首次使
- CompressAI:深度学习与传统图像压缩
qq_41627642
深度学习多模态深度学习人工智能
1、图像压缩算法原理传统的有损图像压缩方法,如JPEG,JPEG2000,HEVC或AV1或VVC,在类似的编码方案上进行了迭代改进:将图像划分为像素块,使用变换域通过线性变换(例如:DCT或DWT)去相关空间频率,基于相邻值执行一些预测,量化转换系数,最后使用有效的熵编码器(例如:CABAC[11])将量化值和预测侧信息编码成比特流。另一方面,基于人工神经网络的编解码器主要依赖于学习分析和综合非
- H266/VVC帧间预测编码技术概述
DogDaoDao
H266(VVC)标准人工智能视频编解码H266VVC深度学习预测编码实时音视频
帧间预测编码简述帧间预测利用视频时间域的相关性,使用邻近已编码图像像素值预测当前图像的像素值,能有效去除视频时域冗余。目前主要的视频编码标准中,帧间预测都采用基于块的运动补偿技术,不同的编码标准有不同的分块方式。为当前图像的每个像素块在之前已编码图像找到一个最佳匹配块,这个寻找过程就称为运动估计(MotionEstimation,ME)。用于预测的图像被称为参考图像或参考帧(ReferencePi
- H266/VVC帧内预测编码
DogDaoDao
H266(VVC)标准H266VVC帧内预测预测编码视频编解码实时音视频深度学习
预测编码技术预测编码(PredictionCoding)是指利用已编码的一个或多个样本值,根据某种模型或方法,对当前的样本值进行预测,并对样本真实值和预测值之间的差值进行编码。视频中的每个像素看成一个信源符号,它通常与空域上或时域上邻近的像素具有较强的相关性,因此视频是一种有记忆信源。预测编码技术通过预测模型消除像素间的相关性,得到的差值信号可以认为没有相关性,或者相关性很小,因此可以作为无记忆信
- Windows11编译VTM源码生成Visual Studio 工程
DogDaoDao
#VTMvisualstudioVTMH266VVC视频编解码WindowsVS2022
VTM介绍VTM作为H266/VVC标准的官方参考软件,一直用作H266/VVC标准的研究和迭代。关于H2666/VVC标准的介绍、代码、提案、文档等,可以参考H266/VVC编码标准介绍。官方代码地址:https://vcgit.hhi.fraunhofer.de/jvet/VVCSoftware_VTM(最新)git镜像地址:https://github.com/yanceyxin/VVCSo
- DCC2023:基于梯度线性模型的帧内色度预测
Dillon2015
H.266/VVC视频编码CCLMVVC
本来自DCC2023文章《GradientLinearModelforChromaIntraPrediction》在VVC中引入了CCLM工具,CCLM用于帧内预测,它根据一个线性模型通过亮度像素重建值获得色度像素的预测值。对于YUV420格式的视频,需要先将亮度分量使用低通滤波器下采样到和色度分量同样的分辨率,然后使用线性模型计算色度的预测值。然而下采样过程会丢失空域信息(例如边界、梯度),为了
- 【论文解读】Comparing VVC, HEVC and AV1 using Objective and Subjective Assessments
DogDaoDao
论文解读AV1VVCHEVC视频编解码HMVTMAOM
时间:2020级别:IEEE机构:IEEE组织摘要:对3种最新的视频编码标准HEVC(HighEfficiencyvideoCoding)测试模型HM(HighEfficiencyvideoCoding)、amediavideo1(AV1)和VersatilevideoCoding测试模型(VTM)进行了客观和主观质量评价。通过精细化选择9个源序列,使其具有多样性和代表性,并在预定义的目标码率下对
- H266/VVC标准的编码结构介绍
DogDaoDao
H266(VVC)标准H266VVC视频编解码实时音视频VTM
概述CVS:H266的编码码流包含一个或多个编码视频序列(CodedVideoSwquence,CVS),每个CVS以帧内随机接入点(IntraRandomAccessPoint,IRAP)或逐渐解码刷新(GradualDecodingRefresh,GDR)图像开始。CVS是时域独立可解码的基本单元。CLVS:编码视频序列层,当编码码流只包含一层时,CVS与CLVS一致。AU:访问单元PU:图像
- H266/VVC编码标准介绍
DogDaoDao
H266(VVC)标准VVCH266视频编解码实时音视频VTM
视频编码标准多样的视频应用催生了多种的视频编码方法。为了使编码后的码流能够在大范围内通用和规范,从20世纪80年代开始,国际组织就开始对视频编码建立国际标准。什么是视频编码标准:视频编码标准只规定了码流的语法语义和解码器,只要求视频编码后的码流符合标准的语法结构,解码器就可以根据码流的语法语义进行正常解码。因此,符合某个解码标准的编码器是有很大的自由度的,只要编码后的码流符合标准规定即可。编码器输
- 屏幕内容编码:HEVC SCC、VVC、AVS3、AV1和EVC
若忘即安
VVC/H.266音频编码解码
近年来,随着许多相关应用变得非常流行,包括计算机生成的文本、图形和动画在内的屏幕内容视频引起了比以往更多的关注。然而,传统的视频编解码器通常被设计成处理摄像机捕获的自然视频。另一方面,屏幕内容视频表现出不同的信号特征和人类对失真的视觉敏感度的不同水平。为了解决对这种内容进行高效编码的需要,已经专门开发了许多编码工具,并且在编码效率方面取得了巨大进步。所有最近开发的视频编码标准都包含屏幕内容编码(S
- H.266/VVC的关键编码技术(五):AI, RA, LD三种编码结构
若忘即安
VVC/H.266视频处理音频编码解码
AI,RA,LD三种编码结构VVC中采用三种编码结构:全帧内(AI,A11lntra)、低延迟(LD,LowDelay),随机接入(RA,RandomAccess),分别用于满足不同场景下的编码需求。AI编码在全帧内编码结构下,序列中每一帧图像均采用帧内编码,具有各自独立的上图所示,I帧不需要参考其他帧的像素信息,可独立的进行编解码,且每一帧的量化参数都保持一致,AI编码结构适合信道环境较差,容易
- H.266/VVC的编码框架
若忘即安
VVC/H.266视频处理音频编码解码
VVC编码框架VVC仍沿用从H.261开始使用的基于块的混合视频编码框架,包括帧内预测、帧间预测、变换、量化、环路滤波、嫡编码等。基本流程是首先利用帧内/帧间预测编码消除空域/时域冗余,接着对预测残差进行变换量化编码消除残差数据间的空域冗余,最后通过嫡编码消除经变换和量化后的残差数据中的信息嫡冗余。在VVC中,视频进入编码器后,每帧图像首先被划分为互不重叠的图像块,称之为编码树单元(CodingT
- H.266VVC的关键编码技术(一):帧内预测
若忘即安
VVC/H.266视频处理音频编码解码调制与编码策略
1.帧内预测帧内预测是指利用视频中相邻像素之间的相似性或者关联性,使用当前图像己编码的相邻像素预测当前像素,从而达到去除空间冗余的口的,得到的预测残差将经过后续的变换、量化和嫡编码等模块进一步处理生成最终的码流。(1)帧内预测模式为了捕捉自然视频中任意的边缘方向,VVC中的帧内预测模式从HEVC中使用的33种扩展到65种。红色虚线表示了VVC中新出现的帧内角度预测模式,黑色为HEVC原有的帧内预测
- AVC、HEVC、VVC帧间预测技术
傻不拉几的程序员
工作学习编解码AVCHEVCVVC
帧间预测总体思路:帧间预测主要的工作是运动估计与运动补偿。所谓运动估计简单说就是在参考帧中找到当前块的最优参考块,用运动向量(MV)表示参考块与当前块的位置关系。所谓运动补偿简单说就是对参考块与当前块求差值得到残差用于传输。总的过程:通过搜索算法找到最优的参考块,计算MV,计算残差,MV提供位置信息,残差提供值的信息。========================================
- AOMedia发布免版税沉浸音频规范IAMF
LiveVideoStack_
音视频
11月10日,开放媒体联盟(AOMedia)发布了旗下首个沉浸式音频规范IAMF(https://aomediacodec.github.io/iamf/),IAMF是一种编解码器无关的容器规范,可以携带回放时间渲染算法和音频混音的信息,而且和旗下的AV1视频标准一样为免版税。从AV1开始,AOMedia就在用开放来对抗老牌的标准组织ITU与ISO/IEC的HEVC、VVC等标准。目前,AV1已经
- 编解码再进化:Ali266与下一代视频技术
LiveVideoStack_
音视频
过去的一年见证了人类百年不遇的大事记,也见证了多种视频应用的厚积薄发。而因此所带来的视频数据量的爆发式增长更加加剧了对高效编解码这样的底层硬核技术的急迫需求。正是在这样的大环境下,在ITU-TVCEG和ISO/IECMPEG两大标准组织再次联手推出的最新视频编解码标准VVC定稿不久之后,阿里巴巴的视频团队开始全力投入开展VVC软件编解码的开发工作。本次LiveVideoStackCon2021北京
- 阿里云视频云发布实时高清VVC编码器Ali266,真正开启VVC商用之路
阿里云视频云
阿里云视频云阿里云视频处理视频编码编码器视频云
基于新一代国际视频编解码标准H.266/VVC,阿里云视频云近日发布了实时高清编码器Ali266,有力推动H.266/VVC标准应用的落地,真正开启H.266/VVC的商用之路,并强力赋能超高清4K、8K、以及AR/VR等应用的真实普及。编码器Ali266=实时+高清+超压缩阿里云视频云于7月中发布了实时高清VVC编码器Ali266首个版本,从已公开的资料可知,这是目前全世界最快的VVC编码器。具
- AVS3:双向光流BIO
Dillon2015
AVS3视频编码avs3双向光流BIOBDOF1024程序员节
AVS3引入了双向光流(BI-directionalOpticalflow,BIO)技术,和H.266/VVC中的BDOF类似,BIO用于解决基于块的预测会存在块内某些区域仍会有偏差的现象导致需要划分更小的块。通过补偿小的像素区域的位移,BIO可以使用更大的块来编码从而节省码率,达到像素级预测的效果。如图1,左侧是双向光流补偿前的预测结果,右侧是补偿后的预测结果。图1补偿前后的预测传统的双向预测对
- AVS3:跨分量预测TSCPM
Dillon2015
AVS3视频编码avs3TSCPMCCLM
TSCPM两步跨分量预测模式(TSCPM,TwoStepCross-componentPredictionMode)通过探索不同分量之间的线性关系去除分量间冗余。TSCPM分为两个步骤执行,首先使用Co-locatedluma块通过参数α和β生成尺寸相同的临时预测块,第二步再进行下采样,得到色度分量的预测值,如图1。图1TSCPMAVS3的TSCPM仅用于intra模式中,类似于VVC中的CCLM
- 帧间快速算法论文阅读
什么都不懂的小青蛙
智能视频编码算法论文阅读视频编解码机器学习深度学习人工智能
LowcomplexityintercodingschemeforVersatileVideoCoding(VVC)通过分析相邻CU的编码区域,预测当前CU的编码区域,以终止不必要的分割模式。1、2、3、4表示当前CU(CU0)的相邻CU。根据空间相关性,当前CU的面积预测为wiw_iwi的值分别为0.3,0.2,0.3,0.2。(考虑到水平方向和垂直方向的相关性大于对角线方向的相关性)当预测面积
- VVC中图片的划分
Ginkgo
在VVC中,输入的视频首先被划为为相等大小的块(最大支持划分为128×128大小的块,虽然VVC支持的变换的块最大尺寸为64×64),这些等大的块成为CTUs(codingtreeunits),每一个CTU都有Y、Cb、Cr三个等大的CU。图1混合编码框架把输入的图像划分为CTUs之后,再对CTUs进行进一步的归类。在HEVC中,可以把CTUs分为Slice和Tile,其中Slice可以进一步划分
- 多维评测指标解读第17届MSU世界编码器大赛全高清10bit赛道结果
阿里云视频云
硬核干货云计算视频云
超高清视频纤毫毕现的关键一环。01主要指标多项第一,带宽节省48%近日,第17届MSU世界编码器大赛全高清10bit赛道成绩揭晓,阿里自研的H.266/VVC编码器Ali266在该赛道最高效的1fps档次上获得两项冠军,相较大赛基准编码器x265可节省48%的带宽,有效降低超高清视频门槛,推动其普及。MSU世界编码器大赛是指由莫斯科国立大学(LomonosovMoscowStateUniversi
- 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