- [TcpConnection]
Bin努力加餐饭
muduo服务器网络
`TcpConnection`类是muduo最核心的类,这个类主要封装了一个已建立的TCP连接,以及控制该TCP连接的方法(连接建立和关闭和销毁),以及该连接发生的各种事件(读/写/错误/连接)对应的处理函数,以及这个TCP连接的服务端和客户端的套接字地址信息等。成员变量private:EventLoop*loop_;//这里绝对不是Mainloop,因为tcpconnection都是在sublo
- 仿RabbitMq实现简易消息队列基础篇(Muduo库的使用)
疏 石 兰 兮
rabbitmqc++开发语言异步操作linuxubuntu
@TOCMuduo库简介Muduo由陈硕⼤佬开发,是⼀个基于⾮阻塞IO和事件驱动的C++⾼并发TCP⽹络编程库。他是一款基于主从Reactor模型的网络库,其使用的线程模型是oneloopperthread,所谓oneloopperthread指的是:一个线程只能有一个事件循环(EventLoop),用于相应计时器和IO时间一个文件描述符只能由一个线程进行读写,换句话说就是一个TCP连接必须归属某
- 【仿muduo库实现并发服务器】Connection模块
tew_gogogo
项目服务器网络android
仿muduo库实现并发服务器一.Connection模块二.成员变量1.连接唯一ID(连接管理)2.Socket对象(套接字操作管理)3.Channel对象(连接事件管理)4.Buffer对象(缓冲区管理)5.ConnStatus对象(连接状态管理)6.EventLoop对象(连接监控/定时任务管理)7.Any对象(上下文管理)8.是否启动非活跃超时连接销毁标志位9.5个阶段性回调函数三.成员函数
- 【仿muduo库实现并发服务器】LoopThreadPool模块
仿muduo库实现并发服务器1.LoopThread模块1.1成员变量1.2构造函数13线程入口函数1.4获取eventloop对象GetLoop()2.LoopThreadPool模块2.1成员变量2.2构造函数2.3配置线程数量2.4按照配置数量创建线程2.5依次分配Eventloop对象1.LoopThread模块这个模块是为了将EventLoop与线程整合起来。一个EventLoop对应一
- Muduo 定时器
小白书舍
c++网络
TimeQueue定时器图片转载自:muduo网络库源码解析(4):TimerQueue定时机制_李兆龙的技术博客_51CTO博客添加新的定时器TimerIdTimerQueue::addTimer(TimerCallbackcb,//用户自定义回调Timestampwhen,//定时器的超时时刻doubleinterval)//重复触发间隔,小于0则不重复触发{Timer*timer=newTi
- 优秀开源库muduo阅读笔记
VictorLeo
网路编程服务端编程muduo
muduo阅读笔记目录设计经验和思想服务端编程设计std::bind和std::function(基于closure闭包的编程)参考资料muduo开源库的笔记,比较杂,没有详细整理,现在就这么杂乱放着,等真的需要再好好整理。设计经验和思想对象构造做到线程安全,唯一的要求就是不要暴露this指针.即不要在构造函数中注册任何回调;也不要在构造函数中把this传给跨线程的对象;即便在构造函数的最后一行也
- muduo
2301_80355452
php前端开发语言
好的,我们来深入剖析陈硕老师开发的著名C++网络库——muduo。它以“简单、高效、易用”著称,是学习LinuxC++高性能网络编程的绝佳范本。我会尽量详细、通俗地讲解其核心思想、关键组件、源码结构和工作原理。核心思想:Reactor模式(Non-blocking+I/OMultiplexing)muduo的灵魂是Reactor模式。理解它就理解了muduo的一半。想象一下:传统阻塞模型的问题:想
- 集群聊天服务器---muduo库使用(2)
power 雀儿
集群聊天服务器学习服务器java前端
书接上回聊天服务器,这个类主要是用于处理网络连接和消息。public:ChatServer(EventLoop*loop,//事件循环constInetAddress&listenAddr,//IP+Portconststring&nameArg)//服务器的名字:_server(loop,listenAddr,nameArg),_loop(loop){//给服务器注册用户连接的创建和断开回调_s
- 【Muduo】三大核心之Channel
打完代码打篮球
Muduo网络库c++stl
Muduo网络库的Channel模块是一个关键组件,它封装了文件描述符(fd)及其相关的事件,使得在TCP网络编程中能够利用IO多路复用技术(如epoll/poll)来监听和处理这些文件描述符上的事件。封装内容文件描述符(fd):每个Channel对象都对应一个特定的文件描述符,该文件描述符通常代表一个网络连接。感兴趣的事件(events):Channel对象封装了与文件描述符相关的一组感兴趣的事
- [muduo] TcpConnection | 回调交互
lvy-
#muduosourcecode交互c++
第六章:TcpConnection在前几章中,我们已经构建了Muduo网络库的基础。我们理解EventLoop(第一章:EventLoop)是单线程的事件引擎,负责管理事件。我们学习了muduo::Thread(第二章:Thread)如何帮助在专用线程中运行EventLoop以实现并发。我们看到了Channel(第三章:Channel)如何将特定的文件描述符(如套接字)连接到EventLoop并保
- 【EventLoop】
在muduo库里边有两种线程:一种里边的事件循环专门处理新用户连接(`mainLoop`(也就是`baseLoop`)),一种里边的事件循环专门处理对应连接的所有读写事件(`ioLoop`)。EventLoop起到一个驱动循环的功能,Poller负责从事件监听器上获取监听结果,Channel类将fd及其相关属性封装,并将fd及其感兴趣事件和发生的事件以及不同事件对应的回调函数封装在一起,这样在各个
- 手写muduo网络库(十):TcpServer
achene_ql
linux网络编程与服务器开发网络开发语言c++linux服务器
引言TcpServer类在muduo网络库中扮演着对外提供服务的重要角色,它封装了TCP服务器的基本功能,包括监听连接、处理新连接、管理连接生命周期等。本文将详细剖析TcpServer类的代码实现,深入探讨其功能和实现逻辑,并结合C++语言特性进行讲解。代码文件概述TcpServer.h头文件分析#pragmaonce#include"EventLoop.h"#include"Acceptor.h
- 手写muduo网络库(终):从实际案例出发详解muduo各模块间调用关系
一、引言在之前的系列文章中,我们已经详细探讨了手写muduo网络库各个模块的实现细节。然而,仅仅了解模块的实现逻辑是不够的,还需要深入理解各个模块之间的调用关系。本文将以一个回声服务器的代码编写为例,详细剖析muduo网络库各模块间的调用关系。通过模拟代码执行过程,深入探究连接建立、事件处理、回调函数设置与调用等关键环节,为读者揭示muduo底层原理。二、程序启动与初始化#include#incl
- 手写muduo网络库(八):Buffer
achene_ql
linux网络编程与服务器开发网络开发语言linux服务器c++
一、引言在网络编程中,数据的读写是非常常见的操作。由于网络数据的收发往往是异步的,而且数据的大小和到达时间都是不确定的,因此需要一个缓冲区来暂存这些数据。Buffer类就是为了解决这个问题而设计的,它提供了一个灵活的缓冲区管理机制,能够方便地处理数据的读写操作。在muduo网络库中,Buffer类扮演着重要的角色,下面我们将详细讲解其功能和实现细节。二、Buffer类的整体功能概述Buffer类主
- 手写muduo网络库(七):深入剖析 Acceptor 类
achene_ql
linux网络编程与服务器开发网络服务器linuxc++开发语言
引言在网络编程中,服务器端程序需要能够监听客户端的连接请求并进行处理。Acceptor类在这个过程中扮演着至关重要的角色,它负责创建监听套接字、绑定地址、开始监听以及处理新的连接请求。在本文中,我们将详细剖析手写muduo网络库中的Acceptor类,探讨其实现原理和工作流程。整体功能概述Acceptor类的主要功能是在指定的地址和端口上监听客户端的连接请求,并在有新的连接到来时调用相应的回调函数
- 手写muduo网络库(四):实现线程 ID 管理与事件循环并分析EventLoop,Poller,Channel关系
achene_ql
linux网络编程与服务器开发网络服务器linuxc++开发语言后端
引言事件驱动架构中的Channel、Poller与EventLoop像是相互咬合的齿轮,它们共同构建了从底层I/O事件监听、事件分发到高层逻辑处理的完整链路。本文将深入剖析事件循环和这三个组件的交互机制,揭示muduo背后的设计思想。一、CurrentThread:高效线程ID获取机制在多线程编程,往往存在一种需求需要某个函数执行在特定线程中,要实现这个功能离不开获取当前线程的唯一标识。muduo
- muduo库EventLoop模块详解
君鼎
C++网络编程开发语言c++网络linux
muduo库EventLoop模块深度解析EventLoop是muduo网络库实现Reactor模型的核心调度中枢,负责驱动整个事件循环机制,协调Poller、Channel、TimerQueue等组件的工作。其设计遵循"OneLoopPerThread"原则。一、核心职责与设计思想1.核心职责事件循环驱动:运行事件循环(loop),持续监听和分发I/O事件任务队列管理:处理跨线程投递的异步任务定
- muduo源码解析
ZI&Yue
网络c++
1.对类进行禁止拷贝classnoncopyable{public:noncopyable(constnoncopyable&)=delete;voidoperator=(constnoncopyable&)=delete;protected:noncopyable()=default;~noncopyable()=default;};2.日志使用枚举定义日志等级enumLogLevel{TRAC
- 【JsonCpp、Muduo、C++11】JsonCpp库、Muduo库、C++11异步操作
LuckyRich1
第三方库c++开发语言
JsonCpp库、Muduo库、C++11异步操作1.JsonCpp库1.1Json数据格式1.2JsonCpp介绍1.3JsonCpp使用2.Muduo库2.1Muduo库常见接口介绍2.1.1TcpServer类基础介绍2.1.2EventLoop类基础介绍2.1.3TcpConnection类基础介绍2.1.4Buffer类基础介绍2.1.5TcpClient类基础介绍2.2Muduo库实现
- [项目深挖]仿muduo库的并发服务器的解析与优化方案
水墨不写bug
项目实践服务器运维linuxmuduoC++
标题:[项目深挖]仿muduo库的并发服务器的优化方案@水墨不写bug文章目录一、buffer模块(1)线性缓冲区+直接扩容---->环形缓冲区+定时扩容(只会扩容一次)(2)使用双缓冲(DoubleBuffering)(3)数据丢弃策略为什么视频传输选择不可靠的UDP协议?(4)零拷贝为什么零拷贝重要?零拷贝的典型场景传统数据传输的过程零拷贝的过程实现零拷贝的技术1.`sendfile`系统调用
- 【从零实现JsonRpc框架#3】线程模型与性能优化
北海有初拥
JsonRpc框架项目性能优化
1.Muduo的线程模型Muduo基于Reactor模式,采用单线程Reactor和多线程Reactor相结合的方式,通过事件驱动和线程池实现高并发。1.单线程模型核心思想:所有I/O操作(accept、read、write)和业务逻辑均在一个线程中完成。适用场景:低并发、低延迟的简单场景(如代理服务器)。优点:无锁,避免线程间同步开销。逻辑简单,调试方便。缺点:无法充分利用多核CPU。单个长耗时
- 施磊老师基于muduo网络库的集群聊天服务器(四)
Zhuai-行淮
施磊老师集群聊天网络服务器运维
文章目录实现登录业务登录业务代码补全数据库接口:查询,更新状态注意学习一下里面用到的数据库api测试与问题**问题1:****问题2:**用户连接信息与线程安全聊天服务器是长连接服务器如何找到用户B的连接?在业务层存储用户的连接信息多线程安全问题加锁!处理客户端异常退出处理情况:-功能不完善两个任务:测试点对点聊天业务(在线)传什么?业务处理逻辑代码结构规划调试与测试:离线消息存储业务设计数据库表
- 施磊老师基于muduo网络库的集群聊天服务器(三)
Zhuai-行淮
施磊老师集群聊天网络服务器c++linux
文章目录业务模块ChatService网络模块-连接回调实现解耦业务头文件公共头文件业务函数定义文件补充网路模块onMessgae()测试至此mysql数据库代码封装ORM(对象关系映射)框架DAO(DataAccessObject)数据访问对象模式分离数据层与业务层数据库读取头文件数据库类函数源文件使用ORM,实现注册业务**第一步:****第二步:****第三步:**错误1:小技巧--红色波浪
- 施磊老师基于muduo网络库的集群聊天服务器(五)
Zhuai-行淮
施磊老师集群聊天网络服务器php
文章目录添加好友业务实现的功能-简单实现功能不完善表设计-每个表对应一个单独的处理文件业务逻辑:-显然不好,可以改进为什么功能少优化SQL联合查询语句代码结构测试问题群组业务主要功能表设计多表查询:`Group`类`GroupUser`类`GroupModel`(数据访问层)添加群聊业务群组阶段面试问题1.**项目介绍怎么讲**2.**面试官常问点**3.**容易翻车的地方**4.**加分点**5
- 施磊老师基于muduo网络库的集群聊天服务器(二)
Zhuai-行淮
施磊老师集群聊天c++开发语言网络
文章目录Cmake简单介绍Cmake与MakefileCmake配置CmakeLists.txt编写完整cmake例子文件夹杂乱问题多级目录Cmakevscode极其推荐的cmake方式Mysql环境与编程mysql简单使用User表Friend表AllGroup表GroupUser表OfflineMessage表集群聊天项目工程目录创建网络模块代码Chatserver头文件类函数定义文件主函数文
- 手写C++ Muduo网络库项目-掌握高性能网络库实现原理
weixin_59289169
pythonjavaphpc++c语言
学习编程的一个很好的方法就是和其他的程序员交谈。不必谈论任何特定的内容。可以是你正在学习的东西,也可以是你认为很酷的东西,更可以是你正在工作的东西,皆可。你会发现很多程序员并不喜欢只是聊编程。这样做可能会让你学到很多关于库,服务器,编程语言和模式方面的知识。但是,最重要的是,你将了解到其他人是如何看待编程的。你会发现,你认为理所当然或从来没有考虑的事情在人与人之间是非常不同的。还有你遇到的那些小问
- 施磊老师基于muduo网络库的集群聊天服务器(六)
Zhuai-行淮
施磊老师集群聊天网络服务器php
文章目录客户端开发开始客户端首页面功能为何不逐行开发?客户端CMake代码搭配知识补充--有很多漏的客户端main-登录,注册,退出群组有问题测试客户端好友添加与聊天功能表驱动设计:commandMapcommandHandlerMap为什么都是int,string添加好友和聊天功能测试错误解决friend表问题mysql注入--(额外辉)数据表问题客户端开发开始客户端客户端首页面功能为何不逐行开
- __sso_string与std::string的区别
未来老干部
C-C++基础string
在学习muduo库源码的时候在,base文件夹下的type.h有#ifdefMUDUO_STD_STRINGusingstd::string;#else//!MUDUO_STD_STRINGtypedef__gnu_cxx::__sso_stringstring;#endif就想了解一下__sso_string和std::string的区别:主要参考了这篇博客:http://blog.csdn.n
- 封装TCP socket
lynijk
网络编程socket网络c++
封装TCPsocket对字节序转化函数、网络地址、Socket操作函数、监听套接字和连接套接字进行了封装,部分代码参考自muduo网络库源码地址:https://github.com/liuyunian/tools-cxx/tree/master/tools/socket字节序转化函数对于字节序转化函数,Unix和Linux共同拥有的是htonl(),htons(),ntohl(),ntohs()
- muduo库net源码分析八(TcpServer/TcpConnection)
houcaihua
tcp/ip网络网络协议
Acceptor类的主要功能是socket、bind、listen一般来说,在上层应用程序中,我们不直接使用Acceptor,而是把它作为TcpServer的成员TcpServer还包含了一个TcpConnection列表TcpConnection与Acceptor类似,有两个重要的数据成员,Socket与Channel。#ifndefMUDUO_NET_TCPSERVER_H#defineMUD
- 关于旗正规则引擎下载页面需要弹窗保存到本地目录的问题
何必如此
jsp超链接文件下载窗口
生成下载页面是需要选择“录入提交页面”,生成之后默认的下载页面<a>标签超链接为:<a href="<%=root_stimage%>stimage/image.jsp?filename=<%=strfile234%>&attachname=<%=java.net.URLEncoder.encode(file234filesourc
- 【Spark九十八】Standalone Cluster Mode下的资源调度源代码分析
bit1129
cluster
在分析源代码之前,首先对Standalone Cluster Mode的资源调度有一个基本的认识:
首先,运行一个Application需要Driver进程和一组Executor进程。在Standalone Cluster Mode下,Driver和Executor都是在Master的监护下给Worker发消息创建(Driver进程和Executor进程都需要分配内存和CPU,这就需要Maste
- linux上独立安装部署spark
daizj
linux安装spark1.4部署
下面讲一下linux上安装spark,以 Standalone Mode 安装
1)首先安装JDK
下载JDK:jdk-7u79-linux-x64.tar.gz ,版本是1.7以上都行,解压 tar -zxvf jdk-7u79-linux-x64.tar.gz
然后配置 ~/.bashrc&nb
- Java 字节码之解析一
周凡杨
java字节码javap
一: Java 字节代码的组织形式
类文件 {
OxCAFEBABE ,小版本号,大版本号,常量池大小,常量池数组,访问控制标记,当前类信息,父类信息,实现的接口个数,实现的接口信息数组,域个数,域信息数组,方法个数,方法信息数组,属性个数,属性信息数组
}
&nbs
- java各种小工具代码
g21121
java
1.数组转换成List
import java.util.Arrays;
Arrays.asList(Object[] obj); 2.判断一个String型是否有值
import org.springframework.util.StringUtils;
if (StringUtils.hasText(str)) 3.判断一个List是否有值
import org.spring
- 加快FineReport报表设计的几个心得体会
老A不折腾
finereport
一、从远程服务器大批量取数进行表样设计时,最好按“列顺序”取一个“空的SQL语句”,这样可提高设计速度。否则每次设计时模板均要从远程读取数据,速度相当慢!!
二、找一个富文本编辑软件(如NOTEPAD+)编辑SQL语句,这样会很好地检查语法。有时候带参数较多检查语法复杂时,结合FineReport中生成的日志,再找一个第三方数据库访问软件(如PL/SQL)进行数据检索,可以很快定位语法错误。
- mysql linux启动与停止
墙头上一根草
如何启动/停止/重启MySQL一、启动方式1、使用 service 启动:service mysqld start2、使用 mysqld 脚本启动:/etc/inint.d/mysqld start3、使用 safe_mysqld 启动:safe_mysqld&二、停止1、使用 service 启动:service mysqld stop2、使用 mysqld 脚本启动:/etc/inin
- Spring中事务管理浅谈
aijuans
spring事务管理
Spring中事务管理浅谈
By Tony Jiang@2012-1-20 Spring中对事务的声明式管理
拿一个XML举例
[html]
view plain
copy
print
?
<?xml version="1.0" encoding="UTF-8"?>&nb
- php中隐形字符65279(utf-8的BOM头)问题
alxw4616
php中隐形字符65279(utf-8的BOM头)问题
今天遇到一个问题. php输出JSON 前端在解析时发生问题:parsererror.
调试:
1.仔细对比字符串发现字符串拼写正确.怀疑是 非打印字符的问题.
2.逐一将字符串还原为unicode编码. 发现在字符串头的位置出现了一个 65279的非打印字符.
 
- 调用对象是否需要传递对象(初学者一定要注意这个问题)
百合不是茶
对象的传递与调用技巧
类和对象的简单的复习,在做项目的过程中有时候不知道怎样来调用类创建的对象,简单的几个类可以看清楚,一般在项目中创建十几个类往往就不知道怎么来看
为了以后能够看清楚,现在来回顾一下类和对象的创建,对象的调用和传递(前面写过一篇)
类和对象的基础概念:
JAVA中万事万物都是类 类有字段(属性),方法,嵌套类和嵌套接
- JDK1.5 AtomicLong实例
bijian1013
javathreadjava多线程AtomicLong
JDK1.5 AtomicLong实例
类 AtomicLong
可以用原子方式更新的 long 值。有关原子变量属性的描述,请参阅 java.util.concurrent.atomic 包规范。AtomicLong 可用在应用程序中(如以原子方式增加的序列号),并且不能用于替换 Long。但是,此类确实扩展了 Number,允许那些处理基于数字类的工具和实用工具进行统一访问。
 
- 自定义的RPC的Java实现
bijian1013
javarpc
网上看到纯java实现的RPC,很不错。
RPC的全名Remote Process Call,即远程过程调用。使用RPC,可以像使用本地的程序一样使用远程服务器上的程序。下面是一个简单的RPC 调用实例,从中可以看到RPC如何
- 【RPC框架Hessian一】Hessian RPC Hello World
bit1129
Hello world
什么是Hessian
The Hessian binary web service protocol makes web services usable without requiring a large framework, and without learning yet another alphabet soup of protocols. Because it is a binary p
- 【Spark九十五】Spark Shell操作Spark SQL
bit1129
shell
在Spark Shell上,通过创建HiveContext可以直接进行Hive操作
1. 操作Hive中已存在的表
[hadoop@hadoop bin]$ ./spark-shell
Spark assembly has been built with Hive, including Datanucleus jars on classpath
Welcom
- F5 往header加入客户端的ip
ronin47
when HTTP_RESPONSE {if {[HTTP::is_redirect]}{ HTTP::header replace Location [string map {:port/ /} [HTTP::header value Location]]HTTP::header replace Lo
- java-61-在数组中,数字减去它右边(注意是右边)的数字得到一个数对之差. 求所有数对之差的最大值。例如在数组{2, 4, 1, 16, 7, 5,
bylijinnan
java
思路来自:
http://zhedahht.blog.163.com/blog/static/2541117420116135376632/
写了个java版的
public class GreatestLeftRightDiff {
/**
* Q61.在数组中,数字减去它右边(注意是右边)的数字得到一个数对之差。
* 求所有数对之差的最大值。例如在数组
- mongoDB 索引
开窍的石头
mongoDB索引
在这一节中我们讲讲在mongo中如何创建索引
得到当前查询的索引信息
db.user.find(_id:12).explain();
cursor: basicCoursor 指的是没有索引
&
- [硬件和系统]迎峰度夏
comsci
系统
从这几天的气温来看,今年夏天的高温天气可能会维持在一个比较长的时间内
所以,从现在开始准备渡过炎热的夏天。。。。
每间房屋要有一个落地电风扇,一个空调(空调的功率和房间的面积有密切的关系)
坐的,躺的地方要有凉垫,床上要有凉席
电脑的机箱
- 基于ThinkPHP开发的公司官网
cuiyadll
行业系统
后端基于ThinkPHP,前端基于jQuery和BootstrapCo.MZ 企业系统
轻量级企业网站管理系统
运行环境:PHP5.3+, MySQL5.0
系统预览
系统下载:http://www.tecmz.com
预览地址:http://co.tecmz.com
各种设备自适应
响应式的网站设计能够对用户产生友好度,并且对于
- Transaction and redelivery in JMS (JMS的事务和失败消息重发机制)
darrenzhu
jms事务承认MQacknowledge
JMS Message Delivery Reliability and Acknowledgement Patterns
http://wso2.com/library/articles/2013/01/jms-message-delivery-reliability-acknowledgement-patterns/
Transaction and redelivery in
- Centos添加硬盘完全教程
dcj3sjt126com
linuxcentoshardware
Linux的硬盘识别:
sda 表示第1块SCSI硬盘
hda 表示第1块IDE硬盘
scd0 表示第1个USB光驱
一般使用“fdisk -l”命
- yii2 restful web服务路由
dcj3sjt126com
PHPyii2
路由
随着资源和控制器类准备,您可以使用URL如 http://localhost/index.php?r=user/create访问资源,类似于你可以用正常的Web应用程序做法。
在实践中,你通常要用美观的URL并采取有优势的HTTP动词。 例如,请求POST /users意味着访问user/create动作。 这可以很容易地通过配置urlManager应用程序组件来完成 如下所示
- MongoDB查询(4)——游标和分页[八]
eksliang
mongodbMongoDB游标MongoDB深分页
转载请出自出处:http://eksliang.iteye.com/blog/2177567 一、游标
数据库使用游标返回find的执行结果。客户端对游标的实现通常能够对最终结果进行有效控制,从shell中定义一个游标非常简单,就是将查询结果分配给一个变量(用var声明的变量就是局部变量),便创建了一个游标,如下所示:
> var
- Activity的四种启动模式和onNewIntent()
gundumw100
android
Android中Activity启动模式详解
在Android中每个界面都是一个Activity,切换界面操作其实是多个不同Activity之间的实例化操作。在Android中Activity的启动模式决定了Activity的启动运行方式。
Android总Activity的启动模式分为四种:
Activity启动模式设置:
<acti
- 攻城狮送女友的CSS3生日蛋糕
ini
htmlWebhtml5csscss3
在线预览:http://keleyi.com/keleyi/phtml/html5/29.htm
代码如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>攻城狮送女友的CSS3生日蛋糕-柯乐义<
- 读源码学Servlet(1)GenericServlet 源码分析
jzinfo
tomcatWebservlet网络应用网络协议
Servlet API的核心就是javax.servlet.Servlet接口,所有的Servlet 类(抽象的或者自己写的)都必须实现这个接口。在Servlet接口中定义了5个方法,其中有3个方法是由Servlet 容器在Servlet的生命周期的不同阶段来调用的特定方法。
先看javax.servlet.servlet接口源码:
package
- JAVA进阶:VO(DTO)与PO(DAO)之间的转换
snoopy7713
javaVOHibernatepo
PO即 Persistence Object VO即 Value Object
VO和PO的主要区别在于: VO是独立的Java Object。 PO是由Hibernate纳入其实体容器(Entity Map)的对象,它代表了与数据库中某条记录对应的Hibernate实体,PO的变化在事务提交时将反应到实际数据库中。
实际上,这个VO被用作Data Transfer
- mongodb group by date 聚合查询日期 统计每天数据(信息量)
qiaolevip
每天进步一点点学习永无止境mongodb纵观千象
/* 1 */
{
"_id" : ObjectId("557ac1e2153c43c320393d9d"),
"msgType" : "text",
"sendTime" : ISODate("2015-06-12T11:26:26.000Z")
- java之18天 常用的类(一)
Luob.
MathDateSystemRuntimeRundom
System类
import java.util.Properties;
/**
* System:
* out:标准输出,默认是控制台
* in:标准输入,默认是键盘
*
* 描述系统的一些信息
* 获取系统的属性信息:Properties getProperties();
*
*
*
*/
public class Sy
- maven
wuai
maven
1、安装maven:解压缩、添加M2_HOME、添加环境变量path
2、创建maven_home文件夹,创建项目mvn_ch01,在其下面建立src、pom.xml,在src下面简历main、test、main下面建立java文件夹
3、编写类,在java文件夹下面依照类的包逐层创建文件夹,将此类放入最后一级文件夹
4、进入mvn_ch01
4.1、mvn compile ,执行后会在