在看 JDK 源码 HashMap 时发现在 put 方法实现过程中使用了下面的语句
if ((tab = table) == null || (n = tab.length) == 0)
n = (tab = resize()).length;
能够看到在判断语句中使用了赋值语句的结果来和 null 和 0 比较,再比如读写文件时会有
while ((line = reader.readLine()) != null) {
out.append(line);
}
就能发现 Java 中的赋值语句是有返回值的,并且也不是简单的 boolean 。事实上赋值语句返回的是左侧变量的引用值,也就是右侧的结果。
@Test
public void testAssignment() {
int i;
System.out.println(i=0);
System.out.println(i=1);
}
输出分别是 0 和 1.
学车到现在已经接近尾声,拖了两年之久的事情终于要有点眉目了。现在只剩下最后的理论—-科目四的考试了,这个考试应该也和科目一的理论差不多,只是最后多了五道多选题而已。现在回想起来,暑假,寒假,寒假,多少时间花在这个上面。断断续续不知道是福还是祸,考试从人监考一直到现在红外线考,变化多多,训练的方法也变化多多。
之前一个寒假我记得当时考试,倒桩和小路考是分开考的,而今年寒假回来就变成一起考了。以前小路考还考单边桥,而现在不见了。以前小路考是一次性,如果通过就通过,现在是有两次机会,第一次不过还有第二次机会。总之里面的变化任谁也搞不清楚。反正这些也不管了,都是过去的事情了。
下面就做一些记录,这是我一边学车,一边记录下来的:
##小路考 上车,安全带(安全带不能带反,因为车上有感应装置,如果安装反了感应不到就是不及格) 起步(不能停顿超过30秒),左方向灯 侧方停车位,开车到看到左边后视镜看见库一角,一圈方向,倒档,车身与库对角线齐平,返回一圈方向,看右后轮胎,快进库时,反方向打死方向盘,进库,出来时方向灯 s路,直着进弯道,看黄线到车头三分之一处一圈方向,车走正了,返回一圈方向,然后 坡上定点停车与坡道起步,车尽量往右边靠30cm,车头要在停止范围内,起步方向灯 直角转弯,反光镜到黄线齐平,打死方向 倒车入库,到黄线打死方向,看左反光镜,车声0.5米,返回半圈方向,看车身与黄线平行,将方向放正
##大路考
上车,安全带,座椅,踩离合,空档发动,大车灯,方向灯切换一下(后来分完车,车上教练教了一个好办法:上车1.空档 2.发动 3.大灯 4.方向 下车1.方向 2.大灯 3.熄火 4.挂一档,正好完全相反) 报告考官,灯光仪器正常,请求起步 方向灯,远近大灯,左右反光镜,挂一档,松离合,松手刹。 挂二档 靠边停车,转向灯,减速 下车,右转向,空档,手刹,关大灯,关方向,熄火,挂一档,松安全带,看反光镜,后面车,下车
总之上面就是这些天反复练习的东西,就这么多。考试也就这么多。
直接上官网
在 vim 配置文件
Plug 'godlygeek/tabular'
Plug 'plasticboy/vim-markdown'
安装插件之后会自动高亮语法。该插件有很多配置选项,建议 :help vim-markdown
而我个人比较常用的一些功能是打开文档中链接,将光标放到链接的任何位置使用如下命令
gx
打开 markdown 中相对链接进行编辑
ge
跳转到下一个标题
]]
同理跳转到上一个标题
[[
上面两个方法不管标题的级别都会直接跳转,如果只想要在同一级别的标题中跳转可以使用
[] # 前一个
][ # 后一个
跳转到当前标题
]c
跳转到父标题
]u
增加或者减少标题级别
:HeaderDecrease
:HeaderIncrease
显示 Toc(Table of Content) 目录:
:Toc
:Toch " 水平打开 horizontal
:Tocv " 垂直窗口打开 vertical
:Toct " 新 tab 中打开
格式化表格
:TableFormat
" disable folding
let g:vim_markdown_folding_disabled=1
" Highlight YAML frontmatter as used by Jekyll
let g:vim_markdown_frontmatter=1
:help vim-markdown
之前东拼西凑写了一篇《投影仪选购指南》,今天再凑一篇配套接口知识。纯为自己了解,当然如果帮到其他人,那就更好了。先来随便看看一款投影仪的最简单的接口。
从左到右接口依次为:音频接口,S 端子,VGA 接口,HDMI,RS232,USB
从左到右依次是 HDMI×2,色差分量接口 Component,MINI USB B 型,VAG,RS-232,S- 端子,AV 复合视频接口(RCA),音频输入输出接口
然后看看平面解释的图
以下涉及到的接口可能有些在投影仪里面有,而有些投影仪不一定是要具备的,必备是对于电视来说的。
HDMI 是新一代的多媒体接口标准,全称是 High-Definition Multimedia Interface,中文意思为高清晰多媒体接口,该标准由索尼、日立、松下、飞利浦、东芝、Silicon image、Thomson (RCA) 等 7 家公司在 2002 年 4 月开始发起的。其产生是为了取代传统的 DVD 碟机、电视及其它视频输出设备的已有接口,统一并简化用户终端接线,并提供更高带宽的数据传输速度和数字化无损传送音视频信号。
传统的 AV 复合和色差接口都需要独立分开音频和视频数据线来传输信号,同为数字接口的 DVI 接口则并不支持音频传输,目前唯有 HDMI 具备了在一条数据线上同时传送影音信号的能力,因此人们也习惯把 HDMI 称为高清一线通。
DVI(Digital Visual Interface)接口,即数字视频接口。DVI 接口标准是 1999 年由 Silicon Image、Intel(英特尔)、Compaq(康柏)、IBM、HP(惠普)、NEC、Fujitsu(富士通)等公司共同组成 DDWG(Digital Display Working Group,数字显示工作组)推出的接口标准。
DVI 接口是以 Silicon Image 公司的 PanalLink 接口技术为基础,基于 TMDS(Transition Minimized Differential Signaling,最小化传输差分信号)电子协议作为基本电气连接。TMDS 是一种微分信号机制,可以将象素数据编码,并通过串行连接传递。显卡产生的数字信号由发送器按照 TMDS 协议编码后通过 TMDS 通道发送给接收器,经过解码送给数字显示设备。
DVI 转 HDMI 视频连接线
目前常见的 DVI 接口有两种,分别是 DVI-Digital(DVI-D)与 DVI-Integrated(DVI-I),DVI-D 仅支持数字信号,而 DVI-I 则不仅支持数字信号,还可以支持模拟信号,也就是说DVI-I的兼容性更强。 DVI-I 插口是兼容数字和模拟接头的,所以,DVI-I 的插口就有 24 个数字插针+5 个模拟插针的插孔(就是旁边那个四针孔和一个十字花)。
DVI-D 插口是纯数字的接口,所以,DVI-D 的插口只有 24 个数字插针的插孔(没有模拟的那个四针孔和一个十字花)。
因此,DVI-I 的插口可以插 DVI-I 和 DVI-D 接头的线,而 DVI-D 的插口只能接 DVI-D 的纯数字线。
色差分量接口 Component
色差分量线材
色差分量(Component)接口采用 YPbPr 和 YCbCr 两种标识,前者表示逐行扫描色差输出,后者表示隔行扫描色差输出。色差分量接口一般利用 3 根信号线分别传送亮色和两路色差信号。这 3 组信号分别是:亮度以 Y 标注,以及从三原色信号中的两种——蓝色和红色——去掉亮度信号后的色彩差异信号,分别标注为 Pb 和 Pr,或者 Cb 和 Cr,在三条线的接头处分别用绿、蓝、红色进行区别。这三条线如果相互之间插错了,可能会显示不出画面,或者显示出奇怪的色彩来。色差分量接口是模拟接口,支持传送 480i/480p/576p/720p/1080i/1080p 等格式的视频信号,本身不传输音频信号。
复合视频接口
复合视频线
AV 复合(Composite)视频接口是目前在视听产品中应用得最广泛的接口,属模拟接口,该接口由黄、白、红 3 路 RCA 接头组成,黄色接头传输视频信号,白色接头传输左声道音频信号,红色接头传输右声道音频信号。AV 复合视频接口实现了音频和视频的分离传输,这就避免了因为音 / 视频混合干扰而导致的图像质量下降,但由于 AV 接口的传输仍然是一种亮度 / 色度 (Y/C) 混合的视频信号,仍然需要显示设备对其进行亮 / 色分离和色度解码才能成像,这种先混合再分离的过程必然会造成色彩信号的损失,色度信号和亮度信号也会有很大的机会相互干扰从而影响最终输出的图像质量。
RF 射频端子是最早在电视机上出现的,原意为无线电射频(Radio Frequency)。它是目前家庭有线电视采用的接口模式。
RF 的成像原理是将视频信号 (CVBS) 和音频信号 (Audio) 相混合编码后,输出然后在显示设备内部进行一系列分离 / 解码的过程输出成像。
由于步骤繁琐且音视频混合编码会互相干扰,所以它的输出质量也是最差的。带此类接口的显卡只需把有线电视信号线连接上,就能将有线电视的信号输入到显卡内。
光纤音频接口 TosLink,全名 Toshiba Link,这是日本东芝(TOSHIBA)公司较早开发并设定的技术标准,在视听器材的背板上有 Optical 作标识。现在几乎所有的数字影音设备都具备这种格式的接头。TosLink 光纤曾大量应用在普通的中低档 CD、LD、MD、DVD 机及组合音响上。光纤连接可以实现电气隔离,阻止数字噪音通过地线传输,有利于提高 DAC 的信噪比。但是,时基误差是影响音质的重要因素,所以衡量数字音响设备传输接口性能的好坏,应以引起时基误差的大小为标准。光纤连接的信号要经过发射器和接收器的两次转换,会产生严重影响音质的时基抖动误差(Jitter)。制造光纤常用的材料有塑料、石英、玻璃等,玻璃光纤(ST)是最昂贵的一种。
RS-232C 标准最初是远程通信连接数据终端设备 DTE(Data Terminal Equipment) 与数据通信设备 DCE(Data Communication Equipment) 而制定的。RS-232C 标准(协定)的全称是 EIA-RS-232C 标准,其中 EIA(Electronic Industry Association) 代表美国电子工业协会,RS(Recommeded Standard)代表推荐标准,232 是标识号,C 代表 RS232 的最新一次修改(1969),在这之前有 RS-232B 和 RS-232A。它规定连接电缆和机械、电气特性、信号功能及传送过程。RS-232C 接口最大传输速率为 20Kbps,线缆最长为 15 米。RS-232C 接口通常被用于将电脑信号输入控制,当通信距离较近时,可不需要 Modem,通信双方可以直接连接,这种情况下,只需使用少数几根信号线。
VGA(Video Graphic Array)接口,即视频图形阵列,也叫 D-Sub 接口,是 15 针的梯形插头,分成 3 排,每排 5 个,传输模拟信号。VGA 接口采用非对称分布的 15 针连接方式,其工作原理:是将显存内以数字格式存储的图像(帧)信号在 RAMDAC 里经过模拟调制成模拟高频信号,然后再输出到显示设备成像。
VGA 支持在 640×480 的较高分辨率下同时显示 16 种色彩或 256 种灰度,同时在 320×240 分辨率下可以同时显示 256 种颜色。VGA 由于良好的性能迅速开始流行,厂商们纷纷在 VGA 基础上加以扩充,如将显存提高至 1M 并使其支持更高分辨率如 SVGA(800×600)或 XGA(1024×768),这些扩充的模式就称之为视频电子标准协会 VESA(Video Electronics Standards Association) 的 SVGA(Super VGA)模式,现在显卡和显示设备基本上都支持 SVGA 模式。
此外后来还有扩展的 SXGA(1280×1024)、SXGA+(1400×1050)、UXGA(1600×1200)、WXGA(1280×768)、WXGA+(1440×900)、WSXGA(1600×1024)、WSXGA+(1680×1050)、WUXGA(1920×1200)、WQXGA(2560×1600)等模式,这些符合 VESA 标准的分辨率信号都可以通过 VGA 接口实现传输。
S 端子,即分离式影像端子 S-video(Separate Video),它实际上是一种五芯接口,由视频亮度讯号 Y 和视频色度讯号 C 和一路公共遮罩地线组成。S 端子将亮度和色度分离输出,避免了混合视频讯号输出时亮度和色度的相互干扰,它只能输入输出视频。
Universal Serial Bus(通用串行总线)简称 USB,是目前电脑、数码、平板电视等产品上光方应用的一种接口规范。USB 接口是一种四针接口,其中中间两个针传输数据,两边两个针给外设供电。USB 有两个规范,即 USB 1.1 和 USB 2.0。二者主要的却别是 USB 1.1 的最高传输速度是 12Mbps(折算为 MB 为 1.5MB/s);USB2.0 标准传输速率在 25Mbps-400 Mbps (最大 480 Mbps,折算为 MB 为 60MB/s),二者相差最高 40 倍。同时,USB1.1 版本接口对外的输出电源的负载能力很低,其最大输出电流只有 250 毫安,而 USB2.0 协议,其输出电流达到 500 毫安以上。USB1.1 接口和 USB2.0 接口相比,USB2.0 接口具有明显的优势,但产品价格相对也要比 USB1.1 接口的产品贵一些,2003 年以后 1.1 版本逐渐被 2.0 版
USB(通用串行总线)将网络、计算机和家庭数码产品的媒体资源进行共享,是 3C 融合的一个趋势。具有流媒体功能的电视实现了让 MP3、摄像机、照相机、移动硬盘、U 盘以及各种各样存储卡的内容在电视机上直接播放,做到信息共享。流媒体电视与普通电视相比,最大的不同在于后者仅能收看电视节目,节目内容固定的,而流媒体电视不仅可以收看更清晰的电视节目,还可以播放数码相机、移动硬盘等数码设备里的图片、音乐、电影,使原来只能在电脑上播放的内容可以在更大、更清晰的平板电视上观看,让全家人共同欣赏。而流媒体这些美妙功能的实现必须依仗 作为中间媒介的“USB”接口。
目前市场销售的平板电视还有部分产品依然为了降低成本采用低速的 USB1.1 接口作为流媒体接口,而这个接口根本不能满足海量流媒体设备的供电和传输需要。目前家用数码设备,例如 MP3 已经向 G 容量过渡,数码相机也已经开始千万像素的换代,大容量的流媒体文件必须依靠可靠的高速接口才能流畅演示,因此购买流媒体电视,一定要先确定是否采用了 USB2.0 高速接口本所替代。
蓝牙(Bluetooth)是由东芝、爱立信、IBM、Intel 和诺基亚于 1998 年 5 月共同提出的近距离无线数据通讯技术标准。它能够在 10 米的半径范围内实现单点对多点的无线数据和声音传输,其数据传输带宽可达 1Mbps。通讯介质为频率在 2.402GHz 到 2.480GHz 之间的电磁波。
蓝牙接口(BlueTooth)与其它同样具有蓝牙接口的设备连接同样可以实现无线连接,它具有无方向性限制,有效连接距离达 10 米,一般的传输速度都有 1M,快速的高达 10M 甚至更快等优点,但目前配置蓝牙接口的电子设备却不是很多,与红外线接口的普及率有很大的差距,这是比较遗憾的一个地方。
不过,没有蓝牙接口的电脑可通过加装蓝牙适配器来实现蓝牙接口功能,这些蓝牙适配器一般都是 USB 接口的,可以插在电脑的 USB 接口上使用,而且只有闪盘大小,携带远比数据线要方便。
高带宽 在高清晰视频即将流行之际,没有高带宽的显示接口是无法立足的。DisplayPort 问世之初,它可提供的带宽就高达 10.8Gb/s。要知道,HDMI 1.2a 的带宽仅为 4.95Gb/s,即便最新发布的 HDMI 1.3 所提供的带宽 (10.2Gb/s) 也稍逊于 DisplayPort 1.0。DisplayPort 可支持 WQXGA+(2560×1600)、QXGA(2048×1536) 等分辨率及 30/36bit(每原色 10/12bit) 的色深,充足的带宽保证了今后大尺寸显示设备对更高分辨率的需求。
最大程度整合周边设备 和 HDMI 一样,DisplayPort 也允许音频与视频信号共用一条线缆传输,支持多种高质量数字音频。但比 HDMI 更先进的是,DisplayPort 在一条线缆上还可实现更多的功能。在四条主传输通道之外,DisplayPort 还提供了一条功能强大的辅助通道。该辅助通道的传输带宽为 1Mbps,最高延迟仅为 500μs,可以直接作为语音、视频等低带宽数据的传输通道,另外也可用于无延迟的游戏控制。可见,DisplayPort 可以实现对周边设备最大程度的整合、控制。
内外接口通吃
目前 DisplayPort 的外接型接头有两种:一种是标准型,类似 USB、HDMI 等接头;另一种是低矮型,主要针对连接面积有限的应用,比如超薄笔记型电脑。两种接头的最长外接距离都可以达到 15 米,虽然这个距离比 HDMI 要逊色一些,不过接头和接线的相关规格已为日后升级做好了准备,即便未来 DisplayPort 采用新的 2X 速率标准 (21.6Gbps),接头和接线也不必重新进行设计。
除实现设备与设备之间的连接外,DisplayPort 还可用作设备内部的接口,甚至是芯片与芯片之间的数据接口。比如,DisplayPort 就“图谋”取代 LCD 中液晶面板与驱动电路板之间主流接口——LVDS(Low Voltage Differential Signaling,低压差分信号)接口的位置。DisplayPort 的内接型接头仅有 26.3mm 宽、1.1mm 高,比 LVDS 接口小 30%,但传输率却是 LVDS 的 3.8 倍。
D 端子中的 D 即 Digital,也说是因为接口造型像倒置的“D”字母,其通过处理芯片将视频信号处理成符其传输标准的数码讯号,采用了类似电脑的多针 D 型插接头,通过数字方式传输视频信号,直接输入到具备 D 视频接收端子的视频显示设备,避免了通过模拟视频信号传输方式传输信号的过程中的数字 - 模拟的转换过程,因而更能提升数字视频还原质量。D 端子依据规格的不同,分为目前有 D1、D2、D3、D4、D5 几个级别,分别对应 480i/480p/1080i/720p/1080p 视频信号,其中 D5 最高。目前 D 端子接口基本上只出现在日本的视听设备中。
同轴音频接口(Coaxial),标准为 SPDIF(Sony / Philips Digital InterFace),是由索尼公司与飞利浦公司联合制定的,在视听器材的背板上有 Coaxial 作标识,主要是提供数字音频信号的传输。它的接头分为 RCA 和 BNC 两种。数字同轴接口采用阻抗为 75Ω的同轴电缆为传输媒介,其优点是阻抗恒定,传输频带较宽,优质的同轴电缆频宽可达几百兆赫。同轴数字传输线标准接头采用 BNC 头,其阻抗是 75Ω,与 75Ω的同轴电缆配合,可保证阻抗恒定,确保信号传输正确。也就是说在传输的线材搭配上,应该是以适用于传输高频率数字讯号的 75 欧姆同轴线材作为搭配标准。
SCART(Syndicat des Constructeursd’ Appareils Radiorécepteurs et Téléviseurs)接口是一种专用的音视频接口,它是由法国公司 Peritel 开发的视听设备互连工业标准,也是欧洲强制要求用于卫星电视接收机、电视机、录像机及其它音视频设备上的互连互通接口。标准的 SCART 接口为 21 针连接器,外型呈直角梯形,俗称“扫把头”。这 21 针中定义了音频和视频信号,可用来传输 CVBS 和隔行 RGB 信号等视频信号,也可以传送立体声音频信号。21 针同时传输 21 个信号,这 21 个信号可分为视频信号、音频信号、控制信号、地线和数据线几种。此外,SCART 接口还是双向传输,实现所谓的“LOOP”循环功能。
###起由 这几天把倚天屠龙记电视剧看完了,不留下点什么觉得对不起自己. 大学这几年把能够补上的电影电视剧补的都差不多了. 这几天逛豆瓣,看到小李飞刀这部电视剧,想小时候没有看过,只有个大概的印象,于是就补起了小李飞刀,可古龙的剧真心让人看不下去. 看李寻欢太纠结了, 不过倒是看剧中天机老人和他孙女小红给小李飞刀这部增添了不少乐趣. 于是就去找了演员的资料, 没想到给我看到了贾静雯,也就是天机老人的孙女在倚天屠龙记中饰演了赵敏. 我想反正苏有朋版的倚天屠龙记我也没看全过, 也不妨看看.
于是这些天空闲下来就看起倚天屠龙记来, 金庸的小说我都看过, “飞雪连天射白鹿,笑书神侠倚碧鸳”十四部,忘记多少部长篇多少部短篇了, 只是知道那时候是从图书馆一部一部书借出来看的,即使是最短篇的«越女剑»也是看了的. 而这些金庸剧中大多数都曾改编成电影电视剧, 可能有的小说还有很多的版本, 更有甚者甚至改变了书中剧情,像最近的一部笑傲江湖, 我无法是无法接受的, 所以至今新版的那部笑傲江湖我一集都没看过. 我这些天看的倚天屠龙记应该还是和原著相差无几的, 看剧的过程中还能顺带回顾书中的剧情—-张无忌掉落山崖之后遇到的白猿;剧中救了丐帮帮主独女,屠狮英雄会击败周芷若的黄衫女子—-看到这些书中有些情节渐渐在记忆中变得清晰. 金庸小说的书看了有几年了, 现在恨当时根本没有做任何形式的记录, 虽然那时在看完全部小说后还看了很多评金庸的文章书籍,现在所剩下的已经没多少了. 所以我决定现在写下些什么做记录.
看完这部剧有几个情节让我久久不能忘怀,其一就是张无忌在四个女人之间的选择.曾有一段不悔和张无忌的对话,不悔问张无忌这几个女人如何选择,张无忌没有做出正面的回答,只是说对周芷若又敬有怕,对赵敏又爱又恨,而不悔对张无忌说的,要爱就不要犹豫,不要在几人之间犹犹豫豫, 或许这就是张无忌最后毅然选择赵敏的原因之一. [[爱情]]里面容不得犹豫. 赵敏对张无忌的爱, 自始至终, 终于可以感动张无忌. 终于张无忌可以在周芷若的逼问下高速她,他爱的是赵敏. 电视剧片尾曲,以赵敏的口吻:
让他一生为你画眉
让他的心宽容似海
再不提你曾给他伤害
你要他身边再没别的女孩
赵敏要求张无忌做的第三件事情就是画眉, 经过毛阿敏的演唱, 让我单曲循环了一阵子. 本来想写更多一点,可是真的不知道写些什么了.~
</embed>
Git 学习笔记 —- 从 git 移除文件而不删除硬盘中的文件,你可能遇到过不小心将一个不需要的文件,或者另外一个重要的包含私密配置的文件添加到了 git 版本库中,这个时候你想从版本库中将其删除,而又不想影响到本地的文件,这个时候就需要使用到本文中需要使用到的内容。
从版本库中移除一个文件,停止对该文件的版本控制
The git rm command will allows you to remove a file from git control. The –cached option to git remove allows you to leave it on your hard drive.
Every once in awhile a file gets checked into git that isn’t supposed to be there. Common examples are configuration files, project files generated by your IDE with personal settings and even the occasional object file that someone decided to check in. These files are needed, so often you can’t delete them entirely and the process of copying them somewhere else, removing them from git and then replacing is painful, not to mention prone to error.
By adding the –cached
option to the git rm
command, you are able to remote the file file from git control while keeping the file in your working tree. They command syntax is:
git rm --cached file
Git will no longer track this file even though it is still on your hard drive.
After running the above command, be sure to add an entry to your .gitignore
file so that ‘file’ doesn’t show up in 'git status'
and that it can’t accidentally be re-added later.
from : http://www.gitguys.com/how-to-remove-a-file-from-git-source-control-but-not-delete-it/
Git 学习笔记,主要用来记忆常用命令。
.git 目录下文件
$>tree -L 1
.
|-- HEAD # git 项目当前处在哪个分支里
|-- config # 项目的配置信息,git config 命令会改动它
|-- description # 项目的描述信息
|-- hooks/ # 系统默认钩子脚本目录
|-- index # 索引文件
|-- logs/ # 各个 refs 的历史信息
|-- objects/ # Git 本地仓库的所有对象 (commits, trees, blobs, tags)
|-- refs/ # 标识你项目里的每个分支指向了哪个提交 (commit)。
生成 SSH keys
ssh-keygen -t rsa -C "youremail@example.com"
一直回车,将自动生成id_rsa
和id_rsa.pub
文件。使用以下命令验证连接是否成功
ssh -T git@github.com
创建本地新 Git 仓库
git init
克隆远端仓库
git clone ssh://user@domain.com/repo.git
提交
修改上次提交 不要修改已经发布的提交记录
git commit --amend
创建签名提交
git commit -sm "commit msg"
撤销本地提交,上一次提交修改内容会添加到暂存区
git reset --soft HEAD~1
回退一个 commit 版本,就好像这个 commit 从来没有提交过
git reset HEAD^
git reset HEAD~1
强制撤销提交,commit-id 之后的提交都会被抛弃
git reset --hard <commit-id>
撤销之前提交的一个 commit, revert 命令会创建一个新的 commit
git revert HEAD
git revert commitid
一份优雅的 Commit message 可以方便后期查看,也方便快速定位更新的内容,通常来说在标题中用简介的一行来描述更改的内容,在描述中使用更多的细节来描述具体修改内容。
更多关于 Git message 的内容可以查看这里
替换本地改动
此命令会使用 HEAD 中的最新内容替换掉你的工作目录中的文件。已添加到暂存区的改动以及新文件都不会受到影响。
git checkout -- <filename>
分离 HEAD
一般 HEAD 都是隐藏在 master 后面,分离 HEAD 就是让其指向一个提交而不是分支名。使用以下命令可以分离 HEAD。
git checkout commitID
将本地修改发布到远端
git push <remote> <local-branch>
强制推送本地版本到远端库
如果想要删除远端仓库不小心提交的 commit,可以使用这条命令,远端仓库之后的 commit 会被抹去
git push origin HEAD --force
git push -f origin master # 将本地 master 分支强行推送到远端并覆盖远端修改内容
推送到镜像 repo
例如本地关联的远端仓库是 gitlab 的,可以使用--mirror
参数将本地库提交到 github
git push --mirror https://github.com/einverne/dotfiles.git
删除远端分支 delete remote branch 以下命令二选一,个人推荐使用第二种,因为简单方便嘛:
git push origin --delete <branchname>
git push origin :<branch name>
分支相关命令
查看远端和本地分支
git branch -a, -all
新建分支
git branch <new-branch-name>
切换到已经存在的分支
git checkout <branchname>
创建分支并切换到该分支
git checkout -b <branchname>
切换到 master 分支,合并分支
合并不一定完全成功,可能遇到冲突
git merge <branchname>
删除本地分支
git branch -d <branchname>
强制删除未合并的分支
git branch -D <branchname>
重命名分支,重命名 old-name 到 new-name,如果 new-name 存在,命令失败
git branch -m old-name new-name
创建新的空分支
create a New and Empty branch , without any commit. And use git rm -rf .
to delete all files in the new working directory. You need to run git version 1.7.2 or higher in order for the –orphan option to be supported.
git checkout --orphan <branch name>
添加远端仓库
Git 将本地 master 分支内容推动到远程新的 master 分支,并且将本地 master 分支与远程 master 分支关联
git remote add <name> <url>
git remote add origin https://github.com/einverne/xxx.git
git remote add origin git@github.com:einverne/xxx.git
将本地分支推送到远端仓库
git push <remote name> <local-branch-name>
git push -u origin master
显示远端仓库地址
git remote -v
删除远端仓库
git remote rm <name>
设置远端仓库地址,修改远端仓库地址
git remote set-url origin git@github.com:einverne/repo.git
给已存在 origin 远端添加 URL
如果远端 origin 存在多个 url,使用 git push origin master
可同时将本地库推送到多个远端仓库。
git remote set-url --add origin https://github.com/einverne/dotfiles.git
显示远端信息
git remote show origin
下载远端所有改动到本地,不自动合并到当前
git fetch <remote>
更新与合并,更新本地仓库至最新改动
git pull
打标签
创建标签
创建 <tagname>
的标签,9fceb02 为 commit id,使用git log
可以查看提交的 ID,一般可以选用前 10 位,如果唯一也可少选
git tag -a <tagname> [9fceb02]
显示标签
git show v1.2
推送特定 tag
git push origin [tagname v1.5]
推送所有 tags
git push origin --tags
查看提交历史
从最新提交开始显示所有提交历史
git log
显示指定文件的所有修改
git log -p <file>
谁,在什么时间,修改了文件的那些内容
git blame <file>
修改 config
git config -e
别名
git config --global alias.co checkout # 设置之后 git co 就代表 git checkout 了
git config --global alias.br branch
git config --global alias.ci commit
git config --global alias.st status
unstage 在 smartGit 中经常使用的命令,存入暂存区,从暂存区移出
git config --global alias.unstage 'reset HEAD --'
然后我就可以使用,git add <file>
来将文件加入暂存区,使用 git unstage <file>
来将文件移出暂存。
最后来推荐一个 git 小游戏,用 ruby 写成,Github,在游戏过程中学习 git 基本使用。有几十个关卡,通关了大概也就对 git 非常了解了。
gem install githug
运行 githug
进入游戏。
Remove file from git source control but not delete it from drive 从 git 移除文件
The git rm command will allows you to remove a file from git control. The -cached
option to git remove allows you to leave it on your hard drive. Every once in awhile a file gets checked into git that isn’t supposed to be there. Common examples are configuration files, project files generated by your IDE with personal settings and even the occasional object file that someone decided to check in. These files are needed, so often you can’t delete them entirely and the process of copying them somewhere else, removing them from git and then replacing is painful, not to mention prone to error.
By adding the -cached
option to the git rm
command, you are able to remote the file file from git control while keeping the file in your working tree. They command syntax is:
git rm --cached file
Git will no longer track this file even though it is still on your hard drive. After running the above command, be sure to add an entry to your .gitignore
file so that ‘file’ doesn’t show up in git status
and that it can’t accidentally be re-added later.
from : gitguys
克隆项目到空文件夹中,在空目录中
git init
git remote add origin PATH/TO/REPO
git fetch
git checkout -t origin/master
NOTE: -t
will set the upstream branch for you, if that is what you want, and it usually is.
查看当前项目下远程
git remote
增加新的分支链接,例如
git remote add other giturl
获取他人的远程更新
git fetch other
将他人的远程更新合并到本地分支
git merge other/master
同样也可用此方法同步更新 fork 的项目
在需要修改的仓库中运行如下语句,写入当前仓库的 config 中
git config user.name "Your Name"
git config user.email your@email.com
该配置会写入 .git/config
设置中。
强烈推荐项目:https://github.com/einverne/my-git 这是我从 @xirong fork 而来的项目,以后有好的 Git 内容我也会更新到该项目。
数码投影仪,也称数码投影仪或数位投影仪。这是一种可以通过不同的接口同计算机、VCD、DVD、BD、游戏机、DV 相连接播放相应的视频信号的设备。视频投影仪可以播放静态的图像或动态的视频,有些投影仪还自带了音响,具备输出声音的功能。这种设备广泛用于家庭、办公室、学校和小型娱乐场所。根据工作方式不同,视频投影仪有 LCD, LCOS 及 DLP,DMD 等不同类型。
所谓“分辨率”指的是投影仪能够显示的像素数量。而“像素”是计算机上构成图象的单点。分辨率越高代表图像质量越好,越能表现出更多的细节。投影仪常见的几种分辨率格式:
分辨率模式 | 水平像素×垂直像素 | 全部像素数量(单位:万) |
---|---|---|
SVGA | 800×600 | 48 |
XGA | 1024×768 | 78.6 |
高清 720p | 1280×720 | 92.1 |
全高清 1080p | 1920×1080 | 207.3 |
WXGA | 1280×800 宽屏分辨率 | 102.4 |
其他分辨率见维基百科
每台投影仪都有一个“天生”分辨率(native 分辨率,有时候也叫真实分辨率),标示了投影仪实际上一次能够投影的最大像素数量。换句话说,SVGA 投影仪一次只能够显示 48 万像素。
这个数字听起来非常巨大,但是如果你使用的是一个常见的 2 米宽幅的投影屏幕,那么投影在屏幕上的每个像素将占用 1/4 厘米的宽度,而如果使用 XGA 投影仪的话,这一数字将会控制在 1/5 厘米以下,这样就可以比 SVGA 投影仪多显示 60% 的像素。用 XGA 投影仪放映,显示的影像将更加锐利清晰,并缓解了马赛克效应。
参考:维基 ty360 标准分辨率 / 最大分辨率
投影仪亮度表示的单位。“light out” 是投影机主要的技术指标,“light out”通常以光通量来表示,光通量是描述单位时间内光源辐射产生视觉响应强弱的能力,单位是流明。投影机表示光通量的国际标准单位是 ANSI 流明,ANSI 流明是美国国家标准化协会制定的测量投影机光通量的方法,测定环境如下:
LCD 投影机属于透射式投影方式,主要依靠提高光源效率、减少光学组件能量损耗、提高液晶面板开口率和加装微透镜等技术手段来提高亮度。DLP 技术属于反射式投影方式,其主要通过改进色轮技术、改变微镜倾角和减少光路损耗等手段提高亮度指标。
参考:投影机标称光亮度
不多介绍,目前已被市场淘汰,更多详见百科
全称:Liquid Crystal Display,液晶投影仪,可以分成液晶板投影机和液晶光阀投影机。液晶是介于液体和固体之间的物质,本身不发光,工作性质受温度影响很大,其工作温度为 -55℃~+77℃。投影机利用液晶的光电效应,即液晶分子的排列在电场作用下发生变化,影响其液晶单元的透光率或反射率,从而影响它的光学性质,产生具有不同灰度层次及颜色的图像。由于 LCD 投影机色彩还原较好、分辨率可达 SXGA 标准,体积小,重量轻,携带起来也非常方便,是投影机市场上的主流产品。
全称:Digital Light Porsessor,数字光处理器。DLP 是一项使用在投影仪和背投电视中的显像技术。DLP 技术最早是由德州仪器开发的。它至今仍然是此项技术的主要供应商。现在,DLP 技术被很多许可制造商所采用,他们销售的产品都是基于德州仪器芯片组的。DLP 以 DMD(Digital Micromirror Device)数字微反射器作为光阀成像器件。一个 DLP 电脑板由模数解码器、内存芯片、一个影象处理器及几个数字信号处理器 (DSP) 组成,所有文字图象就是经过这块板产生一个数字信号,经过处理,数字信号转到 DLP 系统的心脏 –DMD。而光束通过一高速旋转的三色透镜后,被投射在 DMD 上,然后通过光学透镜投射在大屏幕上完成图像投影。一片 DMD 是由许多个微小的正方形反射镜片(简称微镜)按行列紧密排列在一起贴在一块硅晶片的电子节点上形成的,每一个微镜都对应着生成图像的一个像素。因此,DMD 装置的微镜数目决定了一台 DLP 投影仪的物理分辨率,例如一台投影仪的分辨率为 600X800,所指的就是 DMD 装置上的微镜数目就有 600x800=480000 个。
3LCD 投影技术是一种透射式投影技术,将灯泡发出的光分解成红、绿、蓝三种颜色的光,每种颜色分别透过各自的液晶板,最后通过棱镜显现出明亮清晰的图像。目前,3LCD 技术由爱普生与索尼两家公司持有,并推出了多个尺寸与分辨率的液晶面板。
3LCD 是一种三片式技术,通过分离三原色实现了自然、柔和的色彩,而单片式 DLP 投影系统在色彩表现上则更依赖于色轮设计,因此几年前曾有 DLP 投影机的色彩不如 3LCD 的说法。目前,两种技术在色彩上的差距已经大大缩小,但是色轮设计仍没有统一标准,不排除低价 DLP 投影机会出现降低色彩以换取高亮度的做法。
当然,3LCD 技术也存在一些弊端,作为一种非数字化的技术,液晶板的寿命不及 DLP 芯片,为此上游厂商推出了无机液晶面板,相比有机液晶面板在寿命、对比度等方面有不小的提升。但是,在商教市场,很少有厂商与产品会明确标称采用哪种液晶面板。
参考:泡泡网
在了解这一些参数之后,进入电商网站,看投影仪的参数。有几个参数是必看的,像分辨率,流明,投影成像技术,因为我也是初看投影仪这种设备,对其他一些东西也不是很了解,所以以这些为参考以及我参考网上一些人的经验来谈谈一些想法。
当然在钱包鼓鼓的情况下,分辨率能有多高就选多高了。目前市场上最高的 1080P 分辨率应该能够满足绝大多数人的需求,但考虑到价格问题,对于分辨率的问题可以稍微降低一些要求,据我观察,1080P 的投影仪在京东上不下 6000RMB。如果限于钱包问题,以及家用需求,退而求其次,我会选择分辨率可以接受但是价格也可以接受的 720P 或者 WXGA。以上是我的情况,而下面是网上的经验之谈,因为 1080P 比 720P 分辨率多出 2.25 倍像素,高解析度是他的优势,配合相应的高清片源,将获得更加细腻的影响画面,特别适合对画质要求较高的用户。如果预算充足选购 1080P 是必须的。
如果手头的视频资源以 720p 为主,相信以 6000 元以下价格,720p 投影机与 WXGA 投影机依然能够吸引不少用户的目光。但是,目前很多厂商已经将主要精力投入到全高清投影机的研发,这一市场很可能逐步萎缩。
关于 720P 投影仪市场萎缩的情况,网上也有相应介绍,因为在性能上,受到分辨率的限制,投影画面可以很大,但是无法让使用者感受到真正的高清,高画质,适合于对画质要求不高的用户,玩 Wii 游戏、看大屏幕电视或者 DVD 电影还是不错的。
流明越高,亮度也越大,但并不是亮度越大越好,对家用来说,我觉得 2000 以上的流明应该能够满足我的需求了。而我观察了在买的投影仪基本上都在 2000 以上了。以下是网上的一些介绍:起初,高清投影机主要定位高端用户,仅用于专业的影音间里,而且在使用时需要达到如同电影院般的全黑环境,因此投影机的亮度指标通常在 1000 流明左右即可。随后,家用投影机开始走入普通家庭,由于使用习惯与实际环境无法实现影音室的全黑效果,如今主流家用机的亮度已经接近 2000 流明。亮度不是唯一的标准,也不是越亮越好,1000 流明的亮度足够普通家庭使用,除非你喜欢开着灯看大片。此外,如果居室面积很大,且投影距离超过 5 米,建议选择高亮产品。
对于这两项成像技术,在此之前我一点概念也没有,而了解之后对这两个成像技术也一点概念也没有。不过根据我浏览了很多商品参数之后,我发现目前市场上还是 DLP 的产品比较多。可能这个技术成熟了吧。貌似这项技术还涉及到支不支持 3D 成像。而网上是怎么说的:DLP 与 3LCD 是当今两大主流投影技术,占有投影机市场绝大份额,而 LCOS 技术目前还处于发展阶段,其产品制造成本与售价相对较高。同时,随着投影技术不断进步,采用 DLP 或 3LCD 技术的家用高清投影机都拥有很好的画面显示效果。 首先在色彩方面,DLP 高清投影机通过搭配 6 段高速色轮与极致色彩技术,让您不必再为色彩效果与彩虹问题担心。而在寿命与对比度方面,3LCD 投影机通过应用无机液晶面板与自动虹膜技术,大大提升了液晶板使用寿命与画面动态对比度。所以说,目前已经不能简单的从色彩与对比度方面区别两大主流投影技术。
选购建议:虽然投影技术已经非常成熟,但是基于 DLP 与 3LCD 技术的高清投影机的画面风格并不相同,最好通过亲身体验来选择符合个人口味的产品。
Hadoop Distribute File System, Hadoop 的一个分布式文件系统。HDFS 使用 Java,运行在 GNU/Linux
设计理念:
HDFS 需要注意的问题:
HDFS 是一个 master/slave 架构。HDFS 集群包括一个 NameNode(master server 管理文件系统 namespace )和一组 DataNodes,通常在集群中一个节点一个,用来管理存储。HDFS 暴露了一个文件系统 namespace 孕育用户数据保存到文件。在内部,数据块会被分割成多个 block 存储,block 大小默认为 64MB,每一个 block 会在多个 DataNode 中存储多份。
和 Hadoop 一起的压缩包中有 hdfs 命令
这两天突然又莫名的怀念起 Google Reader来,用到如今代替品,没有一个能让我有使用Reader的那种爽的感觉,想当时Reader是我所有Google产品中第一个记住快捷键的,在Reader界面我可以完全使用键盘浏览我想阅读的内容,这个感觉已丢失很久了.
我怀念Google Reader的快捷键, 怀念Google Reader的速度, 怀念Google Reader的分享,怀念Google Reader的搜索。尽管今天Google发布Newsstand整合了Play Magazines和Currents,可我依然找不到但是使用Google Reader的感觉,没有Web版更是让人无法接受。而让我感觉Google Reader又回来的是inoreader这款阅读器。清爽的界面,简洁的操作,丝毫不乱的快捷键让我找回了怀念很久的感觉。 下面就说说我认为一个阅读器很重要的功能,以及inoreader能够提供给我的功能
想要快速阅读大量的订阅文章,快速扫描文章标题,切换订阅目录是很重要的事情。inoreader继承了几乎所有的Google Reader快捷键,我最常用的有:
以上是我最常使用的快捷键,现在inoreader根据自己的情况又添加了很多很方便的快捷键,比如l表示赞,当然你可以自己查阅,找到自己一套熟悉的使用方式。
在Google Reader死掉之后我尝试的很多阅读器中,速度一直是一个很严重的问题。在inoreader之前我使用Feedly,Feedly的速度一直让我很头疼,虽然最近一次更新速度变快很多,但Feedly的界面以及快捷键,以及分享到Google+的问题让我不得不一直寻找其他替代品。虽然很多人现在已经适应了Feedly,包括那些付费的永久高级用户。像我认识的+shizhao, 像台湾的電腦玩物。电脑玩物博主很是推荐Feedly作为Google Reader的代替品,写了很多文章,但我还是抛弃了Feedly,因为它实在是进化迭代太慢了。最基本的https安全协议还是最近刚刚更新加上去的。其他的搜索就不说了,高级用户专用。
Inoreader就如我之前说过的一样,它自建立一套分享机制,就如同没有被Google+入侵前的Google Reader,有好友机制,可以查看好友广播出去的文章(加好友ID:einverne)。当然inoreader也支持向各大社交网站输出分享,Feedly让我离开的一大原因就是分享到Google+非常困难,+1按钮不知道是本身的BUG还是放置时不正确,在Feedly上很慢,还经常出错。这就是inoreader最基本的分享功能,而其他的评论功能,也是自建的,只有inoreader用户能够看到,并且评论只限于inoreader,不是到网站评论,帮我省略了“v”打开原网页留言的步骤,并且我还不知道那个网站使用什么样的评论系统,像极客公园还有自己的帐号系统,这种就该直接乱棒打死.inorader能够支持的云端记事本Evernote啦,支持的稍后阅读Pocket, Instapaper 啦,那些功能有待你去发现.
相信对于任何一个Google Reader的重度使用者,搜索的功能会经常使用,很多自己整理好的资料隐藏在Google Reader中,搜索有的时候比加心收藏方便得多.以前我还将一些电影资源更新的网站订阅到Google Reader中,直接检索电影名就能找到资源呢~现在没办法只能另寻法子了. 以前Google Reader还有一个很值得提的功能就是,即使你的博客挂了,不管是域名过期,空间过期等等其他问题,只要是Google Reader保存过的文章Google都会默默的保存下来,Google Search搜索不到的东西,或许在Reader中就能找到,并且Google Reader是我自己整理的资料订阅列表,我甚至能找到更加详细的资料或介绍.
这是一个不得不提的功能,很多用户因为这个甚至称赞inoreader已经超越了Google Reader,当然这样做的问题先不考虑哈~.那我来解释一下这个功能,也就是对于一些没有全文输出的博客,利用这个功能就能够在inoreader中看到全文输出.inoreader提供了快捷键”w”,来加载全文.当然Android版也是有同样的功能的.这也就是超越Google Reader的地方.
inoreader的Android版制作的非常像已经死亡的Google Reader曾经的客户端.虽然有人觉得不好看,而我觉得这是效率最高的阅读APP,当然如果做好看一点也不是不可以,inoreader提供了API,相信inoreader稳定后的不久就会有人做出更加功能完善,美观的APP,而目前我已经够了.
如果你看到这里想去尝试一下,可以点击: