- 多线程之三:MFC多线程及实例(转)
Stef若木
MFC线程
MFC中有两类线程,分别称之为工作者线程和用户界面线程。二者的主要区别在于工作者线程没有消息循环,而用户界面线程有自己的消息队列和消息循环。工作者线程没有消息机制,通常用来执行后台计算和维护任务,如冗长的计算过程,打印机的后台打印等。用户界面线程一般用于处理独立于其他线程执行之外的用户输入,响应用户及系统所产生的事件和消息等。但对于Win32的API编程而言,这两种线程是没有区别的,它们都只需线程
- RabbitMQ系列(零)概要
yyueshen
RabbitMQrabbitmq分布式消息队列
一、消息队列总览1.什么是消息队列?消息队列(MessageQueue)是一种异步通信机制,允许分布式系统中的服务通过生产-消费模型传递数据。其核心价值在于:解耦性:生产者与消费者无需同时在线或直接交互削峰填谷:应对流量突发场景,避免系统过载(如秒杀系统请求缓冲)可靠性:通过持久化、重试机制保障消息不丢失2.典型应用场景场景实现原理案例服务异步化耗时操作异步执行(如日志记录)用户注册后异步发送通知
- RabbitMQ工作模式
霸都阿甘
RabbitMQrabbitmqjava分布式
一、工作模式介绍RabbbitMQ提供了6种工作模式:简单模式、workqueues、Publish/Subscribe发布与订阅模式、Routing路由模式、Topics主题模式、RPC远程调用模式(不太符合MQ)1.1简单模式P:生产者,也就是要发送消息的程序C:消费者,消息的接收者,会一直等待消息到来Queue:消息队列,图中红色部分。类似一个邮箱,可以缓存消息;生产者向其中投递消息,消费者
- python使用kafka原理详解_Python操作Kafka原理及使用详解
形象顧問Aking
Python操作Kafka原理及使用详解一、什么是KafkaKafka是一个分布式流处理系统,流处理系统使它可以像消息队列一样publish或者subscribe消息,分布式提供了容错性,并发处理消息的机制二、Kafka的基本概念kafka运行在集群上,集群包含一个或多个服务器。kafka把消息存在topic中,每一条消息包含键值(key),值(value)和时间戳(timestamp)。kafk
- Spring Boot 集成 Kafka
m0_74823471
面试学习路线阿里巴巴springbootkafkalinq
在现代软件开发中,分布式系统和微服务架构越来越受到关注。为了实现系统之间的异步通信和解耦,消息队列成为了一种重要的技术手段。Kafka作为一种高性能、分布式的消息队列系统,被广泛应用于各种场景。而SpringBoot作为一种流行的Java开发框架,提供了便捷的方式来构建应用程序。本文将介绍如何在SpringBoot项目中集成Kafka,包括Kafka的基本概念、SpringBoot集成Kafka的
- python操作kafka
您懂我意思吧
python开发kafka分布式python
一、参考阿里云的官方链接:使用PythonSDK接入Kafka收发消息_云消息队列Kafka版(Kafka)-阿里云帮助中心二、安装python环境三、添加python依赖库pipinstallconfluent-kafka==1.9.2四、新建一个setting.py文件配置信息kafka_setting={'sasl_plain_username':'XXX',#如果是默认接入点实例,请删除该
- RabbitMQ实战:构建可靠的异步消息系统
AI天才研究院
计算DeepSeekR1&大数据AI人工智能大模型计算科学神经计算深度学习神经网络大数据人工智能大型语言模型AIAGILLMJavaPython架构设计AgentRPA
RabbitMQ实战:构建可靠的异步消息系统1.背景介绍1.1异步消息系统的重要性在现代软件系统中,各个组件和服务之间通常需要进行大量的通信和数据交换。同步通信会导致系统耦合度高,可扩展性差。异步消息系统应运而生,通过将消息发送者和接收者解耦,提高了系统的灵活性、可靠性和性能。1.2RabbitMQ的优势RabbitMQ是一个开源的消息队列系统,基于AMQP(AdvancedMessageQueu
- IO进程 day08
李倚墨
Linux阶段四:IO进程c语言IO进程linux
IO进程day0811.进程间的通信机制11.6.信号灯集概念步骤semgetsemctlsemop初始化和操作信号灯函数封装命令11.7.消息队列特点步骤msggetmsgsndmsgrcvmsgctl命令11.进程间的通信机制11.6.信号灯集概念 信号灯,又叫信号量,是不同进程或同一个进程的不同线程间的同步机制 SystemV信号灯集是一个或者多个信号灯的集合。其中每一个都是单独的信号灯,P
- 技术架构和工程架构区别
atom goper
架构
技术架构技术架构是对某一技术问题解决方案的结构化描述,包括组件结构及其交互关系。它涵盖部署方案、存储方案、缓存方案、日志方案等多个方面,旨在通过组织人员和技术,以最低的成本满足需求和应对变化,保障软件的稳定高效运行。一般技术架构,需要考虑如何实现这些功能,一部分是基础设施,一部分是系统设计。基础设施包括选择什么语言、什么框架、什么数据库,以及消息队列、搜索引擎、部署方案等等。系统设计是否采用微
- LayoutInflater & Factory2
Android西红柿
Android基础java开发语言android
关于作者:CSDN内容合伙人、技术专家,从零开始做日活千万级APP。专注于分享各领域原创系列文章,擅长java后端、移动开发、商业变现、人工智能等,希望大家多多支持。未经允许不得转载目录一、导读二、概览三、使用3.1LayoutInflater实例获取3.2调用inflate方法解析3.3四、LayoutInflater.Factory(2)4.1使用4.2注意点五、推荐阅读一、导读我们继续总结学
- uml类图
Android西红柿
工具-效率androidflutter
关于作者:CSDN内容合伙人、技术专家,从零开始做日活千万级APP,带领团队单日营收超千万。专注于分享各领域原创系列文章,擅长java后端、移动开发、商业化变现、人工智能等,希望大家多多支持。目录一、导读二、概览三、推荐阅读一、导读我们继续总结学习基础知识,温故知新。二、概览无他,唯记录尔!publicvoidtest(){System.out.println("HelloWorld");}fun
- 腾讯面试:大厂必问消息队列场景面试题
消息队列腾讯面试问题
今天,我将那些大厂必问的消息队列的场景问题为大家整理出来,本文将跟大家一起来探讨如何回答这些问题。为什么要使用消息队列?保证消息有序,一个topic只能有一个partition吗?(消息顺序)业务突然增长,导致消息消费不过来怎么办?(消息积压)生产者收到写入成功响应后消息一定不会丢失吗?(消息丢失)高并发场景下怎么保证消息不会重复消费?(重复消费)如何保证消息的可靠性?各大消息队列中间件对比及使用
- 腾讯云 TDMQ 产品家族新成员:消息队列 MQTT 版全新发布!
腾讯云消息队列mqtt
导语自2024年12月27日起,腾讯云消息队列团队正式发布TDMQ产品家族的新成员:TDMQMQTT版。这款新产品旨在满足物联网和车联网场景下日益增长的应用需求,为企业的技术变革和产业升级提供有力支持。TDMQMQTT版推出的背景当前腾讯云消息队列产品家族已拥有多个子产品:CKafka作为业界高吞吐的标杆,广泛地用于离线消息的场景,如大规模日志收集等类似的业务。RocketMQ以其低延时和高并发的
- MQX - 基于 MySQL 的轻量级消息队列
MQX是一个基于MySQL的轻量级消息队列实现,以Go语言库的形式提供服务,无需额外部署消息服务器。1.项目介绍项目背景在中小型项目中,经常需要使用消息队列来解耦服务,但部署维护专门的消息中间件(如RocketMQ、Kafka)会带来额外的运维成本。MQX基于MySQL实现消息队列功能,复用现有的MySQL基础设施,降低系统复杂度。核心特性零部署:作为Go语言库集成,无需部署额外服务消息可靠:基于
- 【腾讯云中间件】2023年热门文章集锦
各位读者,大家好!光阴似箭,日月如梭,仿佛冬奥会的盛况还在眼前,新的一年却即将到来。在过去的一年里,我们见证了腾讯云中间件在产品升级与创新方面的显著进步,包括消息队列TDMQ品牌全新升级和新产品发布,微服务引擎升级与异地多活单元化能力发布等。腾讯云中间件团队一直秉承持续创新的精神,致力于为行业带来更加优质的产品和服务。在过去的一年里,我们见证了产品升级与创新带来的显著成果。团队不断优化产品性能,提
- 探秘MoonMQ:一款高速分布式消息队列系统
蒙丁啸Sharp
探秘MoonMQ:一款高速分布式消息队列系统moonmqafastdistributedmessagequeueimplementedwithgo项目地址:https://gitcode.com/gh_mirrors/mo/moonmq在当今的微服务架构和高并发场景下,消息队列作为连接各个服务的桥梁,其重要性不言而喻。今天,我们要向大家隆重推荐一个基于Go语言实现的高速分布式消息队列——MoonM
- 消息中间件 --- Apache Pulsar
johnrui
云计算
使用场景,参考地址:最佳实践|ApachePulsar在拉卡拉的技术实践_开源_ApachePulsar_InfoQ写作社区场景1:流式队列场景2:消息队列:OpenMessaging协议实现(透明层协议)场景3:流式队列:自定义Kafka0.8-Source(Source开发)场景4:流式队列:Function消息过滤(消息过滤)场景5:流式队列:PulsarFlinkConnector流式计算
- 最全redis缓存核心知点(原理+图解)
敲代码的胖虎
数据库redis队列数据库分布式
redis缓存核心知点一、主流应用架构二、缓存知识考点三、多路I/O复用模型四、常用的数据类型五、消息队列六、Redis的持久化6.1BGSAVE原理6.2RBD持久化的缺点6.3持久化方式之AOF6.4AOF文件重写6.5Redis数据的恢复6.7RDB和AOF的优缺点6.8RDB-AOF混合持久化方式(新版本的默认备份方式)七、Pipeline及主从同步7.1Pipeline的简介7.2red
- 后端技术栈都有哪些
python资深爱好者
webhttp网络安全
在后端技术领域,有很多不同的技术栈可供选择,这取决于项目的具体需求、团队的技能和经验以及所使用的框架或库的流行程度。以下是一些常见的后端技术栈的示例:Node.js:框架:Express.js,Koa.js,NestJS,Hapi.js数据库:MongoDB,MySQL,PostgreSQL,Redis模板引擎:EJS,Pug(Jade),Nunjucks缓存:Redis消息队列:RabbitMQ
- 常见的消息队列(MQ)及其区别
常见的消息队列(MQ)及其区别消息队列协议特点适用场景性能表现消息持久化方式是否保证消息顺序RabbitMQAMQP功能完备、稳定可靠,支持多种消息路由模式适用于对消息可靠性和事务支持要求较高的应用高可靠性,但在高并发下性能一般消息和队列都可以设置为持久化,保证重启后不丢失支持顺序消息,顺序性较好Kafka自定义协议高吞吐量、低延迟、良好的可扩展性适合处理海量的日志数据、大规模数据场景极高吞吐量,
- Spring Boot集成Redisson实现延迟队列
涛哥是个大帅比
Springspringbootredisredisson延迟队列延迟消息
项目场景:在电商、支付等领域,往往会有这样的场景,用户下单后放弃支付了,那这笔订单会在指定的时间段后进行关闭操作,细心的你一定发现了像某宝、某东都有这样的逻辑,而且时间很准确,误差在1s内;那他们是怎么实现的呢?一般实现的方法有几种:使用redisson、rocketmq、rabbitmq等消息队列的延时投递功能。解决方案:一般项目集成redis的比较多,所以我这篇文章就说下redisson延迟队
- 【RabbitMQ】【PHP】PHP&RabbitMQ高级用法和性能优化的技巧
gskyi
RabbitMQPHPrabbitmqphp性能优化
在使用RabbitMQ进行消息队列管理时,有几个高级用法和性能优化的技巧,以及常见问题及其解决方法,以下是一些重要的建议和最佳实践。1.高级用法1.1使用交换机(Exchanges)RabbitMQ使用交换机(Exchange)来决定消息的路由方式。常见的交换机类型有:DirectExchange:消息通过路由键发送到指定队列。FanoutExchange:消息广播到所有绑定的队列。TopicEx
- linux/C++ 进程线程
takkto
linuxc++运维
linux/C++进程线程文章目录linux/C++进程线程进程创建进程:跳转执行另一个程序僵尸进程命令与进程树孤儿进程进程间通信匿名管道(Pipe)有名管道(FIFO)共享内存消息队列signal信号基本概念使用方法信号类型处理动作含义信号处理方法发送信号多进程和信号调用可执行程序进程终止5种正常终止进程的方法3种异常终止进程的方法return和三种exit之间的区别进程的终止函数线程创建线程等
- 详解Redis淘汰策略
优人ovo
redismybatis数据库
引言Redis是一个高性能的内存数据库,广泛应用于缓存系统、消息队列等场景。当Redis的内存达到限制时,需要根据一定的策略来淘汰数据,以便腾出空间给新数据。本文将深入解析Redis的内存淘汰机制,帮助更好地配置Redis,应对不同的内存需求。Redis内存淘汰机制Redis默认将所有数据存储在内存中,当内存满了且没有设置淘汰策略时,Redis将无法接受新的写入操作。因此,Redis提供了一些内存
- 【复习】Redis
xiaolin0333
复习=。=redis数据库缓存
数据结构Redis常见的数据结构String:缓存对象Hash:缓存对象、购物车List:消息队列Set:点赞、共同关注ZSet:排序Zset底层?Zset底层的数据结构是由压缩链表或跳表实现的如果有序集合的元素0.25结束,最终确定该节点的层数为什么Zset使用跳表而不是B+树?B+树的设计目标是优化磁盘,通过减少树的高度来降低磁盘寻道次数;跳表是基于链表,通过多级索引加速查询,内存访问模式更符
- 嵌入式学习|C语言篇进程间通信(IPC)全面解析与示例
DXX——
学习c语言php
一、进程通信基础概念1.1进程隔离原理现代操作系统通过虚拟内存技术为每个进程创建独立的地址空间,这种隔离机制保障了系统的安全性,但也导致进程无法直接访问彼此的内存数据。进程间通信(IPC)正是为解决这一矛盾而设计的核心机制。1.2IPC分类体系主要通信方式可分为:传统UnixIPC:管道、FIFOSystemVIPC:消息队列、信号量、共享内存POSIXIPC:改进的消息队列、信号量、共享内存网络
- RabbitMQ集群搭建:使用HAProxy和Keepalived实现RabbitMQ的高可用负载均衡
EvktJava
rabbitmq负载均衡ruby
在本文中,我们将探讨如何使用HAProxy和Keepalived来搭建RabbitMQ的高可用负载均衡集群。我们还将介绍如何将SpringBoot与RabbitMQ集成,以便在应用程序中使用消息队列。搭建RabbitMQ集群首先,我们需要搭建一个RabbitMQ集群。在集群中,我们将有多个节点来处理消息队列的请求。每个节点都是独立的,但它们之间会相互通信以保持数据的同步。为了简化安装过程,我们将使
- 计算机基础之操作系统——进程与线程管理(一)
查理养殖场
计算机八股linux
1、进程、线程、协程区别与联系?进程、线程和协程是计算机程序执行的三个不同层次。进程(Process):定义:进程是操作系统进行资源分配和调度的基本单位,每个进程都有自己的内存空间、系统资源和程序计数器。特点:进程间相互独立。每个进程有自己的地址空间,无法直接访问其他进程的数据。进程之间的资源是相互隔离的,进程之间的通信需要通过进程间通信(IPC)机制,如管道、消息队列、共享内存等。开销较大,因为
- 全面汇总windows进程通信(三)
爱上解放晚晚
C++高级编程实例windowsqt开发语言c++
在Windows操作系统下,实现进程间通信(IPC,Inter-ProcessCommunication)有几种常见的方法,包括使用管道(Pipe)、共享内存(SharedMemory)、消息队列(MessageQueue)、命名管道(NamedPipe)、套接字(Socket)等。本文介绍如下几种:RPC(远程过程调用,RemoteProcedureCall)Windows注册表(Registr
- 全面汇总windows进程通信(四)
爱上解放晚晚
C++高级编程实例windowsc++
在Windows操作系统下,实现进程间通信(IPC,Inter-ProcessCommunication)有几种常见的方法,包括使用管道(Pipe)、共享内存(SharedMemory)、消息队列(MessageQueue)、命名管道(NamedPipe)、套接字(Socket)等。本文介绍如下几种:Windows共享内存(SharedMemorywithMappedFiles)Windows套接
- jvm调优总结(从基本概念 到 深度优化)
oloz
javajvmjdk虚拟机应用服务器
JVM参数详解:http://www.cnblogs.com/redcreen/archive/2011/05/04/2037057.html
Java虚拟机中,数据类型可以分为两类:基本类型和引用类型。基本类型的变量保存原始值,即:他代表的值就是数值本身;而引用类型的变量保存引用值。“引用值”代表了某个对象的引用,而不是对象本身,对象本身存放在这个引用值所表示的地址的位置。
- 【Scala十六】Scala核心十:柯里化函数
bit1129
scala
本篇文章重点说明什么是函数柯里化,这个语法现象的背后动机是什么,有什么样的应用场景,以及与部分应用函数(Partial Applied Function)之间的联系 1. 什么是柯里化函数
A way to write functions with multiple parameter lists. For instance
def f(x: Int)(y: Int) is a
- HashMap
dalan_123
java
HashMap在java中对很多人来说都是熟的;基于hash表的map接口的非同步实现。允许使用null和null键;同时不能保证元素的顺序;也就是从来都不保证其中的元素的顺序恒久不变。
1、数据结构
在java中,最基本的数据结构无外乎:数组 和 引用(指针),所有的数据结构都可以用这两个来构造,HashMap也不例外,归根到底HashMap就是一个链表散列的数据
- Java Swing如何实时刷新JTextArea,以显示刚才加append的内容
周凡杨
java更新swingJTextArea
在代码中执行完textArea.append("message")后,如果你想让这个更新立刻显示在界面上而不是等swing的主线程返回后刷新,我们一般会在该语句后调用textArea.invalidate()和textArea.repaint()。
问题是这个方法并不能有任何效果,textArea的内容没有任何变化,这或许是swing的一个bug,有一个笨拙的办法可以实现
- servlet或struts的Action处理ajax请求
g21121
servlet
其实处理ajax的请求非常简单,直接看代码就行了:
//如果用的是struts
//HttpServletResponse response = ServletActionContext.getResponse();
// 设置输出为文字流
response.setContentType("text/plain");
// 设置字符集
res
- FineReport的公式编辑框的语法简介
老A不折腾
finereport公式总结
FINEREPORT用到公式的地方非常多,单元格(以=开头的便被解析为公式),条件显示,数据字典,报表填报属性值定义,图表标题,轴定义,页眉页脚,甚至单元格的其他属性中的鼠标悬浮提示内容都可以写公式。
简单的说下自己感觉的公式要注意的几个地方:
1.if语句语法刚接触感觉比较奇怪,if(条件式子,值1,值2),if可以嵌套,if(条件式子1,值1,if(条件式子2,值2,值3)
- linux mysql 数据库乱码的解决办法
墙头上一根草
linuxmysql数据库乱码
linux 上mysql数据库区分大小写的配置
lower_case_table_names=1 1-不区分大小写 0-区分大小写
修改/etc/my.cnf 具体的修改内容如下:
[client]
default-character-set=utf8
[mysqld]
datadir=/var/lib/mysql
socket=/va
- 我的spring学习笔记6-ApplicationContext实例化的参数兼容思想
aijuans
Spring 3
ApplicationContext能读取多个Bean定义文件,方法是:
ApplicationContext appContext = new ClassPathXmlApplicationContext(
new String[]{“bean-config1.xml”,“bean-config2.xml”,“bean-config3.xml”,“bean-config4.xml
- mysql 基准测试之sysbench
annan211
基准测试mysql基准测试MySQL测试sysbench
1 执行如下命令,安装sysbench-0.5:
tar xzvf sysbench-0.5.tar.gz
cd sysbench-0.5
chmod +x autogen.sh
./autogen.sh
./configure --with-mysql --with-mysql-includes=/usr/local/mysql
- sql的复杂查询使用案列与技巧
百合不是茶
oraclesql函数数据分页合并查询
本片博客使用的数据库表是oracle中的scott用户表;
------------------- 自然连接查询
查询 smith 的上司(两种方法)
&
- 深入学习Thread类
bijian1013
javathread多线程java多线程
一. 线程的名字
下面来看一下Thread类的name属性,它的类型是String。它其实就是线程的名字。在Thread类中,有String getName()和void setName(String)两个方法用来设置和获取这个属性的值。
同时,Thr
- JSON串转换成Map以及如何转换到对应的数据类型
bijian1013
javafastjsonnet.sf.json
在实际开发中,难免会碰到JSON串转换成Map的情况,下面来看看这方面的实例。另外,由于fastjson只支持JDK1.5及以上版本,因此在JDK1.4的项目中可以采用net.sf.json来处理。
一.fastjson实例
JsonUtil.java
package com.study;
impor
- 【RPC框架HttpInvoker一】HttpInvoker:Spring自带RPC框架
bit1129
spring
HttpInvoker是Spring原生的RPC调用框架,HttpInvoker同Burlap和Hessian一样,提供了一致的服务Exporter以及客户端的服务代理工厂Bean,这篇文章主要是复制粘贴了Hessian与Spring集成一文,【RPC框架Hessian四】Hessian与Spring集成
在
【RPC框架Hessian二】Hessian 对象序列化和反序列化一文中
- 【Mahout二】基于Mahout CBayes算法的20newsgroup的脚本分析
bit1129
Mahout
#!/bin/bash
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information re
- nginx三种获取用户真实ip的方法
ronin47
随着nginx的迅速崛起,越来越多公司将apache更换成nginx. 同时也越来越多人使用nginx作为负载均衡, 并且代理前面可能还加上了CDN加速,但是随之也遇到一个问题:nginx如何获取用户的真实IP地址,如果后端是apache,请跳转到<apache获取用户真实IP地址>,如果是后端真实服务器是nginx,那么继续往下看。
实例环境: 用户IP 120.22.11.11
- java-判断二叉树是不是平衡
bylijinnan
java
参考了
http://zhedahht.blog.163.com/blog/static/25411174201142733927831/
但是用java来实现有一个问题。
由于Java无法像C那样“传递参数的地址,函数返回时能得到参数的值”,唯有新建一个辅助类:AuxClass
import ljn.help.*;
public class BalancedBTree {
- BeanUtils.copyProperties VS PropertyUtils.copyProperties
诸葛不亮
PropertyUtilsBeanUtils
BeanUtils.copyProperties VS PropertyUtils.copyProperties
作为两个bean属性copy的工具类,他们被广泛使用,同时也很容易误用,给人造成困然;比如:昨天发现同事在使用BeanUtils.copyProperties copy有integer类型属性的bean时,没有考虑到会将null转换为0,而后面的业
- [金融与信息安全]最简单的数据结构最安全
comsci
数据结构
现在最流行的数据库的数据存储文件都具有复杂的文件头格式,用操作系统的记事本软件是无法正常浏览的,这样的情况会有什么问题呢?
从信息安全的角度来看,如果我们数据库系统仅仅把这种格式的数据文件做异地备份,如果相同版本的所有数据库管理系统都同时被攻击,那么
- vi区段删除
Cwind
linuxvi区段删除
区段删除是编辑和分析一些冗长的配置文件或日志文件时比较常用的操作。简记下vi区段删除要点备忘。
vi概述
引文中并未将末行模式单独列为一种模式。单不单列并不重要,能区分命令模式与末行模式即可。
vi区段删除步骤:
1. 在末行模式下使用:set nu显示行号
非必须,随光标移动vi右下角也会显示行号,能够正确找到并记录删除开始行
- 清除tomcat缓存的方法总结
dashuaifu
tomcat缓存
用tomcat容器,大家可能会发现这样的问题,修改jsp文件后,但用IE打开 依然是以前的Jsp的页面。
出现这种现象的原因主要是tomcat缓存的原因。
解决办法如下:
在jsp文件头加上
<meta http-equiv="Expires" content="0"> <meta http-equiv="kiben&qu
- 不要盲目的在项目中使用LESS CSS
dcj3sjt126com
Webless
如果你还不知道LESS CSS是什么东西,可以看一下这篇文章,是我一朋友写给新人看的《CSS——LESS》
不可否认,LESS CSS是个强大的工具,它弥补了css没有变量、无法运算等一些“先天缺陷”,但它似乎给我一种错觉,就是为了功能而实现功能。
比如它的引用功能
?
.rounded_corners{
- [入门]更上一层楼
dcj3sjt126com
PHPyii2
更上一层楼
通篇阅读完整个“入门”部分,你就完成了一个完整 Yii 应用的创建。在此过程中你学到了如何实现一些常用功能,例如通过 HTML 表单从用户那获取数据,从数据库中获取数据并以分页形式显示。你还学到了如何通过 Gii 去自动生成代码。使用 Gii 生成代码把 Web 开发中多数繁杂的过程转化为仅仅填写几个表单就行。
本章将介绍一些有助于更好使用 Yii 的资源:
- Apache HttpClient使用详解
eksliang
httpclienthttp协议
Http协议的重要性相信不用我多说了,HttpClient相比传统JDK自带的URLConnection,增加了易用性和灵活性(具体区别,日后我们再讨论),它不仅是客户端发送Http请求变得容易,而且也方便了开发人员测试接口(基于Http协议的),即提高了开发的效率,也方便提高代码的健壮性。因此熟练掌握HttpClient是很重要的必修内容,掌握HttpClient后,相信对于Http协议的了解会
- zxing二维码扫描功能
gundumw100
androidzxing
经常要用到二维码扫描功能
现给出示例代码
import com.google.zxing.WriterException;
import com.zxing.activity.CaptureActivity;
import com.zxing.encoding.EncodingHandler;
import android.app.Activity;
import an
- 纯HTML+CSS带说明的黄色导航菜单
ini
htmlWebhtml5csshovertree
HoverTree带说明的CSS菜单:纯HTML+CSS结构链接带说明的黄色导航
在线体验效果:http://hovertree.com/texiao/css/1.htm代码如下,保存到HTML文件可以看到效果:
<!DOCTYPE html >
<html >
<head>
<title>HoverTree
- fastjson初始化对性能的影响
kane_xie
fastjson序列化
之前在项目中序列化是用thrift,性能一般,而且需要用编译器生成新的类,在序列化和反序列化的时候感觉很繁琐,因此想转到json阵营。对比了jackson,gson等框架之后,决定用fastjson,为什么呢,因为看名字感觉很快。。。
网上的说法:
fastjson 是一个性能很好的 Java 语言实现的 JSON 解析器和生成器,来自阿里巴巴的工程师开发。
- 基于Mybatis封装的增删改查实现通用自动化sql
mengqingyu
DAO
1.基于map或javaBean的增删改查可实现不写dao接口和实现类以及xml,有效的提高开发速度。
2.支持自定义注解包括主键生成、列重复验证、列名、表名等
3.支持批量插入、批量更新、批量删除
<bean id="dynamicSqlSessionTemplate" class="com.mqy.mybatis.support.Dynamic
- js控制input输入框的方法封装(数字,中文,字母,浮点数等)
qifeifei
javascript js
在项目开发的时候,经常有一些输入框,控制输入的格式,而不是等输入好了再去检查格式,格式错了就报错,体验不好。 /** 数字,中文,字母,浮点数(+/-/.) 类型输入限制,只要在input标签上加上 jInput="number,chinese,alphabet,floating" 备注:floating属性只能单独用*/
funct
- java 计时器应用
tangqi609567707
javatimer
mport java.util.TimerTask; import java.util.Calendar; public class MyTask extends TimerTask { private static final int
- erlang输出调用栈信息
wudixiaotie
erlang
在erlang otp的开发中,如果调用第三方的应用,会有有些错误会不打印栈信息,因为有可能第三方应用会catch然后输出自己的错误信息,所以对排查bug有很大的阻碍,这样就要求我们自己打印调用的栈信息。用这个函数:erlang:process_display (self (), backtrace).需要注意这个函数只会输出到标准错误输出。
也可以用这个函数:erlang:get_s