- leetcode hot100【LeetCode 146. LRU缓存】java实现
DataCrafter
LeetCodeHot100leetcode缓存java链表
LeetCode146.LRU缓存题目描述设计和实现一个LRU(LeastRecentlyUsed)缓存机制。它应该支持以下操作:get(key):如果缓存中存在key,则返回value,否则返回-1。put(key,value):如果缓存已满,移除最久未使用的项,然后插入新的key-value对。如果key已存在,则更新其value。Java实现解法解法:使用哈希表和双向链表importjava
- Python常用函数及常用库整理
Nicholson07
python
简单整理一下一些常用函数,方便自己查阅。目录文件操作文件夹/目录文件数据格式链表类特殊函数一些常用函数常用库tqdm进度条库tqdm模块参数说明常用函数使用方法yacs参数配置库简介使用方法logging日志库使用方法文件操作文件夹/目录importos1、os.path.exists(path)判断一个文件/目录是否存在,只要存在相匹配的文件或目录就返回True,因此当目录与文件同名时可能报错2
- 使用C++实现链表数据结构
向着开发进攻
c语言数据结构c++链表
使用C++实现链表数据结构在计算机科学中,链表是最基础且常用的数据结构之一,它属于线性数据结构。链表相比于数组,它能动态地管理内存,具有更高的插入和删除效率,特别是在频繁需要增删操作的场景下。本文将通过C++编程语言实现单链表的数据结构。我们将实现以下功能:链表的插入:在链表头、尾部插入节点。链表的删除:删除指定位置的节点。链表的遍历:打印链表的所有元素。链表的搜索:根据值查找节点。一、链表的基本
- RecyclerView学习笔记(1) ChildHelper.Bucket
奋斗小小鸟cy
Androidandroid数据结构
简介toString方法set方法get方法clear方法countOnesBefore方法reset方法insert方法remove方法总结简介RecyclerView中的ChildHelper.Bucket是一个工具类,实现了类似List的数据结构,从而达到减少内存占用的目的。Bucket是一个链表结构,有两个字段:mData用于存储当前信息,next指向下一个数据publicstaticcl
- 代码随想录数组链表总结(day1-day4)
文化说不定
链表算法数据结构python
数组1.二分查找习惯写左闭右闭,终止条件尽量放最前面,放后面有可能递归再经过一次处理就出不来了顺序存储查找定位的题目优先想是否为二分查找的变形(二分查找的条件太苛刻了感觉,但是效果也很好,所以如果是顺序存储的话,尽量先想二分查找)classSolution:defsearch(self,nums:List[int],target:int)->int:defbinary(low,high):iflo
- 计算机考研408数据结构大题高频考点与真题解析
竹木有心
数据结构
一、线性表(顺序表与链表)1.1顺序表操作与算法设计高频考点:插入/删除操作的边界处理:检查下标越界与存储空间溢出子数组操作:合并、拆分、逆置等多数组综合问题:如寻找三元组最小距离真题示例:2020年408真题题目:给定三个升序数组S1、S2、S3,求所有可能的三元组(a,b,c)的最小距离D=|a−b|+|b−c|+|c−a|。解法:算法思想:三指针法遍历数组,每次移动当前最小元素的指针核心代码
- 【面试题系列】Redis 常见面试题&答案
颜淡慕潇
面试题系列redis数据库缓存
一、基础概念1.Redis有哪些数据结构?各自的应用场景是什么?答案:Redis支持以下数据结构:String:最基础类型,存储字符串、数字、二进制数据。场景:缓存用户信息、计数器、分布式锁。Hash:键值对集合,类似Java的HashMap。场景:存储对象(如用户属性)。List:双向链表,支持左右插入和弹出。场景:消息队列(LPUSH+RPOP)、微博时间线。Set:无序唯一集合,支持交集、并
- c++ 嵌套类(Nested Class)、局部类(Local Class)
JANGHIGH
C++c++开发语言
c++嵌套类(NestedClass)、局部类(LocalClass)一、嵌套类(NestedClass)典型场景示例:链表实现中的嵌套类二、局部类(LocalClass)典型场景示例:函数内部的策略类三、关键区别与注意事项注意事项四、总结C++中的嵌套类(NestedClass)和局部类(LocalClass)是两种特殊的类定义方式,用于优化代码组织和封装性。以下是详细说明和示例:一、嵌套类(N
- C中如何实现字符串反转功能?
计算机学长大白
Cc语言开发语言
在C语言中实现字符串反转功能有多种方法,包括使用循环和指针交换字符位置、递归方法、双指针法等。下面将详细介绍这些方法,并给出具体的示例代码。方法一:使用循环和指针交换字符位置这种方法是最常见且高效的方法之一。通过定义两个指针,一个指向字符串的开头,另一个指向字符串的末尾,然后交换这两个指针所指向的字符,并将指针向中间移动,直到相遇。「示例代码:」#include<stdio.h>#in
- Python面试题:如何在 Python 中反转一个字符串?
超哥同学
Python系列pythonwindows开发语言面试编程
在Python中反转一个字符串有多种方法,下面详细介绍几种常用的方法,并扩展相关的知识点。方法1:使用切片Python的切片(slice)功能强大,反转字符串可以通过负步长实现。#示例original_string="hello"reversed_string=original_string[::-1]print(reversed_string)#输出:"olleh"解释:original_str
- 用Python实现字符串反转
程序媛了了
pythonjava前端
字符串反转代码:#第一种:最简单的切片方法defpythonit():n=input("请输入一段文本:")a=n[::-1]print(a)pythonit()#第二种:列表循环法,利用sort()函数defpython():n=input("请输入一段文本:")list=[]foriinn:list.append(i)list.sort(reverse=True)print("".join(l
- Python实现数据结构与算法——反转字符串
Mantana
数据结构与算法字符串算法数据结构递归法
题目描述:编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组char[]的形式给出。不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用O(1)的额外空间解决这一问题。你可以假设数组中的所有字符都是ASCII码表中的可打印字符。示例1:输入:["h","e","l","l","o"]输出:["o","l","l","e","h"]示例2:输入:["H","a"
- 数据结构与算法——哈希表,数组加强哈希表,双链表加强哈希表
Book_熬夜!
数据结构与算法散列表哈希算法数据结构javascript算法
文章目录哈希表1.数组实现hash表2.双链表实现hash表哈希表key是唯一的,value可以重复哈希表和我们常说的Map(键值映射)不是同一个东西。【Map】是一个Java接口,仅声明了若干个方法,并没有给出方法的具体实现;HashMap这种数据结构根据自身特点实现了这些操作。可以说hashmap的get、put、remove等方法复杂度为O(1),但是map接口的复杂度不一定,需要看他底层数
- 数据结构与算法(java版)
future-2002
算法数据结构
一、初识数据结构与算法1.1数据结构与算法数据结构是指在计算机中组织和存储数据的方式。它关注数据的逻辑关系、操作和存储方式,以及如何有效地访问和修改数据。常见的数据结构包括数组、链表、栈、队列、树、图等。算法是解决问题的一系列步骤或规则。它描述了如何通过输入数据来产生所需的输出结果。算法可以用来执行各种计算任务,如排序、搜索、图形处理等。好的算法应该具有正确性、可读性、高效性和健壮性。数据结构和算
- Python 数据处理
Learn2Learn
usefultools
收集整理平时跑实验遇到的数据处理问题(不定期更新)for循环文件处理相关文件遍历文件名序列化获取特定文件路径字符串处理反转字符串图片处理PILCSV文件处理for循环遍历list等对象时,尽量不要用range#需要使用引索时,forindex,valueinenmuerate(alist):print(index,value)#同时迭代两个循环forword,numberinzip(words,n
- LVGL的学习笔记第一章
期待的是什么
LVGL学习
1.屏幕对象的创建过程lv_init_lv_ll_init(&LV_GC_ROOT(_lv_disp_ll),sizeof(lv_disp_t));//注册初始化显示器链表lv_disp_drv_register_lv_ll_ins_head(&LV_GC_ROOT(_lv_disp_ll));//注册显示器到链表disp->act_src=lv_obj_create(NULL);//在显示器上创
- 2.数据结构-栈和队列
这一wa是晚安
数据结构-考研数据结构
数据结构-栈和队列2.1栈2.1.1栈的表示和实现2.1.2栈的应用举例数制转换括号匹配检验迷宫给求解表达式求值2.1.3链栈的表示和实现2.1.4栈与递归的实现遍历输出链表中各个结点的递归算法*Hanoi塔问题的递归算法2.2队列2.2.1循环队列——队列的顺序表示和实现2.2.2链队——队列的链式表示和实现2.1栈栈是限定仅在表尾进行插入或删除操作的线性表,因此,对栈来说,表尾端有其特殊含义,
- C++-第13课List 容器详解:适合每个程序员的必备知识
藤椒味的火腿肠真不错
C++学习之路c++list
1:C++list容器简介1.1C++STL容器概述C++提供了丰富的标准模板库(STL),其中包括顺序容器(如vector、deque)和关联容器(如map、set)。list是一种链表结构的顺序容器,它的底层实现是双向链表。这使得list在插入和删除操作上比vector更加高效,但由于不支持随机访问,因此访问特定位置的元素时效率较低。1.2list的特点双向链表:list底层是一个双向链表,能
- STL:List模拟实现
Ghost__s
C++
原理:list的底层是双向链表结构,双向链表中每个元素存储在互不相关的独立节点中,在节点中通过指针指向其前一个元素和后一个元素。优点:任意位置的插入删除效率很高(双向迭代)缺点:任意位置的随机访问效率很低list的使用#include#includevoidtest1(){std::listl1(3,10);std::list::iteratorit=l1.begin();//迭代器遍历while
- 链表的应用
不知真不只
链表java前端
双向链表的引用双向有头链表的创建Dou_node*create_doulink(){Dou_node*pnode=malloc(sizeof(Dou_node));if(NULL==pnode){printf("failmalloc");returnNULL;}pnode->ppre=NULL;pnode->pnext=NULL;returnpnode;}链表是否为空的判断intis_empty_
- 自学嵌入式第十七天-----栈和队列
以德服人23
windowsmicrosoft
先附上思维导图:1.栈和队列与表的区别:1.栈和队列是一种特殊的表状结构2.栈和队列只允许在固定位置取出或者插入数据3.栈:先进后出,后进先出FILO4.队列:先进先出,后进后出FIFO要熟悉list.h的使用:---###1.**`INIT_LIST_HEAD(head)`**-**作用**:初始化一个双向链表的头节点。-**详细说明**:-将链表头节点`head`的`next`和`prev`指
- BFS比DFS更好理解「翻转二叉树」
学不会java和算法绝不改名!
算法leetcode宽度优先深度优先数据结构java
一周没发博客,算法好难!一直在复习前面的,哈希表、链表、二叉树已经够我喝一壶了,不过我一定要啃下来,哪怕慢一点,也不能盲目的追求速度,勤于复习才能将知识变成自己的,复习比学习重要!!今天复习翻转二叉树的时候吗,发现BFS其实更加适合这道题,因为这道题本身就是以“层”为逻辑去进行的——每层翻转就好了之前用的DFS递归是真的好恶心555给你一棵二叉树的根节点root,翻转这棵二叉树,并返回其根节点。示
- 删除单向链表中的一个节点
01292520
数据结构与算法链表
删除单向链表中的一个节点:法1:voidremove_if(node**head,remove_fnrm){for(node**curr=head;*curr;){node*entry=*curr;if(rm(entry)){*curr=entry->next;free(entry);}elsecurr=&entry->next;}}通过使用二级指针,使头节点和其他节点同等,不需要返回值node*
- 算法练习——双指针算法(更新中)
*TQK*
算法练习c++学习算法双指针
一、介绍双指针算法双指针(或称为双索引)算法是一种高效的算法技巧,常用于处理数组或链表等线性数据结构。它通过使用两个指针来遍历数据,从而减少时间复杂度,避免使用嵌套循环。双指针算法在解决诸如查找、排序、去重等问题时非常有效。1.双指针算法的基本思想双指针算法的核心思想是通过两个指针(通常是索引)来遍历数组或链表,而不是使用嵌套循环。这两个指针可以是:快慢指针:一个指针移动速度比另一个快。左右指针:
- python数据结构之线性表
努力Study的小陈
python数据结构python数据结构
线性表线性表的基本概念线性表的两种存储结构顺序存储结构优缺点链式存储结构优缺点顺序表1.初始化顺序表2.按下标值查找元素3.修改下标值为index的位置的元素4.判断顺序表是否为空5.插入表头元素6.在顺序表中任意位置插入元素O(n)7.删除表尾元素8.删除任意位置的元素9.获取顺序表的长度10.遍历顺序表单链表1.节点定义代码2.初始化3.判断是否为空4.获取单链表长度5.头插入法6.在中间插入
- 【LeetCode刷题】链表篇
mjh_yylx
算法学习算法刷题打卡leetcode链表算法
203.移除链表元素/***Definitionforsingly-linkedlist.*publicclassListNode{*intval;*ListNodenext;*ListNode(){}*ListNode(intval){this.val=val;}*ListNode(intval,ListNodenext){this.val=val;this.next=next;}*}*/cla
- C++学习笔记(十三)——指针
奕天者
C++基础学习c++学习笔记
一、指针的作用指针(Pointer)是C++中的一种特殊变量,它存储的是另一个变量的内存地址,而不是具体的值。指针有以下作用:直接操作内存地址,提高效率。动态内存分配,如new和delete。数组与字符串的操作,如遍历数组。函数参数传递,提高性能,避免数据拷贝。实现数据结构,如链表、树等。二、指针的声明、取地址和解引用(1)指针的声明作用:定义指针变量。语法:数据类型*指针变量名;示例:inta=
- LeetCode刷题 2.两数相加
_深海凉_
LeetCode
题目要求:给出两个非空的链表用来表示两个非负的整数。其中,它们各自的位数是按照逆序的方式存储的,并且它们的每个节点只能存储一位数字。如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。您可以假设除了数字0之外,这两个数都不会以0开头。示例:输入:(2->4->3)+(5->6->4)输出:7->0->8原因:342+465=807思路:我们同时遍历两个链表,逐位计算它们的和,并与当前
- 5分钟理解依赖注入和控制反转
laraveljavaphp
基本的解释想必打开这篇文章的人,对依赖注入和控制反转都有了大致的概念。简单的说:控制反转是依赖注入的实现。举一个例子男人A要找女朋友,他可以去网聊、去夜店、去酒吧等等各种地方碰运气,花钱花时间。这是一种找女朋友的方法,也是很多人的做法。男人B要找女朋友,他年纪大了没有那么多时间和精力在这方面花费气力,直接去相亲。这是很多大龄青年找女朋友的方法,也就是今天想说的方法。简单的说明假设以上例子就是找女朋
- 跳表的C语言实现
sekaii
算法
跳表(SkipList)是一种基于链表的动态数据结构,用于实现高效的查找、插入和删除操作。它通过引入多级索引来加速查找过程,类似于多级索引的有序链表。跳表的平均时间复杂度为O(logn),在某些场景下可以替代平衡树。以下是跳表的基本实现思路和一个简单的C语言实现示例。1.跳表的基本概念节点结构:每个节点包含一个值和多个指向不同层级的指针。层级:每个节点的层级是随机的,通常通过抛硬币的方式决定。层级
- Java开发中,spring mvc 的线程怎么调用?
小麦麦子
springmvc
今天逛知乎,看到最近很多人都在问spring mvc 的线程http://www.maiziedu.com/course/java/ 的启动问题,觉得挺有意思的,那哥们儿问的也听仔细,下面的回答也很详尽,分享出来,希望遇对遇到类似问题的Java开发程序猿有所帮助。
问题:
在用spring mvc架构的网站上,设一线程在虚拟机启动时运行,线程里有一全局
- maven依赖范围
bitcarter
maven
1.test 测试的时候才会依赖,编译和打包不依赖,如junit不被打包
2.compile 只有编译和打包时才会依赖
3.provided 编译和测试的时候依赖,打包不依赖,如:tomcat的一些公用jar包
4.runtime 运行时依赖,编译不依赖
5.默认compile
依赖范围compile是支持传递的,test不支持传递
1.传递的意思是项目A,引用
- Jaxb org.xml.sax.saxparseexception : premature end of file
darrenzhu
xmlprematureJAXB
如果在使用JAXB把xml文件unmarshal成vo(XSD自动生成的vo)时碰到如下错误:
org.xml.sax.saxparseexception : premature end of file
很有可能时你直接读取文件为inputstream,然后将inputstream作为构建unmarshal需要的source参数。InputSource inputSource = new In
- CSS Specificity
周凡杨
html权重Specificitycss
有时候对于页面元素设置了样式,可为什么页面的显示没有匹配上呢? because specificity
CSS 的选择符是有权重的,当不同的选择符的样式设置有冲突时,浏览器会采用权重高的选择符设置的样式。
规则:
HTML标签的权重是1
Class 的权重是10
Id 的权重是100
- java与servlet
g21121
servlet
servlet 搞java web开发的人一定不会陌生,而且大家还会时常用到它。
下面是java官方网站上对servlet的介绍: java官网对于servlet的解释 写道
Java Servlet Technology Overview Servlets are the Java platform technology of choice for extending and enha
- eclipse中安装maven插件
510888780
eclipsemaven
1.首先去官网下载 Maven:
http://www.apache.org/dyn/closer.cgi/maven/binaries/apache-maven-3.2.3-bin.tar.gz
下载完成之后将其解压,
我将解压后的文件夹:apache-maven-3.2.3,
并将它放在 D:\tools目录下,
即 maven 最终的路径是:D:\tools\apache-mave
- jpa@OneToOne关联关系
布衣凌宇
jpa
Nruser里的pruserid关联到Pruser的主键id,实现对一个表的增删改,另一个表的数据随之增删改。
Nruser实体类
//*****************************************************************
@Entity
@Table(name="nruser")
@DynamicInsert @Dynam
- 我的spring学习笔记11-Spring中关于声明式事务的配置
aijuans
spring事务配置
这两天学到事务管理这一块,结合到之前的terasoluna框架,觉得书本上讲的还是简单阿。我就把我从书本上学到的再结合实际的项目以及网上看到的一些内容,对声明式事务管理做个整理吧。我看得Spring in Action第二版中只提到了用TransactionProxyFactoryBean和<tx:advice/>,定义注释驱动这三种,我承认后两种的内容很好,很强大。但是实际的项目当中
- java 动态代理简单实现
antlove
javahandlerproxydynamicservice
dynamicproxy.service.HelloService
package dynamicproxy.service;
public interface HelloService {
public void sayHello();
}
dynamicproxy.service.impl.HelloServiceImpl
package dynamicp
- JDBC连接数据库
百合不是茶
JDBC编程JAVA操作oracle数据库
如果我们要想连接oracle公司的数据库,就要首先下载oralce公司的驱动程序,将这个驱动程序的jar包导入到我们工程中;
JDBC链接数据库的代码和固定写法;
1,加载oracle数据库的驱动;
&nb
- 单例模式中的多线程分析
bijian1013
javathread多线程java多线程
谈到单例模式,我们立马会想到饿汉式和懒汉式加载,所谓饿汉式就是在创建类时就创建好了实例,懒汉式在获取实例时才去创建实例,即延迟加载。
饿汉式:
package com.bijian.study;
public class Singleton {
private Singleton() {
}
// 注意这是private 只供内部调用
private static
- javascript读取和修改原型特别需要注意原型的读写不具有对等性
bijian1013
JavaScriptprototype
对于从原型对象继承而来的成员,其读和写具有内在的不对等性。比如有一个对象A,假设它的原型对象是B,B的原型对象是null。如果我们需要读取A对象的name属性值,那么JS会优先在A中查找,如果找到了name属性那么就返回;如果A中没有name属性,那么就到原型B中查找name,如果找到了就返回;如果原型B中也没有
- 【持久化框架MyBatis3六】MyBatis3集成第三方DataSource
bit1129
dataSource
MyBatis内置了数据源的支持,如:
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<data
- 我程序中用到的urldecode和base64decode,MD5
bitcarter
cMD5base64decodeurldecode
这里是base64decode和urldecode,Md5在附件中。因为我是在后台所以需要解码:
string Base64Decode(const char* Data,int DataByte,int& OutByte)
{
//解码表
const char DecodeTable[] =
{
0, 0, 0, 0, 0, 0
- 腾讯资深运维专家周小军:QQ与微信架构的惊天秘密
ronin47
社交领域一直是互联网创业的大热门,从PC到移动端,从OICQ、MSN到QQ。到了移动互联网时代,社交领域应用开始彻底爆发,直奔黄金期。腾讯在过去几年里,社交平台更是火到爆,QQ和微信坐拥几亿的粉丝,QQ空间和朋友圈各种刷屏,写心得,晒照片,秀视频,那么谁来为企鹅保驾护航呢?支撑QQ和微信海量数据背后的架构又有哪些惊天内幕呢?本期大讲堂的内容来自今年2月份ChinaUnix对腾讯社交网络运营服务中心
- java-69-旋转数组的最小元素。把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个排好序的数组的一个旋转,输出旋转数组的最小元素
bylijinnan
java
public class MinOfShiftedArray {
/**
* Q69 旋转数组的最小元素
* 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个排好序的数组的一个旋转,输出旋转数组的最小元素。
* 例如数组{3, 4, 5, 1, 2}为{1, 2, 3, 4, 5}的一个旋转,该数组的最小值为1。
*/
publ
- 看博客,应该是有方向的
Cb123456
反省看博客
看博客,应该是有方向的:
我现在就复习以前的,在补补以前不会的,现在还不会的,同时完善完善项目,也看看别人的博客.
我刚突然想到的:
1.应该看计算机组成原理,数据结构,一些算法,还有关于android,java的。
2.对于我,也快大四了,看一些职业规划的,以及一些学习的经验,看看别人的工作总结的.
为什么要写
- [开源与商业]做开源项目的人生活上一定要朴素,尽量减少对官方和商业体系的依赖
comsci
开源项目
为什么这样说呢? 因为科学和技术的发展有时候需要一个平缓和长期的积累过程,但是行政和商业体系本身充满各种不稳定性和不确定性,如果你希望长期从事某个科研项目,但是却又必须依赖于某种行政和商业体系,那其中的过程必定充满各种风险。。。
所以,为避免这种不确定性风险,我
- 一个 sql优化 ([精华] 一个查询优化的分析调整全过程!很值得一看 )
cwqcwqmax9
sql
见 http://www.itpub.net/forum.php?mod=viewthread&tid=239011
Web翻页优化实例
提交时间: 2004-6-18 15:37:49 回复 发消息
环境:
Linux ve
- Hibernat and Ibatis
dashuaifu
Hibernateibatis
Hibernate VS iBATIS 简介 Hibernate 是当前最流行的O/R mapping框架,当前版本是3.05。它出身于sf.net,现在已经成为Jboss的一部分了 iBATIS 是另外一种优秀的O/R mapping框架,当前版本是2.0。目前属于apache的一个子项目了。 相对Hibernate“O/R”而言,iBATIS 是一种“Sql Mappi
- 备份MYSQL脚本
dcj3sjt126com
mysql
#!/bin/sh
# this shell to backup mysql
#
[email protected] (QQ:1413161683 DuChengJiu)
_dbDir=/var/lib/mysql/
_today=`date +%w`
_bakDir=/usr/backup/$_today
[ ! -d $_bakDir ] && mkdir -p
- iOS第三方开源库的吐槽和备忘
dcj3sjt126com
ios
转自
ibireme的博客 做iOS开发总会接触到一些第三方库,这里整理一下,做一些吐槽。 目前比较活跃的社区仍旧是Github,除此以外也有一些不错的库散落在Google Code、SourceForge等地方。由于Github社区太过主流,这里主要介绍一下Github里面流行的iOS库。 首先整理了一份
Github上排名靠
- html wlwmanifest.xml
eoems
htmlxml
所谓优化wp_head()就是把从wp_head中移除不需要元素,同时也可以加快速度。
步骤:
加入到function.php
remove_action('wp_head', 'wp_generator');
//wp-generator移除wordpress的版本号,本身blog的版本号没什么意义,但是如果让恶意玩家看到,可能会用官网公布的漏洞攻击blog
remov
- 浅谈Java定时器发展
hacksin
java并发timer定时器
java在jdk1.3中推出了定时器类Timer,而后在jdk1.5后由Dou Lea从新开发出了支持多线程的ScheduleThreadPoolExecutor,从后者的表现来看,可以考虑完全替代Timer了。
Timer与ScheduleThreadPoolExecutor对比:
1.
Timer始于jdk1.3,其原理是利用一个TimerTask数组当作队列
- 移动端页面侧边导航滑入效果
ini
jqueryWebhtml5cssjavascirpt
效果体验:http://hovertree.com/texiao/mobile/2.htm可以使用移动设备浏览器查看效果。效果使用到jquery-2.1.4.min.js,该版本的jQuery库是用于支持HTML5的浏览器上,不再兼容IE8以前的浏览器,现在移动端浏览器一般都支持HTML5,所以使用该jQuery没问题。HTML文件代码:
<!DOCTYPE html>
<h
- AspectJ+Javasist记录日志
kane_xie
aspectjjavasist
在项目中碰到这样一个需求,对一个服务类的每一个方法,在方法开始和结束的时候分别记录一条日志,内容包括方法名,参数名+参数值以及方法执行的时间。
@Override
public String get(String key) {
// long start = System.currentTimeMillis();
// System.out.println("Be
- redis学习笔记
MJC410621
redisNoSQL
1)nosql数据库主要由以下特点:非关系型的、分布式的、开源的、水平可扩展的。
1,处理超大量的数据
2,运行在便宜的PC服务器集群上,
3,击碎了性能瓶颈。
1)对数据高并发读写。
2)对海量数据的高效率存储和访问。
3)对数据的高扩展性和高可用性。
redis支持的类型:
Sring 类型
set name lijie
get name lijie
set na
- 使用redis实现分布式锁
qifeifei
在多节点的系统中,如何实现分布式锁机制,其中用redis来实现是很好的方法之一,我们先来看一下jedis包中,有个类名BinaryJedis,它有个方法如下:
public Long setnx(final byte[] key, final byte[] value) {
checkIsInMulti();
client.setnx(key, value);
ret
- BI并非万能,中层业务管理报表要另辟蹊径
张老师的菜
大数据BI商业智能信息化
BI是商业智能的缩写,是可以帮助企业做出明智的业务经营决策的工具,其数据来源于各个业务系统,如ERP、CRM、SCM、进销存、HER、OA等。
BI系统不同于传统的管理信息系统,他号称是一个整体应用的解决方案,是融入管理思想的强大系统:有着系统整体的设计思想,支持对所有
- 安装rvm后出现rvm not a function 或者ruby -v后提示没安装ruby的问题
wudixiaotie
function
1.在~/.bashrc最后加入
[[ -s "$HOME/.rvm/scripts/rvm" ]] && source "$HOME/.rvm/scripts/rvm"
2.重新启动terminal输入:
rvm use ruby-2.2.1 --default
把当前安装的ruby版本设为默