- 【ARMv8M Cortex-M33 系列 2.4 -- JFlash 烧写之链接脚本介绍】
主公CodingCos
#【ARMv8MM33专栏】嵌入式硬件arm开发
文章目录JFlash烧写之链接脚本介绍MEMORY区段示例SECTIONS区段示例符号定义启动代码实际使用ARMBCC指令介绍BCC指令使用举例JFlash烧写之链接脚本介绍在RT-Thread实时操作系统中,链接脚本(LinkerScript)定义了如何将代码和数据映射到微控制器的内存中。链接脚本通常以.ld为扩展名。对于特定的微控制器,如RenesasR7FA4M2AC3C,链接脚本中的MEM
- [译] ARMv8-A系统安全之TrustZone硬件架构
赵国开
[译]ARMv8-A系统安全之TrustZone硬件架构原文https://developer.arm.com/products/architecture/a-profile/docs/100935/latest/the-trustzone-hardware-architecture
- ARMv8-AArch64 的异常处理模型详解之异常处理概述Handling exceptions
SOC罗三炮
ARMarm异常处理exceptionAArch64ARMv8
异常处理模型详解之异常处理概述一,异常处理相关概念二,异常处理概述一,异常处理相关概念在介绍异常处理之前,有必要了解一些关于异常处理状态的术语:当处理器响应一个异常时,我们称该异常被获取了(taken)。处理器响应异常之前的状态被称为takenfrom。处理器响应异常之后的状态被称为takento。因此,当处理器识别到异常时,此时处理器处于takenfrom。在异常之后的状态称为takento。当
- armv8 qemu bios uart hello world 实现
goodcat666
tee安全teepwn
uartuart.h#if!defined(_UART_H)#define_UART_H#includevoiduart_putc(constcharc);voiduart_puthex(uint64_tn);voiduart_puts(constchar*s);#endif/*_UART_H*/uart.c#include"uart.h"volatileunsignedint*constUART
- 基于鲲鹏服务NodeJs安装
sujrex
鲲鹏服务器鲲鹏arcch64nodejs
准备工作查看当前环境uname-a查看鲲鹏云CPU架构cat/proc/cpuinfo#查看CPUarchitecture项,8表示v8,7表示v7下载Node.jsNodeJs选择LinuxBinaries(ARM)ARMv8wget-chttps://nodejs.org/dist/v12.18.3/node-v12.18.3-linux-arm64.tar.xz编译安装解压tarxvfnod
- Armv8-M的TrustZone技术在不同攻击场景下的安全性
安全二次方
ARM安全ARM安全架构ARMv8-MTrustzone攻击场景下的安全性
在讨论安全系统设计时,一个常见的问题是:“它有多安全?”在Armv8-M的TrustZone技术开发中考虑了许多攻击场景的各个方面,例如:软件访问:通过额外的系统级组件,内存可以在安全和非安全空间之间分区,并可以禁止非安全软件访问安全内存和资源。分支跳转到任意的安全地址位置:SG指令和NSC内存属性确保只能在有效入口点处进行从非安全到安全的分支。二进制数据中的意外SG指令:NSC内存属性确保只有预
- Armv8-M的TrustZone技术之IDAU接口、IDAU和内存映射
安全二次方
ARM安全ARM安全架构ARMv8-MTrustzoneIDAU内存映射
IDAU(ImplementationDefinedAttributionUnit)用于向处理器指示特定内存地址是安全的、非安全可调用(NSC)的,还是非安全的,并提供内存地址所在的区域号。它还可以标记一个内存区域,以免受安全检查的影响,例如一个ROM表。总体而言,IDAU接口是处理器特定的。然而,不同Cortex-M处理器上的IDAU接口之间存在高度相似性。理论上,设计IDAU为可编程是可能的。
- Linux——命令行查看操作系统架构
Irving.Gao
Linux
命令行查看操作系统架构uname-a对于arm架构,一般32位为armv7,64位armv8。
- [architecture]-DMB、DSB 和 ISB指令的深度解读
代码改变世界ctw
ARM-TEE-Androidarmv9DMBDSBISB内存屏障
快速链接:.个人博客笔记导读目录(全部)付费专栏-付费课程【购买须知】:【精选】ARMv8/ARMv9架构入门到精通-[目录]术语:DMB–DataMemoryBarrierDSB–DataSynchronizationBarrierISB–InstructionSynchronizationBarrier思考:内存屏障到底屏的什么?为什么要用内存屏障?乱序执行是怎样的一个乱序?为什么会出现乱序
- 一个查看armv8系统寄存器-值-含义的方式
goodcat666
tee安全teepwn
找到解压后的SysReg_xml_v86A-2019-12目录wgethttps://developer.arm.com/-/media/developer/products/architecture/armv8-a-architecture/2019-12/SysReg_xml_v86A-2019-12.tar.gzwgethttps://developer.arm.com/-/media/de
- 浅析Linux进程管理:preempt_count抢占计数器
Aspiresky
#进程管理linux服务器运维
本文基于Linux5.10.186版本内核源码进行分析。文章目录preempt_count变量preempt_count字段使用preempt变量判断系统上下文preempt_count变量的定义x86体系下preempt_count变量ARMv8体系下preempt_count变量系统上下文的设置内核抢占操作使能抢占禁止抢占软中断上下文进入软中断下文退出软中断上下文禁用/使能中断下半部硬中断上下
- 浅析Linux进程管理:current宏实现
Aspiresky
#进程管理linux运维服务器
本文基于Linux5.10.186版本内核源码进行分析。文章目录current概述早期内核版本实现最新版本内核实现x86体系下的current宏实现ARMv8体系下的current实现相关参考current概述Linux内核在运行时经常需要访问当前运行进程的task_struct指针,于是,系统提供了current宏来查找当前运行进程的task_struct指针。由于体系结构的不同,加上内核版本在
- Armv8-M的TrustZone技术之在安全状态和非安全状态之间切换
安全二次方
博客目录导读ARM安全ARM安全架构ARMv8-MTrustzone安全非安全切换
Armv8-M安全扩展允许在安全和非安全软件之间直接调用。Armv8-M处理器提供了几条指令来处理状态转换:下图显示了安全状态转换。如果入口点的第一条指令是SG且位于非安全可调用内存位置中,则允许从非安全到安全软件的直接API函数调用。当非安全程序调用安全API时,API通过使用BXNS指令返回到非安全状态。如果非安全程序尝试分支或调用安全程序地址而不使用有效的入口点,则会生成故障事件。在Armv
- Armv8-M的TrustZone技术之测试目标指令
安全二次方
博客目录导读ARM安全ARM安全架构ARMv8-MTrustzoneTT指令
为了允许软件确定内存位置的安全属性,使用了TT指令(TestTarget)。TestTarget(TT)查询内存位置的安全状态和访问权限。TestTargetUnprivileged(TTT)查询内存位置的安全状态和访问权限,以进行对该位置的非特权访问。TestTargetAlternateDomain(TTA)和TestTargetAlternateDomainUnprivileged(TTAT
- 二进制分析平台逆向编译器:Vector 35 Binary Ninja for Mac
d5fanfan
macos
BinaryNinja是一个交互式反汇编器、反编译器和二进制分析平台,Vector35为多种架构的反汇编提供第一方支持,包括x86、x86-64、ARMv7(带有Thumb2)、ARMv8(AArch64)、PowerPC、6502、Z80和MIps,我们的反编译器输出到C和BNIL,并且可以按需切换。非常适用于在Windows上运行的逆向工程师、恶意软件分析师、漏洞研究人员和软件开发人员。bin
- Uboot中ARMV7和ARMV8 MMU配置
持续成长,保持快乐
ubootlinux嵌入式硬件
问题概述Uboot中如果打开MMU,则MMU需要配置MMUtable来管理不同的地址空间。其中ARMV7和ARMV8中这部分的配置代码是不同。ARMV7的配置过程代码参考:u-boot-2020.04/arch/arm/lib/cache-cp15.cmmu_setup→set_section_dcache→dram_bank_mmu_setup其中dram_bank_mmu_setup函数中使用
- Arm AArch64 alignment(对齐)
谷公子的藏经阁
ARMARMAArch64alignmentarchitectureattributes
数据和指令必须与合适的边界保持对齐(alignment)。访问是否对齐会影响ARM核的性能,并且在将代码从早期的体系结构移植到ARMv8-A时可能会出现可移植性问题。出于性能原因,或者在移植代码时,都值得去注意下对齐问题。本文将讲述了ARMv8-AAArch64的对齐。一、指令对齐指令对齐(Instructionalignment)比较简单,A64指令必须word对齐。如果从非对齐位置读取指令的话
- 2024最新:Armv8/Armv9架构从入门到精通二期-课程介绍
代码改变世界ctw
学习方法armv9armv8arm架构SOC芯片安全
【学习对象】[行业]:汽车电子、手机、服务器、云计算、物联网、人工智能;[人群]:本科/研究生/博士、初级工程师、中级工程师、资深工程师、行业大佬,即适合小白入门,也适合大佬查缺补漏;[方向]:电子/计算机专业、芯片架构设计、芯片底层软件、芯片验证、BSP软件开发、内核驱动开发、固件开发、bootrom/bootloader开发、安全、虚拟化、大系统开发等;[行业链]:主机厂、OEM、OEM、ti
- 2024最新:optee系统开发精讲 - 课程介绍
代码改变世界ctw
学习方法opteeATFtrustzonearmv9armv8armtee
(本课程中如有涉及代码或硬件架构,则对应的版本号:TF-A2.80,optee3.20,LinuxKernel6.3,armv8.7+9.0的aarch64)(注意:该课程没有PPT,该课程是对照代码讲解的)适用人群安全行业开发者ATF、固件开发者系统架构师、战略规划师汽车行业软件工程师ASIC硬件开发者SOC/芯片底层软件开发者系统工程师/BSP软件工程师/驱动工程师学生…既适合资深/高级工程师
- 2024最新:ATF架构开发精讲 - 课程介绍
代码改变世界ctw
学习方法trustzoneteeATFoptee安全armv9armv8
(本课程中如有涉及代码或硬件架构,则对应的版本号:TF-A2.80,optee3.20,LinuxKernel6.3,armv8.7+9.0的aarch64)适用人群安全行业开发者ATF、固件开发者系统架构师、战略规划师汽车行业软件工程师ASIC硬件开发者SOC/芯片底层软件开发者系统工程师/BSP软件工程师/驱动工程师学生…既适合资深/高级工程师来查缺补漏,又适合初级工程师入门,也适合ASIC同
- CSDN : Armv8/Armv9架构从入门到精通二期-课程介绍
代码改变世界ctw
ARMARMV9armv8arm64ARMARM视频ARM资料嵌入式
【学习对象】[行业]:汽车电子、手机、服务器、云计算、物联网、人工智能;[人群]:本科/研究生/博士、初级工程师、中级工程师、资深工程师、行业大佬,即适合小白入门,也适合大佬查缺补漏;[方向]:电子/计算机专业、芯片架构设计、芯片底层软件、芯片验证、BSP软件开发、内核驱动开发、固件开发、bootrom/bootloader开发、安全、虚拟化、大系统开发等;[行业链]:主机厂、OEM、OEM、ti
- 《Armv8/armv9架构入门指南》-【第二章】ARMv8‑A 架构和处理器
嵌入式学习规划
Arm原理和基础架构
引流关键词:optee、ATF、TF-A、Trustzone、optee3.14、MMU、VMSA、cache、TLB、arm、armv8、armv9、TEE、安全、内存管理、页表,Non-cacheable,Cacheable,non-shareable,inner-shareable,outer-shareable,optee、ATF、TF-A、Trustzone、optee3.14、MMU、
- 2024最新:Armv8/Armv9架构从入门到精通一期-课程介绍
代码改变世界ctw
学习方法架构armv9armv8armtrustzonetee安全
学习对象在全民造车、造芯的大时代,在努力去解决卡脖子的时代,ASIC硬件、SOC底层软件、LinuxKernel等操作系统软件(内核/驱动)、软硬件方面的系统架构师等的岗位需求也越来越明显,社会一直都是非常缺人的,缺的是核心的那一小撮、领头的那一小撮,社会所缺的更是能够软硬件融合的那一小撮人……总之,要想在这个时代,站稳自己的脚跟,能够在大公司或行业上拥有一席之地,就必需深入学习底层技术原理,核心
- stm32产品架构
晴山ぺ
#相关知识arm开发架构
文章目录前言一、pandas是什么?二、使用步骤1.引入库2.读入数据总结前言起因是我在看野火的ucosiii,然后他是基于i.mx芯片。然后我就很疑惑i.mx是什么芯片,看了下好像是ARM-M7(或者叫ARMCM7)架构的芯片。然后我又疑惑ARM-M7又是什么架构。然后看到知乎一篇文章这样写:ARM架构:由英国ARM公司设计的一系列32位的RISC微处理器架构总称,现有ARMv1~ARMv8种类
- armv8 - GIC-V2 中断控制器
三境界
嵌入式Linux操作系统个人笔记linuxarm开发
GIC起源上一节中,粗略讲了hylicos上用的armv7上的一个通用中断控制器,其只支持60个中断源。但现代SoC上,中断系统正变得越来越复杂,旧的中断控制器已经无法胜任这些系统,主要体现在以下几点上:中断源越来越多,有的系统中断源有几百个,甚至上千个。中断类型越来越多,比如普通外设中断,软件触发中断,CPUCore之间的中断,还有类似于PCIe上的基于消息传递的中断等虚拟化技术的引入,主要开始
- Armv8-M的TrustZone技术之内存系统和内存分区
卢鸿波
博客目录导读ARM安全ARM安全架构ARMv8-MTrustzone内存系统内存分区
如果实现了安全扩展,4GB的内存空间将被划分为安全和非安全内存区域。安全内存空间进一步分为两种类型:安全(S)和非安全可调用(NSC)。3.1安全(S)安全地址用于只能由安全软件或安全主设备访问的内存和外设。安全事务是源自作为安全操作或被视为安全的主设备的事务,且其目标是安全地址。3.2非安全可调用(NSC)NSC是一种特殊类型的安全位置。这种类型的内存是Armv8-M处理器允许容纳SG指令的唯一
- 13-SDEI: Software Delegated Exception Interface
代码改变世界ctw
atf_docatfarmv9SEDI
引流关键词:中断、同步异常、异步异常、irq、fiq、BL1,BL2,BL3,BL31,BL32,BL33,AP_BL1,AP_BL2,AP_BL3,AP_BL31,AP_BL32,AP_BL33,SCP_BL1,SCP_BL2,BL0,BL30,optee、ATF、TF-A、Trustzone、optee3.14、MMU、VMSA、cache、TLB、arm、armv8、armv9、TEE、安全
- Armv8-M的TrustZone技术之SAU寄存器总结
卢鸿波
博客目录导读ARM安全ARM安全架构ARMv8-MTrustzoneSAU
每个SAU寄存器是32位宽。下表显示了SAU寄存器概要。5.1SAU_CTRLregisterSAU_CTRL寄存器的特征如下图和表所示:5.2SAU_TYPEregister5.3SAU_RNRregister5.4SAU_RBARregister5.5SAU_RLARregister5.6SAU区域配置当SAU启用时,未由已启用的SAU区域覆盖的内存是安全的。区域可以单独使用SAU_RLAR启
- ARMv8-AArch64 的异常处理模型详解之异常类型 Exception types
SOC罗三炮
ARMARM异常等级异常处理同步异常异步异常
异常类型详解Exceptiontypes一,什么是异常二,同步异常(synchronousexceptions)2.1无效的指令和陷阱异常(Invalidinstructionsandtrapexceptions)2.2内存访问产生的异常2.3产生异常的指令2.4调试异常Debugexceptions三,异步异常Asynchronousexceptions3.1物理中断Physicalinterr
- 【ARM 常见汇编指令学习 2 -- 存储指令 STP 与 LDP】
CodingCos
#ARM64常见汇编指令学习STPLDPARMSTPARMLDPARMBLARMBLRBLR与BL区别
文章目录STP存储指令LDP加载指令上篇文章:ARM常见汇编指令学习1–跳转指令BL与BLR区别下篇文章:ARM常见汇编指令学习3–ARM64无符号位域提取指令UBFXSTP存储指令在ARMv8架构中,STP指令用于将两个通用寄存器的值存储到内存中。STP指令的语法如下:STP,,[{,#}]或STP,,[{,#}]其中:和表示两个要存储的32位通用寄存器,和表示两个要存储的64位通用寄存器。[]
- Java实现的简单双向Map,支持重复Value
superlxw1234
java双向map
关键字:Java双向Map、DualHashBidiMap
有个需求,需要根据即时修改Map结构中的Value值,比如,将Map中所有value=V1的记录改成value=V2,key保持不变。
数据量比较大,遍历Map性能太差,这就需要根据Value先找到Key,然后去修改。
即:既要根据Key找Value,又要根据Value
- PL/SQL触发器基础及例子
百合不是茶
oracle数据库触发器PL/SQL编程
触发器的简介;
触发器的定义就是说某个条件成立的时候,触发器里面所定义的语句就会被自动的执行。因此触发器不需要人为的去调用,也不能调用。触发器和过程函数类似 过程函数必须要调用,
一个表中最多只能有12个触发器类型的,触发器和过程函数相似 触发器不需要调用直接执行,
触发时间:指明触发器何时执行,该值可取:
before:表示在数据库动作之前触发
- [时空与探索]穿越时空的一些问题
comsci
问题
我们还没有进行过任何数学形式上的证明,仅仅是一个猜想.....
这个猜想就是; 任何有质量的物体(哪怕只有一微克)都不可能穿越时空,该物体强行穿越时空的时候,物体的质量会与时空粒子产生反应,物体会变成暗物质,也就是说,任何物体穿越时空会变成暗物质..(暗物质就我的理
- easy ui datagrid上移下移一行
商人shang
js上移下移easyuidatagrid
/**
* 向上移动一行
*
* @param dg
* @param row
*/
function moveupRow(dg, row) {
var datagrid = $(dg);
var index = datagrid.datagrid("getRowIndex", row);
if (isFirstRow(dg, row)) {
- Java反射
oloz
反射
本人菜鸟,今天恰好有时间,写写博客,总结复习一下java反射方面的知识,欢迎大家探讨交流学习指教
首先看看java中的Class
package demo;
public class ClassTest {
/*先了解java中的Class*/
public static void main(String[] args) {
//任何一个类都
- springMVC 使用JSR-303 Validation验证
杨白白
springmvc
JSR-303是一个数据验证的规范,但是spring并没有对其进行实现,Hibernate Validator是实现了这一规范的,通过此这个实现来讲SpringMVC对JSR-303的支持。
JSR-303的校验是基于注解的,首先要把这些注解标记在需要验证的实体类的属性上或是其对应的get方法上。
登录需要验证类
public class Login {
@NotEmpty
- log4j
香水浓
log4j
log4j.rootCategory=DEBUG, STDOUT, DAILYFILE, HTML, DATABASE
#log4j.rootCategory=DEBUG, STDOUT, DAILYFILE, ROLLINGFILE, HTML
#console
log4j.appender.STDOUT=org.apache.log4j.ConsoleAppender
log4
- 使用ajax和history.pushState无刷新改变页面URL
agevs
jquery框架Ajaxhtml5chrome
表现
如果你使用chrome或者firefox等浏览器访问本博客、github.com、plus.google.com等网站时,细心的你会发现页面之间的点击是通过ajax异步请求的,同时页面的URL发生了了改变。并且能够很好的支持浏览器前进和后退。
是什么有这么强大的功能呢?
HTML5里引用了新的API,history.pushState和history.replaceState,就是通过
- centos中文乱码
AILIKES
centosOSssh
一、CentOS系统访问 g.cn ,发现中文乱码。
于是用以前的方式:yum -y install fonts-chinese
CentOS系统安装后,还是不能显示中文字体。我使用 gedit 编辑源码,其中文注释也为乱码。
后来,终于找到以下方法可以解决,需要两个中文支持的包:
fonts-chinese-3.02-12.
- 触发器
baalwolf
触发器
触发器(trigger):监视某种情况,并触发某种操作。
触发器创建语法四要素:1.监视地点(table) 2.监视事件(insert/update/delete) 3.触发时间(after/before) 4.触发事件(insert/update/delete)
语法:
create trigger triggerName
after/before 
- JS正则表达式的i m g
bijian1013
JavaScript正则表达式
g:表示全局(global)模式,即模式将被应用于所有字符串,而非在发现第一个匹配项时立即停止。 i:表示不区分大小写(case-insensitive)模式,即在确定匹配项时忽略模式与字符串的大小写。 m:表示
- HTML5模式和Hashbang模式
bijian1013
JavaScriptAngularJSHashbang模式HTML5模式
我们可以用$locationProvider来配置$location服务(可以采用注入的方式,就像AngularJS中其他所有东西一样)。这里provider的两个参数很有意思,介绍如下。
html5Mode
一个布尔值,标识$location服务是否运行在HTML5模式下。
ha
- [Maven学习笔记六]Maven生命周期
bit1129
maven
从mvn test的输出开始说起
当我们在user-core中执行mvn test时,执行的输出如下:
/software/devsoftware/jdk1.7.0_55/bin/java -Dmaven.home=/software/devsoftware/apache-maven-3.2.1 -Dclassworlds.conf=/software/devs
- 【Hadoop七】基于Yarn的Hadoop Map Reduce容错
bit1129
hadoop
运行于Yarn的Map Reduce作业,可能发生失败的点包括
Task Failure
Application Master Failure
Node Manager Failure
Resource Manager Failure
1. Task Failure
任务执行过程中产生的异常和JVM的意外终止会汇报给Application Master。僵死的任务也会被A
- 记一次数据推送的异常解决端口解决
ronin47
记一次数据推送的异常解决
需求:从db获取数据然后推送到B
程序开发完成,上jboss,刚开始报了很多错,逐一解决,可最后显示连接不到数据库。机房的同事说可以ping 通。
自已画了个图,逐一排除,把linux 防火墙 和 setenforce 设置最低。
service iptables stop
- 巧用视错觉-UI更有趣
brotherlamp
UIui视频ui教程ui自学ui资料
我们每个人在生活中都曾感受过视错觉(optical illusion)的魅力。
视错觉现象是双眼跟我们开的一个玩笑,而我们往往还心甘情愿地接受我们看到的假象。其实不止如此,视觉错现象的背后还有一个重要的科学原理——格式塔原理。
格式塔原理解释了人们如何以视觉方式感觉物体,以及图像的结构,视角,大小等要素是如何影响我们的视觉的。
在下面这篇文章中,我们首先会简单介绍一下格式塔原理中的基本概念,
- 线段树-poj1177-N个矩形求边长(离散化+扫描线)
bylijinnan
数据结构算法线段树
package com.ljn.base;
import java.util.Arrays;
import java.util.Comparator;
import java.util.Set;
import java.util.TreeSet;
/**
* POJ 1177 (线段树+离散化+扫描线),题目链接为http://poj.org/problem?id=1177
- HTTP协议详解
chicony
http协议
引言
- Scala设计模式
chenchao051
设计模式scala
Scala设计模式
我的话: 在国外网站上看到一篇文章,里面详细描述了很多设计模式,并且用Java及Scala两种语言描述,清晰的让我们看到各种常规的设计模式,在Scala中是如何在语言特性层面直接支持的。基于文章很nice,我利用今天的空闲时间将其翻译,希望大家能一起学习,讨论。翻译
- 安装mysql
daizj
mysql安装
安装mysql
(1)删除linux上已经安装的mysql相关库信息。rpm -e xxxxxxx --nodeps (强制删除)
执行命令rpm -qa |grep mysql 检查是否删除干净
(2)执行命令 rpm -i MySQL-server-5.5.31-2.el
- HTTP状态码大全
dcj3sjt126com
http状态码
完整的 HTTP 1.1规范说明书来自于RFC 2616,你可以在http://www.talentdigger.cn/home/link.php?url=d3d3LnJmYy1lZGl0b3Iub3JnLw%3D%3D在线查阅。HTTP 1.1的状态码被标记为新特性,因为许多浏览器只支持 HTTP 1.0。你应只把状态码发送给支持 HTTP 1.1的客户端,支持协议版本可以通过调用request
- asihttprequest上传图片
dcj3sjt126com
ASIHTTPRequest
NSURL *url =@"yourURL";
ASIFormDataRequest*currentRequest =[ASIFormDataRequest requestWithURL:url];
[currentRequest setPostFormat:ASIMultipartFormDataPostFormat];[currentRequest se
- C语言中,关键字static的作用
e200702084
C++cC#
在C语言中,关键字static有三个明显的作用:
1)在函数体,局部的static变量。生存期为程序的整个生命周期,(它存活多长时间);作用域却在函数体内(它在什么地方能被访问(空间))。
一个被声明为静态的变量在这一函数被调用过程中维持其值不变。因为它分配在静态存储区,函数调用结束后并不释放单元,但是在其它的作用域的无法访问。当再次调用这个函数时,这个局部的静态变量还存活,而且用在它的访
- win7/8使用curl
geeksun
win7
1. WIN7/8下要使用curl,需要下载curl-7.20.0-win64-ssl-sspi.zip和Win64OpenSSL_Light-1_0_2d.exe。 下载地址:
http://curl.haxx.se/download.html 请选择不带SSL的版本,否则还需要安装SSL的支持包 2. 可以给Windows增加c
- Creating a Shared Repository; Users Sharing The Repository
hongtoushizi
git
转载自:
http://www.gitguys.com/topics/creating-a-shared-repository-users-sharing-the-repository/ Commands discussed in this section:
git init –bare
git clone
git remote
git pull
git p
- Java实现字符串反转的8种或9种方法
Josh_Persistence
异或反转递归反转二分交换反转java字符串反转栈反转
注:对于第7种使用异或的方式来实现字符串的反转,如果不太看得明白的,可以参照另一篇博客:
http://josh-persistence.iteye.com/blog/2205768
/**
*
*/
package com.wsheng.aggregator.algorithm.string;
import java.util.Stack;
/**
- 代码实现任意容量倒水问题
home198979
PHP算法倒水
形象化设计模式实战 HELLO!架构 redis命令源码解析
倒水问题:有两个杯子,一个A升,一个B升,水有无限多,现要求利用这两杯子装C
- Druid datasource
zhb8015
druid
推荐大家使用数据库连接池 DruidDataSource. http://code.alibabatech.com/wiki/display/Druid/DruidDataSource DruidDataSource经过阿里巴巴数百个应用一年多生产环境运行验证,稳定可靠。 它最重要的特点是:监控、扩展和性能。 下载和Maven配置看这里: http
- 两种启动监听器ApplicationListener和ServletContextListener
spjich
javaspring框架
引言:有时候需要在项目初始化的时候进行一系列工作,比如初始化一个线程池,初始化配置文件,初始化缓存等等,这时候就需要用到启动监听器,下面分别介绍一下两种常用的项目启动监听器
ServletContextListener
特点: 依赖于sevlet容器,需要配置web.xml
使用方法:
public class StartListener implements
- JavaScript Rounding Methods of the Math object
何不笑
JavaScriptMath
The next group of methods has to do with rounding decimal values into integers. Three methods — Math.ceil(), Math.floor(), and Math.round() — handle rounding in differen