- Docker
℡余晖^
黑马点评项目相关问题和笔记dockereureka容器
在黑马点评项目中,在谈到Redisson解决redis的主从一致性问题时,弹幕提到了Docker,本文来简单了解一下Docker,我的初步理解运维是维护多个集群的稳定,那它和VM虚拟机的区别又是什么?,如果要更深入地理解与学习(运维工程师),可以到b站搜索专门的课程(SpringCloud)。一、Docker是什么?重新理解“容器化”的本质1.1Docker的定义Docker是一个开源的容器化平台
- 分布式方案 一 分布式锁的四大实现方式
white camel
分布式方案分布式分布式锁rediszookeeper
Java分布式锁实现方式详解什么是分布式锁基于数据库的分布式锁基于Redis的分布式锁基于ZooKeeper的分布式锁基于Etcd的分布式锁各种实现方式对比最佳实践建议多节点/线程调用结果展示基于数据库的分布式锁-多线程测试基于Redis的分布式锁-多节点测试基于ZooKeeper的分布式锁-多线程测试基于Redisson的分布式锁-高并发测试性能对比测试结果故障恢复测试总结什么是分布式锁分布式锁
- Redisson源码 RedissonLock加锁与解锁过程原理分析
渡边沐风
javaredis
在当今分布式微服务架构流行的情况下,显然在传统单体项目中使用的JDK自带的锁已经不能解决资源竞争的问题了,进而出现的解决方案有1)利用数据库2)redis3)zookeeper,经过验证的是利用redis做分布式锁无论在可用性、可靠性上比较有优势。而使用Redisson来做分布式锁很多人在熟悉不过了,它提供的Lock就是基于redis来做的。1Redisson锁的基本使用JDK提供的Lock、Co
- Redisson加锁脚本分析
SHENKEM
Redisson
if(redis.call('exists',KEYS[1])==0)then"+"redis.call('hincrby',KEYS[1],ARGV[2],1);"+"redis.call('pexpire',KEYS[1],ARGV[1]);"+"returnnil;"+"end;"+"if(redis.call('hexists',KEYS[1],ARGV[2])==1)then"+"red
- redis面试(七)初识lua加锁脚本
木小同
redis面试redis面试lualua加锁lua脚本
redissonredisson如何来进行redis分布式锁实现的源码,基于redis实现各种各样的分布式锁的原理https://redisson.org/这是官网https://github.com/redisson/redisson/wiki/Table-of-Content这是官方文档开始demo建一个普通的工程在pom.xml里引入依赖org.redissonredisson3.8.1参照
- Redisson 加锁解锁源码
skystep
Redis分布式redisjava
分布式锁使用对于redisson分布式锁的使用很简单:1、调用getLock函数获取锁操作对象;2、调用tryLock函数进行加锁;3、调用unlock函数进行解锁;注意unlock操作需要放到finally代码段中,保证锁可以被释放。privatevoidsumLock(){lock=redissonClient.getLock("sum-lock");booleanb=lock.tryLock
- Redisson 加锁解锁原理 实现源码
SHENKEM
Redisson
Redisson加锁解锁原理及源码分析Redisson是一个基于Redis的Java客户端,提供了分布式锁的实现。下面我将详细分析Redisson的加锁和解锁原理及其核心源码实现。一、加锁原理1.基本加锁流程Redisson的分布式锁主要通过Lua脚本在Redis中实现,主要流程如下:客户端尝试在Redis中设置一个键值对(锁)如果设置成功(键不存在),则获取锁成功如果设置失败(键已存在),则等待
- RedissonLock-tryLock-续期
周末吃鱼
redisson
redisson版本3.16.61.什么是看门狗Redisson提供的分布式锁是支持锁自动续期的,也就是说,如果线程仍旧没有执行完,那么redisson会自动给redis中的目标key延长超时时间,这在Redisson中称之为WatchDog机制。默认情况下,看门狗的检查锁的超时时间是30秒钟,也可以通过修改Config.lockWatchdogTimeout来另行指定。2.什么情况会续期什么情况
- Redisson:强大的Redis Java客户端库
大宝S**蜜
java
Redisson:强大的RedisJava客户端库在Java应用程序中,Redis经常作为缓存、消息代理、分布式锁等功能的首选。然而,直接使用Redis的原生协议或Jedis等简单的Java客户端可能不足以满足复杂的分布式和并发需求。这时,Redisson作为一个功能强大的RedisJava客户端库,提供了许多高级功能和易用性改进,成为开发者的有力工具。1.Redisson简介Redisson是一
- Redisson实现限流器详解:从原理到实践
源末coco
单片机stm32嵌入式硬件
什么是限流器?限流器(RateLimiter)是一种控制请求频率的机制,用于保护系统免受过多请求的冲击。想象一下,你开了一家餐厅,如果同时涌入1000个客人,厨房肯定忙不过来,这时候就需要"限流"——控制进入餐厅的人数。限流的常见场景//场景1:API接口限流@RestControllerpublicclassUserController{@GetMapping("/api/user/{id}")
- redission 实现滑动窗口(注解)推荐
结构目录相关代码org.redissonredisson-spring-boot-starter3.17.0packageorg.example.redission.config;importorg.redisson.Redisson;importorg.redisson.api.RedissonClient;importorg.redisson.config.Config;importorg.s
- 从面试懵逼到通透掌握:分布式锁原理全解(附Redisson与Redlock机制剖析)
爱骑行的Coder
数据库redisjava基础面试分布式javaredis后端
从面试懵逼到通透掌握:分布式锁原理全解(附Redisson与Redlock机制剖)你是不是也有这样的经历?简历上写着“精通Java,精通Redis,熟悉高并发场景”,结果一面下来,分布式锁怎么实现?Redisson是怎么加锁的?看门狗机制了解吗?锁丢失你知道怎么解决吗?全程“啊能能”,频频磕巴。本文不整虚的,带你从0到1,一步步真正搞懂分布式锁的原理与落地实践,面试高频,架构核心,不能不会。一、什
- redis统计各用户版本记录
逐梦ya
redisjava数据库
思路:通过每次用户登录去使用redi统计用户useid和版本version-->目的是为啦获取之前存入redis中的版本判断用户之前有没有存版本没有则新增,有且版本升级则更新用户版本,版本相同则直接返回。//定义RedisKeyStringuserVersionKey="user:version";//1.使用Map存储用户-版本映射RMapuserVersionMap=redissonClien
- Spring Boot多实例环境下保障数据一致性
KiddoStone
springboot后端java
在SpringBoot多实例环境下保障数据一致性需要结合分布式系统设计原则,以下是针对两个场景的设计与实现方案:1.多实例ScheduleJob的数据一致性问题场景多个实例同时执行定时任务,可能导致重复处理(如重复推送消息、重复扣款)。解决方案(1)分布式锁控制//使用Redisson实现分布式锁@Scheduled(cron="0*/5***?")publicvoidsyncDataJob(){
- 在 Redis 分布式锁场景中,锁超时但业务逻辑未完成解决方案
程序媛青青
redis分布式数据库
在Redis分布式锁场景中,锁超时但业务逻辑未完成是一个典型问题,通常称为锁过期与业务执行时间不匹配。以下是几种解决方案:方案一:自续期(看门狗机制)在获取锁的同时启动一个后台线程,定期检查业务是否仍在执行,若未执行完则自动延长锁的过期时间。示例代码(使用Redisson框架):importorg.redisson.Redisson;importorg.redisson.api.RLock;imp
- 25年最新Java后端社招场景项目题总结!(附100w字面试题)
小凡敲代码
javajava面试Java面试题Java场景题程序员互联网大厂计算机
一、高并发与分布式系统设计百万级QPS秒杀系统核心问题:如何解决超卖、库存一致性、高并发请求?技术方案:Redis预减库存+异步扣减(Kafka/RocketMQ)分布式锁(Redisson)或乐观锁(CAS)限流策略(Nginx/Sentinel)扩展:热点数据隔离(独立Redis集群)、风控防刷(IP限流、验证码)。分布式文件存储系统(类似GFS)需求:支持海量文件存储、高可用、快速检索。关键
- Redisson实现的分布式锁核心原理
俏布斯
redis分布式redis
Redisson实现的分布式锁核心原理是利用Redis的原子操作、数据结构和发布订阅机制,在单节点或集群环境下提供互斥、可重入、自动续期(看门狗)、公平锁等特性。其核心机制如下:核心原理与流程锁获取(加锁)Lua脚本保证原子性:当线程尝试获取锁时,Redisson会执行一个Lua脚本到Redis服务器。脚本的核心逻辑是:if(redis.call('exists',KEYS[1])==0)then
- Redission实现的分布式锁的可重入性
俏布斯
redisredis
Redisson分布式锁在Redis中存储可重入状态所使用的Hash结构,并通过示例说明。核心数据结构Key:锁的名称。例如:"myLock"。数据类型:Hash(RedisHSET/HGET/HINCRBY操作的对象)。HashField(字段名):客户端唯一标识符。格式通常为:UUID:threadId。UUID:生成Redisson客户端实例时创建的一个全局唯一ID(一个JVM进程一个)。t
- Redisson使用示例
1,引入依赖(百度搜索即可)2,配置yamlspring:redis:##redis单机环境配置host:127.0.0.1#host:10.192.33.144port:6379#port:20051#password:123456password:''#database:1database:0ssl:false##redis集群环境配置#cluster:#nodes:127.0.0.1:700
- 分布式锁的实现方式:使用 Redisson 实现分布式锁( Spring Boot )
weixin_43833540
分布式springboot后端
Redisson提供了分布式和可扩展的Java数据结构,包括分布式锁的实现。1.添加依赖在pom.xml中添加Redisson依赖:org.redissonredisson-spring-boot-starter3.16.42.配置Redisson客户端创建Redisson配置类:importorg.redisson.Redisson;importorg.redisson.api.Redisson
- Redisson 的 “看门狗
dj_master
Redis服务器数据库java
Redisson的“看门狗(WatchDog)”机制是其针对Redis分布式锁实现的一个重要优化,用于解决分布式锁因业务执行时间过长,锁自动过期释放,导致锁失效的问题。下面从原理、作用、工作机制等方面详细介绍:一、背景:分布式锁的过期问题在使用Redis实现分布式锁时,通常会给锁设置一个过期时间(比如setIfAbsent加过期时间),防止持有锁的客户端因故障(如程序崩溃、网络阻塞)无法释放锁,导
- Redisson看门狗机制:分布式锁的可靠守护者
小韩学长yyds
Redisson分布式Redisson
个人主页:小韩学长yyds-CSDN博客⛺️欢迎关注:点赞留言收藏箴言:拥有耐心才是生活的关键目录一、引言二、Redisson简介三、看门狗机制原理剖析3.1自动续期核心逻辑3.2锁释放与取消续期3.3核心源码深度解读3.3.1scheduleExpirationRenewal方法3.3.2renewExpiration方法3.3.3cancelExpirationRenewal方法四、应用场景与
- 中间件复习(java向,示例代码为java),所有问题都会有链接单独解析
搞不懂语言的程序员
重拾java中间件中间件java开发语言
根据近些年情况整理的Java服务常用中间件及面试复习指南(每个中间件10个以上问题+实战模拟)一、核心中间件清单(2020-2023高频使用)中间件分类典型中间件核心应用场景RPC框架Dubbo3.x、gRPC、SpringCloudOpenFeign微服务通信、跨语言调用消息队列Kafka、RocketMQ、RabbitMQ异步解耦、削峰填谷、顺序消息缓存Redis(集群/Redisson)、C
- 基于Redisson的Redis发布订阅传对象[消息队列]
1、实体类实现Serializable接口2、发布消息packagecom.ahies.stm.app.synthesizes.aifind.controller;importcom.ahies.stm.app.synthesizes.aifind.entity.AifindHistory;importcom.ahies.stm.app.util.ResponseResult;importorg.
- 详解Redission分布式锁脑裂问题
码上库利南
redis分布式
Redisson在RedisCluster模式下实现的分布式锁(基于RedLock思想),理论上仍然存在脑裂(NetworkPartition)导致锁失效的风险。这是由其依赖的“多数派”(Quorum)机制和分布式系统的不可能三角(CAP)决定的。一、脑裂发生的核心场景:假设一个拥有5个主节点(A,B,C,D,E)的RedisCluster:网络分区发生:集群被分裂成两个独立且无法通信的子集:分区
- Redisson看门狗机制和mulitLock原理保姆级别
localhost:8081
redis数据库javajvmredisspringboot
Redisson看门狗机制这段代码主要实现了异步处理一个任务,并根据任务结果来执行不同的操作。首先,调用handleNoSync方法进行异步处理,并返回一个表示异步计算结果的CompletionStage对象,这里使用了threadId和ttlRemainingFuture作为参数。然后,通过CompletableFutureWrapper将上一步返回的CompletionStage包装起来,创建
- 深入理解 Redisson 客户端的锁机制:可重入锁、锁重试与看门狗
CatTietie
redisjavaredis分布式后端springboot
在分布式系统中,锁机制是保证数据一致性和避免并发冲突的重要手段。Redisson作为一个强大的Redis客户端,提供了丰富且高效的分布式锁实现,其中可重入锁、锁重试和看门狗机制尤为值得关注。可重入锁可重入锁允许同一线程多次获取同一把锁,而不会造成死锁。在Redisson中,可重入锁的实现利用了Redis的Hash结构。获取锁逻辑使用exist命令判断当前线程是否存在锁。如果返回值为空,说明锁未被获
- Redis分布式锁解析:从SETNX到Redisson
崎岖Qiu
Redis篇redis分布式数据库缓存java后端面试
目录一、直接使用SETNX存在的问题二、优化方案(Redisson实现)1.锁续期机制(Watchdog)2.原子性保证(Lua脚本)3.可重入锁4.锁等待和重试机制四、结合抢券业务场景的面试回答一、直接使用SETNX存在的问题锁超时自动释放问题场景:在抢券业务中,用户A获取锁后开始扣减库存,但由于阻塞或异常等原因导致处理时间超过锁的过期时间(如30秒),锁自动释放。此时用户B也能获取锁开始抢券。
- Redis面试高频问题
sanggou
redis面试数据库
什么是缓存穿透?怎么解决?缓存穿透是指查询一个一定不存在的数据,如果从存储层查不到数据则不写入缓存,这将导致这个不存在的数据每次请求都要到数据库去查询,可能导致数据库挂掉。这种情况大概率是遭到了攻击。解决方案的话,我们通常都会用布隆过滤器来解决它你能介绍一下布隆过滤器吗布隆过滤器主要是用于检索一个元素是否在一个集合中。一般会使用redisson实现的布隆过滤器。它的底层主要是先去初始化一个比较大数
- 从Spring Boot Redis迁移到Redisson:实现高效分布式数据操作
stay_love
springbootredis分布式
从SpringBootRedis迁移到Redisson:实现高效分布式数据操作引言在SpringBoot生态中,spring-boot-starter-data-redis是操作Redis的主流方案。然而,随着分布式系统复杂性的增加,开发者对Redis的需求已从简单的键值存储扩展至分布式锁、限流、延迟队列等高级场景。此时,基于Netty和异步驱动的Redisson框架成为更优选择。本文将探讨如何通
- java线程Thread和Runnable区别和联系
zx_code
javajvmthread多线程Runnable
我们都晓得java实现线程2种方式,一个是继承Thread,另一个是实现Runnable。
模拟窗口买票,第一例子继承thread,代码如下
package thread;
public class ThreadTest {
public static void main(String[] args) {
Thread1 t1 = new Thread1(
- 【转】JSON与XML的区别比较
丁_新
jsonxml
1.定义介绍
(1).XML定义
扩展标记语言 (Extensible Markup Language, XML) ,用于标记电子文件使其具有结构性的标记语言,可以用来标记数据、定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言。 XML使用DTD(document type definition)文档类型定义来组织数据;格式统一,跨平台和语言,早已成为业界公认的标准。
XML是标
- c++ 实现五种基础的排序算法
CrazyMizzz
C++c算法
#include<iostream>
using namespace std;
//辅助函数,交换两数之值
template<class T>
void mySwap(T &x, T &y){
T temp = x;
x = y;
y = temp;
}
const int size = 10;
//一、用直接插入排
- 我的软件
麦田的设计者
我的软件音乐类娱乐放松
这是我写的一款app软件,耗时三个月,是一个根据央视节目开门大吉改变的,提供音调,猜歌曲名。1、手机拥有者在android手机市场下载本APP,同意权限,安装到手机上。2、游客初次进入时会有引导页面提醒用户注册。(同时软件自动播放背景音乐)。3、用户登录到主页后,会有五个模块。a、点击不胫而走,用户得到开门大吉首页部分新闻,点击进入有新闻详情。b、
- linux awk命令详解
被触发
linux awk
awk是行处理器: 相比较屏幕处理的优点,在处理庞大文件时不会出现内存溢出或是处理缓慢的问题,通常用来格式化文本信息
awk处理过程: 依次对每一行进行处理,然后输出
awk命令形式:
awk [-F|-f|-v] ‘BEGIN{} //{command1; command2} END{}’ file
[-F|-f|-v]大参数,-F指定分隔符,-f调用脚本,-v定义变量 var=val
- 各种语言比较
_wy_
编程语言
Java Ruby PHP 擅长领域
- oracle 中数据类型为clob的编辑
知了ing
oracle clob
public void updateKpiStatus(String kpiStatus,String taskId){
Connection dbc=null;
Statement stmt=null;
PreparedStatement ps=null;
try {
dbc = new DBConn().getNewConnection();
//stmt = db
- 分布式服务框架 Zookeeper -- 管理分布式环境中的数据
矮蛋蛋
zookeeper
原文地址:
http://www.ibm.com/developerworks/cn/opensource/os-cn-zookeeper/
安装和配置详解
本文介绍的 Zookeeper 是以 3.2.2 这个稳定版本为基础,最新的版本可以通过官网 http://hadoop.apache.org/zookeeper/来获取,Zookeeper 的安装非常简单,下面将从单机模式和集群模式两
- tomcat数据源
alafqq
tomcat
数据库
JNDI(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API。
没有使用JNDI时我用要这样连接数据库:
03. Class.forName("com.mysql.jdbc.Driver");
04. conn
- 遍历的方法
百合不是茶
遍历
遍历
在java的泛
- linux查看硬件信息的命令
bijian1013
linux
linux查看硬件信息的命令
一.查看CPU:
cat /proc/cpuinfo
二.查看内存:
free
三.查看硬盘:
df
linux下查看硬件信息
1、lspci 列出所有PCI 设备;
lspci - list all PCI devices:列出机器中的PCI设备(声卡、显卡、Modem、网卡、USB、主板集成设备也能
- java常见的ClassNotFoundException
bijian1013
java
1.java.lang.ClassNotFoundException: org.apache.commons.logging.LogFactory 添加包common-logging.jar2.java.lang.ClassNotFoundException: javax.transaction.Synchronization
- 【Gson五】日期对象的序列化和反序列化
bit1129
反序列化
对日期类型的数据进行序列化和反序列化时,需要考虑如下问题:
1. 序列化时,Date对象序列化的字符串日期格式如何
2. 反序列化时,把日期字符串序列化为Date对象,也需要考虑日期格式问题
3. Date A -> str -> Date B,A和B对象是否equals
默认序列化和反序列化
import com
- 【Spark八十六】Spark Streaming之DStream vs. InputDStream
bit1129
Stream
1. DStream的类说明文档:
/**
* A Discretized Stream (DStream), the basic abstraction in Spark Streaming, is a continuous
* sequence of RDDs (of the same type) representing a continuous st
- 通过nginx获取header信息
ronin47
nginx header
1. 提取整个的Cookies内容到一个变量,然后可以在需要时引用,比如记录到日志里面,
if ( $http_cookie ~* "(.*)$") {
set $all_cookie $1;
}
变量$all_cookie就获得了cookie的值,可以用于运算了
- java-65.输入数字n,按顺序输出从1最大的n位10进制数。比如输入3,则输出1、2、3一直到最大的3位数即999
bylijinnan
java
参考了网上的http://blog.csdn.net/peasking_dd/article/details/6342984
写了个java版的:
public class Print_1_To_NDigit {
/**
* Q65.输入数字n,按顺序输出从1最大的n位10进制数。比如输入3,则输出1、2、3一直到最大的3位数即999
* 1.使用字符串
- Netty源码学习-ReplayingDecoder
bylijinnan
javanetty
ReplayingDecoder是FrameDecoder的子类,不熟悉FrameDecoder的,可以先看看
http://bylijinnan.iteye.com/blog/1982618
API说,ReplayingDecoder简化了操作,比如:
FrameDecoder在decode时,需要判断数据是否接收完全:
public class IntegerH
- js特殊字符过滤
cngolon
js特殊字符js特殊字符过滤
1.js中用正则表达式 过滤特殊字符, 校验所有输入域是否含有特殊符号function stripscript(s) { var pattern = new RegExp("[`~!@#$^&*()=|{}':;',\\[\\].<>/?~!@#¥……&*()——|{}【】‘;:”“'。,、?]"
- hibernate使用sql查询
ctrain
Hibernate
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import org.hibernate.Hibernate;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.hibernate.Transa
- linux shell脚本中切换用户执行命令方法
daizj
linuxshell命令切换用户
经常在写shell脚本时,会碰到要以另外一个用户来执行相关命令,其方法简单记下:
1、执行单个命令:su - user -c "command"
如:下面命令是以test用户在/data目录下创建test123目录
[root@slave19 /data]# su - test -c "mkdir /data/test123" 
- 好的代码里只要一个 return 语句
dcj3sjt126com
return
别再这样写了:public boolean foo() { if (true) { return true; } else { return false;
- Android动画效果学习
dcj3sjt126com
android
1、透明动画效果
方法一:代码实现
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
{
View rootView = inflater.inflate(R.layout.fragment_main, container, fals
- linux复习笔记之bash shell (4)管道命令
eksliang
linux管道命令汇总linux管道命令linux常用管道命令
转载请出自出处:
http://eksliang.iteye.com/blog/2105461
bash命令执行的完毕以后,通常这个命令都会有返回结果,怎么对这个返回的结果做一些操作呢?那就得用管道命令‘|’。
上面那段话,简单说了下管道命令的作用,那什么事管道命令呢?
答:非常的经典的一句话,记住了,何为管
- Android系统中自定义按键的短按、双击、长按事件
gqdy365
android
在项目中碰到这样的问题:
由于系统中的按键在底层做了重新定义或者新增了按键,此时需要在APP层对按键事件(keyevent)做分解处理,模拟Android系统做法,把keyevent分解成:
1、单击事件:就是普通key的单击;
2、双击事件:500ms内同一按键单击两次;
3、长按事件:同一按键长按超过1000ms(系统中长按事件为500ms);
4、组合按键:两个以上按键同时按住;
- asp.net获取站点根目录下子目录的名称
hvt
.netC#asp.nethovertreeWeb Forms
使用Visual Studio建立一个.aspx文件(Web Forms),例如hovertree.aspx,在页面上加入一个ListBox代码如下:
<asp:ListBox runat="server" ID="lbKeleyiFolder" />
那么在页面上显示根目录子文件夹的代码如下:
string[] m_sub
- Eclipse程序员要掌握的常用快捷键
justjavac
javaeclipse快捷键ide
判断一个人的编程水平,就看他用键盘多,还是鼠标多。用键盘一是为了输入代码(当然了,也包括注释),再有就是熟练使用快捷键。 曾有人在豆瓣评
《卓有成效的程序员》:“人有多大懒,才有多大闲”。之前我整理了一个
程序员图书列表,目的也就是通过读书,让程序员变懒。 写道 程序员作为特殊的群体,有的人可以这么懒,懒到事情都交给机器去做,而有的人又可
- c++编程随记
lx.asymmetric
C++笔记
为了字体更好看,改变了格式……
&&运算符:
#include<iostream>
using namespace std;
int main(){
int a=-1,b=4,k;
k=(++a<0)&&!(b--
- linux标准IO缓冲机制研究
音频数据
linux
一、什么是缓存I/O(Buffered I/O)缓存I/O又被称作标准I/O,大多数文件系统默认I/O操作都是缓存I/O。在Linux的缓存I/O机制中,操作系统会将I/O的数据缓存在文件系统的页缓存(page cache)中,也就是说,数据会先被拷贝到操作系统内核的缓冲区中,然后才会从操作系统内核的缓冲区拷贝到应用程序的地址空间。1.缓存I/O有以下优点:A.缓存I/O使用了操作系统内核缓冲区,
- 随想 生活
暗黑小菠萝
生活
其实账户之前就申请了,但是决定要自己更新一些东西看也是最近。从毕业到现在已经一年了。没有进步是假的,但是有多大的进步可能只有我自己知道。
毕业的时候班里12个女生,真正最后做到软件开发的只要两个包括我,PS:我不是说测试不好。当时因为考研完全放弃找工作,考研失败,我想这只是我的借口。那个时候才想到为什么大学的时候不能好好的学习技术,增强自己的实战能力,以至于后来找工作比较费劲。我
- 我认为POJO是一个错误的概念
windshome
javaPOJO编程J2EE设计
这篇内容其实没有经过太多的深思熟虑,只是个人一时的感觉。从个人风格上来讲,我倾向简单质朴的设计开发理念;从方法论上,我更加倾向自顶向下的设计;从做事情的目标上来看,我追求质量优先,更愿意使用较为保守和稳妥的理念和方法。
&