- Java多线程与高并发专题——原子类和 volatile、synchronized 有什么异同?
黄雪超
技术基础java开发语言并发编程
原子类和volatile异同首先,通过我们对原子类和的了解,原子类和volatile都能保证多线程环境下的数据可见性。在多线程程序中,每个线程都有自己的工作内存,当多个线程访问共享变量时,可能会出现一个线程修改了共享变量的值,而其他线程不能及时看到最新值的情况。原子类和volatile关键字都能在一定程度上解决这个问题。例如,当一个变量被volatile修饰后,对该变量的写操作会立即刷新到主内存,
- Java多线程与高并发专题——阻塞和非阻塞队列的并发安全原理是什么?
黄雪超
技术基础java开发语言并发编程
引入之前我们探究了常见的阻塞队列的特点,在本文我们就以ArrayBlockingQueue为例,首先分析BlockingQueue,也就是阻塞队列的线程安全原理,然后再看看它的兄弟——非阻塞队列的并发安全原理。ArrayBlockingQueue源码分析我们首先看一下ArrayBlockingQueue的源码,ArrayBlockingQueue有以下几个重要的属性:/***用于存储队列元素的数组
- Java多线程与高并发专题——什么是阻塞队列?
黄雪超
技术基础java开发语言并发编程
引入阻塞队列(BlockingQueue)是一种线程安全的队列数据结构,它的主要特点是:线程安全:多个线程可以安全地同时访问队列。阻塞操作:当队列为空时,从队列中获取元素的操作会被阻塞,直到队列中有元素可用;当队列为满时,向队列中插入元素的操作会被阻塞,直到队列有空间可用。BlockingQueueBlockingQueue继承了Queue接口,是队列的一种。Queue和BlockingQueue
- Java多线程与高并发专题——为什么 Map 桶中超过 8 个才转为红黑树?
黄雪超
技术基础java开发语言并发编程
引入JDK1.8的HashMap和ConcurrentHashMap都有这样一个特点:最开始的Map是空的,因为里面没有任何元素,往里放元素时会计算hash值,计算之后,第1个value会首先占用一个桶(也称为槽点)位置,后续如果经过计算发现需要落到同一个桶中,那么便会使用链表的形式往后延长,俗称“拉链法”。当链表长度大于或等于阈值(默认为8)的时候,如果同时还满足容量大于或等于MIN_TREEI
- Java多线程与高并发专题——线程池源码剖析
黄雪超
技术基础java开发语言并发编程
引入我们先梳理一下如何自定义线程池,首先ThreadPoolExecutor中,一共提供了7个参数,每个参数都是非常核心的属性,在线程池去执行任务时,每个参数都有决定性的作用。但是如果直接采用JDK提供的方式去构建,可以设置的核心参数最多就两个,这样就会导致对线程池的控制粒度很粗。所以推荐自己去自定义线程池,也就是手动的去newThreadPoolExecutor设置他的一些核心属性。自定义构建线
- Java多线程与高并发专题——线程池补充1
黄雪超
技术基础java并发编程开发语言
引入首先,如上图所示,结合上一篇线程池相关文章的内容,我们总结一下线程池的内部结构如下:第一部分是线程池管理器,它主要负责管理线程池的创建、销毁、添加任务等管理操作,它是整个线程池的管家。第二部分是工作线程,也就是图中的线程t0~t9,这些线程勤勤恳恳地从任务队列中获取任务并执行。第三部分是任务队列,作为一种缓冲机制,线程池会把当下没有处理的任务放入任务队列中,由于多线程同时从任务队列中获取任务是
- Java多线程与高并发专题——线程池补充2
黄雪超
技术基础java开发语言并发编程
引入前面我们通过以下问题梳理了线程池相关内容:Java多线程与高并发专题——线程池为什么要使用线程池?如何使用线程池?使用线程池的优缺点?线程池的各个参数的含义?线程池有哪几种拒绝策略?Java多线程与高并发专题——线程池补充1(线程池的内部结构梳理)有哪些常见的线程池?线程池常用的阻塞队列有哪些?为什么不应该自动创建线程池?本篇会通过下面几个问题去进行补充:合适的线程数量是多少?CPU核心数和线
- 多线程与高并发(6)——CAS详解(包含ABA问题)
李王家的翠花
java多线程java开发语言
一、乐观锁和悲观锁乐观锁和悲观锁都是用于解决并发场景下的数据竞争问题,不局限于某种编程语言或数据库。1、乐观锁:就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据。乐观锁的实现方式:主要有两种,一种是CAS机制,一种是版本号机制。(1)版本号机制:在数据中增加一个version字段用来表示该数据的版本号,每当数据被修改版本号就
- Java多线程与高并发专题——JMM
黄雪超
大数据面试java开发语言JMM
引入上一篇我们讲到在并发场景中,存在结果问题和性能问题,其中结果问题主要是因为没有保障可见性、原子性、有序性等导致的。这三者在编程领域属于共性问题,所有的编程语言都会遇到,Java在诞生之初就支持多线程,所以肯定有保障它们的技术方案。理解Java解决并发问题的方案,对于了解其他语言的解决方案有触类旁通的效果。在Java中,对应的解决方案就是JMM(Java内存模型)。什么是JMM?为了更准确的理解
- Java多线程与高并发专题——基础篇1
黄雪超
大数据面试java开发语言并发编程
基础概览进程与线程什么是进程?进程是指运行中的程序。比如我们使用聊天软件,浏览器,需要启动这个程序,操作系统会给这个程序分配一定的资源。什么线程?线程是CPU调度的基本单位,每个线程执行的都是某一个进程的代码的某个片段。进程是系统进行资源分配和调度的基本单位,线程则是进程的一个执行路径,一个进程中至少有一个线程,进程中的多个线程共享进程的资源。在Java中,当我们启动main函数时其实就启动了一个
- JUC多线程与高并发(一)
JasonHuan1123
计算机类linuxjavajvm缓存
1.谈谈对volatile的理解volatile是java虚拟机提供的一种轻量级的同步机制保证可见性不保证原子性禁止指令重排相当于轻量级的sychronized1.1.JMM的理解JMM,java内存模型JavaMemoryModel,是一种抽象的概念,并不真实存在,它描述的是一组规则或规范,通过这组规范定义了程序中各个变量(包括实例字段,静态字段和构成数组对象的元素)的访问方式。JMM关于同步的
- Java多线程与高并发(二):线程安全性
java高并发
线程安全性当多个线程访问某个类时,不管运行时环境采用何种调度方式或者这些线程将如何交替执行,并且在调用代码中不需要任何额外的同步,这个类都能表现出正确的行为,那么这个类就是线程安全的。原子性:同一时刻只能有一个线程对它操作可见性:一个线程对内存的修改能让其他线程观察到有序性:指令执行顺序,杂乱无序原子性Atomic包AtomicIntegerAtomicInteger中的incrementAndG
- 并发编程面试题(持续更新...)
心安成长
面试题并发编程面试java
目录基础知识多线程与高并发Java多线程涉及技术点高并发技术解决方案并发编程的优劣为什么要使用并发编程(并发编程的优点)并发编程有什么缺点并发编程三要素是什么?在Java程序中怎么保证多线程的运行安全?并行和并发有什么区别?什么是多线程,多线程的优劣?线程和进程区别什么是线程和进程?什么是上下文切换?(重点)守护线程和用户线程有什么区别呢?如何在Windows和Linux上查找哪个线程cpu利用率
- JAVA 多线程与高并发学习笔记(十三)——JUC显式锁
简单一点点
前面孩子生病了,一直照顾孩子。然后自己又感冒了,嗓子难受的要死。今天终于好多了。显式锁介绍JDK5引入了Lock接口,与内置加锁机制不同的是,Lock提供了一种无条件的、可轮询的、定时的以及可中断的锁获取操作,所有加锁和解锁的方法都是显式的。显式锁Lock接口Lock接口位于java.util.concurrent.locks包中,是JUC显式锁的一个抽象,主要抽象方法如下表。方法说明voidlo
- 多线程与高并发编程(一)
woaihuoguoooo
多线程与高并发编程(一)什么叫线程,进程,协程?一个程序启动起来叫做进程,可以理解为动态的程序,线程是一个进程的小弟,是cpu调度的基本单位,协程不是被操作系统内核所管理的,而是完全由程序所控制,也就是在用户态执行。性能大幅度的提升,因为不会像线程切换那样消耗资源。线程创建的几种方法通过继承Thread,重写run()方法classMyThreadextendsThread{@Overridepu
- java 多线程 安全 源码,纯干货,从源码解析多线程与高并发,再说不会,我再也不踏足IT圈...
李轶林
java多线程安全源码
没什么太多说的,多线程与高并发,面试重点,咱直接进入正题,联合底层源码,咱们从源码看一下,多线程与高并发底层的知识点,这也是阿里p8+的面试官建议的学习到的级别javaCASCompareAndSwap(CompareAndExchange)/自旋/自旋锁/无锁linux由于常常配合循环操做,直到完成为止,因此泛指一类操做gitcas(v,a,b),变量v,期待值a,修改值b面试ABA问题,你的女
- JAVA 多线程与高并发学习笔记(一)——线程创建
简单一点点
好久没写笔记了,重新回归Java,打好基础。Java进程中每一个线程都对应着一个Thread实例,其中保存着线程的描述信息。Thread类Java使用Thread类表示线程,首先看一个简单的示例。publicstaticvoidmain(String[]args)throwsInterruptedException{Threadthread=newThread();System.out.print
- J2SE II一一多线程与高并发编程的基础知识及运用(详解)
Help_II
前言几乎所有的程序员都知道,现代操作系统进行资源分配的最小单元是进程,而操作系统进行运算调度的最小单元是线程,其实,在Linux中线程也可以看作是一种轻量级的进程,那么线程是包含于进程之中的,是进程中实际的运作单位;同一进程中的多个线程共用同一块内存空间,而不同的线程又拥有独立的栈内存用以存放线程本地数据;大家都知道,现在的计算机动辄就是多处理器核心的,而每一个线程同一时间只能运行在一个处理器上,
- 多线程与高并发-volatile与CAS
我是流浪者
javajava
多线程与高并发-volatile与CAS1.volatile1.1volatile的作用1.2DCL单例模式1.3volatile与synchronized的区分2.CASABA问题ReentrantLockCountDownLatchCyclicBarrierPhaserReadWriteLockSemaphoreExchanger总结1.volatile我们来看一下这个小程序,写了一个方法啊,
- Java多线程与高并发(三):对象的安全发布与共享策略
java高并发
面试官:你知道如何发布或共享一个对象吗?发布对象:使一个对象能够被其他线程、其他作用域的代码所使用。变量逸出原有作用域importjava.util.Arrays;publicclassMain{privateString[]strs={"1","2","3"};publicString[]getStrs(){returnstrs;}publicstaticvoidmain(String[]arg
- 3万5千字70+道大厂Java经典面试题【金三银四(金九银十)面试小抄之Java经典多线程与高并发篇总结】(附答案)
硕风和炜
面试小抄多线程与高并发java面试多线程高并发锁
作者简介:硕风和炜,CSDN-Java领域新星创作者,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享座右铭:人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?关注我,私信回复面试题,获取《3万5千字70+道大厂多线程与高并发面试题【金三银四(金九银十)面试小抄之Java经典多线程与高并发篇总结】(附答案)》pdf目录一.前言二.J
- 高并发、多线程、分布式都不懂,你拿什么跳槽阿里、腾讯、京东?
小课VIP
Java多线程与高并发实战实践先来看看高并发多线程一些大厂并发面试题,看你能答出几道!(1)synchronized的CPU原语级别是如何实现的?(2)无锁、偏向锁、轻量级锁、重量级锁有什么差别,升级过程如何?(3)线程间通信,同机器进程间通信,跨机器进程间通信,各有什么方法?(4)下列三种业务,应该如何使用线程池:高并发、任务执行时间短的业务并发不高、任务执行时间长的业务并发高、业务执行时间长的
- 2022年阿里核心版Java面试八股文合集+各大厂面试真题
「已注销」
java面试jvm
疫情当下、裁员浪潮,焦虑和不安充斥着这个金九银十。为了能让大家有更好的面试资料去面试大厂的技术岗位,花费了2个多月的时间,把市面上的所有的Java面试题,做了一个归纳本文档是从阿里面试官整理的Java面试题其包含的内容模块有:基础、JVM、多线程与高并发、Spring、MyBatis、SpringBoot、MYSQL、SpringCloud、Dubbo、Nginx、MQ、数据结构与算法、Linux
- 自旋锁和互斥锁实例_JUC多线程与高并发面试题——公平锁/非公平锁/重入锁/递归锁/自旋锁...
你十分甜
自旋锁和互斥锁实例
一、公平锁和非公平锁1.1公平锁和非公平锁分别是什么公平锁:是指多个线程按照申请锁的顺序来获取锁,类似排队打饭,先来后到。非公平锁:是指多个线程获取锁的顺序并不是按照申请锁的顺序,有可能后申请的线程比先申请的线程优先获取锁。在高并发的情况下,有可能会造成优先级反转或者饥饿现象。1.2区别并发包中ReentrantLock的创建可以指定构造函数的boolean类型来得到公平锁或非公平锁,默认是非公平
- 骨灰级扫地神僧出版的《多线程与高并发》,2020你值得拥有
Java互联网进阶架构师
某粉丝年前参加某个NB企业的面试题列表:1.聊聊synchronized的CPU原语级别实现2.有一千万个数,写一个程序进行高效求和3.已知2开平方为1.414,如何不用数学库,求开平方的值,精确到小数点儿后面10位4.编码实现两个线程,线程A不断打印1-10的数字,要求在打印到第五个数字的时候通知线程B5.自定义线程池需要指定哪7个参数,为什么不建议使用JUC内置线程池?6.高并发、任务执行时间
- 马士兵《多线程与高并发》电子版,附笔记+代码+最新大厂面试真题
小宁学JAVA
如何获得高并发经验?-年能够涨薪5W?来看看清华架构师马兵老师全网最底层的多线程与高并发训练营,本次训练营的内容基本都是最新。限时福利,全网最底层的多线程与高并发内容,-年让你轻轻松松涨薪!!训练营第一天:线程的本质(操作系统与CPU是如何执行线程的)纤程的本质(go语言纤程为什么和线程池有关)并发的本质是什么?锁的本质是什么?synchronized关键字的字节码原语无锁、偏向锁、轻量级锁、重量
- 多线程与高并发
果粒多
1024程序员节
1.线程创建的3种方式2.线程的状态切换步骤3.线程的5中状态Java中的线程的生命周期大体可分为5种状态。1.新建(NEW):新创建了一个线程对象。2.可运行(RUNNABLE):线程对象创建后,其他线程(比如main线程)调用了该对象的start()方法。该状态的线程位于可运行线程池中,等待被线程调度选中,获取cpu的使用权。3.运行(RUNNING):可运行状态(runnable)的线程获得
- 多线程与高并发
6596dfcf0778
1.synchronized四种状态以及锁升级过程无锁->偏向锁->轻量级锁(cas)->重量级锁当只有一个线程进行加锁的时候,默认会使用偏向锁一旦有线程竞争就会升级成轻量级锁(未获得锁的线程会通过自旋等待获取锁,占用cpu资源)默认自旋超过10次还未获取锁会升级为重量级锁2.synchronized和ReentrantLock区别synchronized使用的是锁升级的方式加锁,Reentran
- 多线程与高并发(一):正确使用Thread
SteveLaw1124
1.创建一个线程Threadt=newThread(()->{System.out.println("runbythread")})这里使用了Lambda表达式,等同于Threadt2=newThread(newRunnable(){@Overridepublicvoidrun(){System.out.println("runinthread");}});2.使用t.start();t.run(
- JAVA 多线程与高并发学习笔记(十七)——异步回调
简单一点点
异步回调模式是高并发下的核心模式,本部分对异步回调进行详细介绍。泡茶案例本部分从一个很好理解的异步生活示例-泡茶开始。为了异步执行泡茶流程,分别涉及三个线程:泡茶线程(主线程)、烧水线程和清洗线程。泡茶线程的工作是:启动清洗线程、启动烧水线程,等清洗、烧水的工作完成后,泡茶喝;清洗线程的工作是:洗茶壶、洗茶杯;烧水线程的工作是:洗好水壶、灌上凉水,放在火上,一直等水烧开。下面分别使用阻塞模式、回调
- 312个免费高速HTTP代理IP(能隐藏自己真实IP地址)
yangshangchuan
高速免费superwordHTTP代理
124.88.67.20:843
190.36.223.93:8080
117.147.221.38:8123
122.228.92.103:3128
183.247.211.159:8123
124.88.67.35:81
112.18.51.167:8123
218.28.96.39:3128
49.94.160.198:3128
183.20
- pull解析和json编码
百合不是茶
androidpull解析json
n.json文件:
[{name:java,lan:c++,age:17},{name:android,lan:java,age:8}]
pull.xml文件
<?xml version="1.0" encoding="utf-8"?>
<stu>
<name>java
- [能源与矿产]石油与地球生态系统
comsci
能源
按照苏联的科学界的说法,石油并非是远古的生物残骸的演变产物,而是一种可以由某些特殊地质结构和物理条件生产出来的东西,也就是说,石油是可以自增长的....
那么我们做一个猜想: 石油好像是地球的体液,我们地球具有自动产生石油的某种机制,只要我们不过量开采石油,并保护好
- 类与对象浅谈
沐刃青蛟
java基础
类,字面理解,便是同一种事物的总称,比如人类,是对世界上所有人的一个总称。而对象,便是类的具体化,实例化,是一个具体事物,比如张飞这个人,就是人类的一个对象。但要注意的是:张飞这个人是对象,而不是张飞,张飞只是他这个人的名字,是他的属性而已。而一个类中包含了属性和方法这两兄弟,他们分别用来描述对象的行为和性质(感觉应该是
- 新站开始被收录后,我们应该做什么?
IT独行者
PHPseo
新站开始被收录后,我们应该做什么?
百度终于开始收录自己的网站了,作为站长,你是不是觉得那一刻很有成就感呢,同时,你是不是又很茫然,不知道下一步该做什么了?至少我当初就是这样,在这里和大家一份分享一下新站收录后,我们要做哪些工作。
至于如何让百度快速收录自己的网站,可以参考我之前的帖子《新站让百
- oracle 连接碰到的问题
文强chu
oracle
Unable to find a java Virtual Machine--安装64位版Oracle11gR2后无法启动SQLDeveloper的解决方案
作者:草根IT网 来源:未知 人气:813标签:
导读:安装64位版Oracle11gR2后发现启动SQLDeveloper时弹出配置java.exe的路径,找到Oracle自带java.exe后产生的路径“C:\app\用户名\prod
- Swing中按ctrl键同时移动鼠标拖动组件(类中多借口共享同一数据)
小桔子
java继承swing接口监听
都知道java中类只能单继承,但可以实现多个接口,但我发现实现多个接口之后,多个接口却不能共享同一个数据,应用开发中想实现:当用户按着ctrl键时,可以用鼠标点击拖动组件,比如说文本框。
编写一个监听实现KeyListener,NouseListener,MouseMotionListener三个接口,重写方法。定义一个全局变量boolea
- linux常用的命令
aichenglong
linux常用命令
1 startx切换到图形化界面
2 man命令:查看帮助信息
man 需要查看的命令,man命令提供了大量的帮助信息,一般可以分成4个部分
name:对命令的简单说明
synopsis:命令的使用格式说明
description:命令的详细说明信息
options:命令的各项说明
3 date:显示时间
语法:date [OPTION]... [+FORMAT]
- eclipse内存优化
AILIKES
javaeclipsejvmjdk
一 基本说明 在JVM中,总体上分2块内存区,默认空余堆内存小于 40%时,JVM就会增大堆直到-Xmx的最大限制;空余堆内存大于70%时,JVM会减少堆直到-Xms的最小限制。 1)堆内存(Heap memory):堆是运行时数据区域,所有类实例和数组的内存均从此处分配,是Java代码可及的内存,是留给开发人
- 关键字的使用探讨
百合不是茶
关键字
//关键字的使用探讨/*访问关键词private 只能在本类中访问public 只能在本工程中访问protected 只能在包中和子类中访问默认的 只能在包中访问*//*final 类 方法 变量 final 类 不能被继承 final 方法 不能被子类覆盖,但可以继承 final 变量 只能有一次赋值,赋值后不能改变 final 不能用来修饰构造方法*///this()
- JS中定义对象的几种方式
bijian1013
js
1. 基于已有对象扩充其对象和方法(只适合于临时的生成一个对象):
<html>
<head>
<title>基于已有对象扩充其对象和方法(只适合于临时的生成一个对象)</title>
</head>
<script>
var obj = new Object();
- 表驱动法实例
bijian1013
java表驱动法TDD
获得月的天数是典型的直接访问驱动表方式的实例,下面我们来展示一下:
MonthDaysTest.java
package com.study.test;
import org.junit.Assert;
import org.junit.Test;
import com.study.MonthDays;
public class MonthDaysTest {
@T
- LInux启停重启常用服务器的脚本
bit1129
linux
启动,停止和重启常用服务器的Bash脚本,对于每个服务器,需要根据实际的安装路径做相应的修改
#! /bin/bash
Servers=(Apache2, Nginx, Resin, Tomcat, Couchbase, SVN, ActiveMQ, Mongo);
Ops=(Start, Stop, Restart);
currentDir=$(pwd);
echo
- 【HBase六】REST操作HBase
bit1129
hbase
HBase提供了REST风格的服务方便查看HBase集群的信息,以及执行增删改查操作
1. 启动和停止HBase REST 服务 1.1 启动REST服务
前台启动(默认端口号8080)
[hadoop@hadoop bin]$ ./hbase rest start
后台启动
hbase-daemon.sh start rest
启动时指定
- 大话zabbix 3.0设计假设
ronin47
What’s new in Zabbix 2.0?
去年开始使用Zabbix的时候,是1.8.X的版本,今年Zabbix已经跨入了2.0的时代。看了2.0的release notes,和performance相关的有下面几个:
:: Performance improvements::Trigger related da
- http错误码大全
byalias
http协议javaweb
响应码由三位十进制数字组成,它们出现在由HTTP服务器发送的响应的第一行。
响应码分五种类型,由它们的第一位数字表示:
1)1xx:信息,请求收到,继续处理
2)2xx:成功,行为被成功地接受、理解和采纳
3)3xx:重定向,为了完成请求,必须进一步执行的动作
4)4xx:客户端错误,请求包含语法错误或者请求无法实现
5)5xx:服务器错误,服务器不能实现一种明显无效的请求
- J2EE设计模式-Intercepting Filter
bylijinnan
java设计模式数据结构
Intercepting Filter类似于职责链模式
有两种实现
其中一种是Filter之间没有联系,全部Filter都存放在FilterChain中,由FilterChain来有序或无序地把把所有Filter调用一遍。没有用到链表这种数据结构。示例如下:
package com.ljn.filter.custom;
import java.util.ArrayList;
- 修改jboss端口
chicony
jboss
修改jboss端口
%JBOSS_HOME%\server\{服务实例名}\conf\bindingservice.beans\META-INF\bindings-jboss-beans.xml
中找到
<!-- The ports-default bindings are obtained by taking the base bindin
- c++ 用类模版实现数组类
CrazyMizzz
C++
最近c++学到数组类,写了代码将他实现,基本具有vector类的功能
#include<iostream>
#include<string>
#include<cassert>
using namespace std;
template<class T>
class Array
{
public:
//构造函数
- hadoop dfs.datanode.du.reserved 预留空间配置方法
daizj
hadoop预留空间
对于datanode配置预留空间的方法 为:在hdfs-site.xml添加如下配置
<property>
<name>dfs.datanode.du.reserved</name>
<value>10737418240</value>
 
- mysql远程访问的设置
dcj3sjt126com
mysql防火墙
第一步: 激活网络设置 你需要编辑mysql配置文件my.cnf. 通常状况,my.cnf放置于在以下目录: /etc/mysql/my.cnf (Debian linux) /etc/my.cnf (Red Hat Linux/Fedora Linux) /var/db/mysql/my.cnf (FreeBSD) 然后用vi编辑my.cnf,修改内容从以下行: [mysqld] 你所需要: 1
- ios 使用特定的popToViewController返回到相应的Controller
dcj3sjt126com
controller
1、取navigationCtroller中的Controllers
NSArray * ctrlArray = self.navigationController.viewControllers;
2、取出后,执行,
[self.navigationController popToViewController:[ctrlArray objectAtIndex:0] animated:YES
- Linux正则表达式和通配符的区别
eksliang
正则表达式通配符和正则表达式的区别通配符
转载请出自出处:http://eksliang.iteye.com/blog/1976579
首先得明白二者是截然不同的
通配符只能用在shell命令中,用来处理字符串的的匹配。
判断一个命令是否为bash shell(linux 默认的shell)的内置命令
type -t commad
返回结果含义
file 表示为外部命令
alias 表示该
- Ubuntu Mysql Install and CONF
gengzg
Install
http://www.navicat.com.cn/download/navicat-for-mysql
Step1: 下载Navicat ,网址:http://www.navicat.com/en/download/download.html
Step2:进入下载目录,解压压缩包:tar -zxvf navicat11_mysql_en.tar.gz
- 批处理,删除文件bat
huqiji
windowsdos
@echo off
::演示:删除指定路径下指定天数之前(以文件名中包含的日期字符串为准)的文件。
::如果演示结果无误,把del前面的echo去掉,即可实现真正删除。
::本例假设文件名中包含的日期字符串(比如:bak-2009-12-25.log)
rem 指定待删除文件的存放路径
set SrcDir=C:/Test/BatHome
rem 指定天数
set DaysAgo=1
- 跨浏览器兼容的HTML5视频音频播放器
天梯梦
html5
HTML5的video和audio标签是用来在网页中加入视频和音频的标签,在支持html5的浏览器中不需要预先加载Adobe Flash浏览器插件就能轻松快速的播放视频和音频文件。而html5media.js可以在不支持html5的浏览器上使video和audio标签生效。 How to enable <video> and <audio> tags in
- Bundle自定义数据传递
hm4123660
androidSerializable自定义数据传递BundleParcelable
我们都知道Bundle可能过put****()方法添加各种基本类型的数据,Intent也可以通过putExtras(Bundle)将数据添加进去,然后通过startActivity()跳到下一下Activity的时候就把数据也传到下一个Activity了。如传递一个字符串到下一个Activity
把数据放到Intent
- C#:异步编程和线程的使用(.NET 4.5 )
powertoolsteam
.net线程C#异步编程
异步编程和线程处理是并发或并行编程非常重要的功能特征。为了实现异步编程,可使用线程也可以不用。将异步与线程同时讲,将有助于我们更好的理解它们的特征。
本文中涉及关键知识点
1. 异步编程
2. 线程的使用
3. 基于任务的异步模式
4. 并行编程
5. 总结
异步编程
什么是异步操作?异步操作是指某些操作能够独立运行,不依赖主流程或主其他处理流程。通常情况下,C#程序
- spark 查看 job history 日志
Stark_Summer
日志sparkhistoryjob
SPARK_HOME/conf 下:
spark-defaults.conf 增加如下内容
spark.eventLog.enabled true spark.eventLog.dir hdfs://master:8020/var/log/spark spark.eventLog.compress true
spark-env.sh 增加如下内容
export SP
- SSH框架搭建
wangxiukai2015eye
springHibernatestruts
MyEclipse搭建SSH框架 Struts Spring Hibernate
1、new一个web project。
2、右键项目,为项目添加Struts支持。
选择Struts2 Core Libraries -<MyEclipes-Library>
点击Finish。src目录下多了struts