歡迎來到梁良 | LonBlog,這里記錄下了我生活點點滴滴。

網路上關于 iOS 的使用技巧可以說是汗牛充棟,不有一些極其有用的小技巧,由于比較零碎,很容易被忽略。
此文就是 nAODI 收集的一些使用技巧,之前在 Twitter 上想到就推,在此做一個歸檔。
如果你還有什么實用的小技巧,歡迎留言,偶會補充。
當你不想接一通來電,又被其不斷的響鈴或震動所困擾時,只需按一下任一「音量」按鈕或「開關」按鈕,手機馬上進入靜默狀態。響鈴與震動統統消失。
當你在輸入文字時,搖晃手機就會有對話框彈出詢問你是否「Undo」,再晃一下則是「Redo」。在輸錯內容時格外方便,免去不斷按「退格鍵」繁瑣。
當你在輸入大段文字時要插入零星數字(比如要輸入年份或是時間)或標點,可以單手按住「123」鍵然后直接滑到要輸入的數字或符號,松開后鍵盤會自動回到「字母」狀態。
如果臨時要輸入一段內容有大量自創詞,又不想去關閉「改錯」功能。可疑先輸入一個字母「z」,然后將光標移到「z」字母前,再鍵入任何內容都不會激活「自動糾錯」功能。
將一些條形碼的會員卡、單據拍下來存成照片,借由 iPhone 高清晰的屏幕完全可以被掃描器識別,從而免去帶大量卡片的繁瑣。
在電話「撥號鍵盤」模式下,不輸入任何電話號碼,直接點擊「Call」,則會自動跳出最后一個呼出號碼。
當你進出電梯之類的地方導致 3G 或是電話信號丟失,可以通過開關「飛行模式」來快速重獲信號,這比等待手機自動重搜信號快很多。
Mac 下 iPhone 的備份文件存放在路徑「/Library/Application Support/MobileSync/Backup」下,Win 下存放在路徑「C:\Documents and Settings\XXXXX\Application Data\Apple Computer\MobileSync\Backup」下。
如果你覺得許多轉好的 iPhone 格式視頻清晰度太低,可以直接下載 iPad 適用的視頻文件,在 iPhone 4 上播放清晰度會比普通為 iPhone 轉換的視頻好很多。
當你在同步 iPhone 時,如果有電話撥入,同步會被中斷。可將手機調到飛行模式避免之。
當你設置了鎖屏密碼后,每次待機重開都需要輸入密碼,甚為繁瑣。只需要在設置﹣常規﹣鎖屏密碼 選項中的「Require Passcode」設置一個時間,鎖屏密碼就會在設定時間之后才開啟,省去頻繁待機重開時需要輸入密碼之苦。
據美國華爾街日報報道,美國高客傳媒(Gawker Media)旗下諸多網站遭到黑客襲擊,致上百萬用戶信息泄露。受“高客事件”的影響,其他很多網站也開始敦促用戶修改密碼。
上周日,黑客在網上貼出了關于高客傳媒用戶的個人信息,包括用戶名、電子郵件和密碼等。令人啞然的是,人們最常用的密碼居然是“123456”和 “password”!雖然原始密碼經過加密,但還是很容易被破解。有業內人士從中總結出了50個最流行的密碼設置,看一下是不是你自己也正在用呢?

通常注設置密碼時,網站會提醒你密碼的安全程度,單純的數字或者字母的安全程度是非常低的,一些固定的詞或者數字組成的密碼也是很容易猜到的。但還是有很多人這樣設置密碼,如“123456”“654321”“1234567”“666666”“password(密碼)”“monkey(猴子)”“football(足球)”“superman(超人)”等。
此外,密碼的長度也與安全程度有關,密碼越長,相對來說就越安全。據黑客資料顯示,在谷歌、雅虎和微軟這三大網站的用戶中,超過40%的用戶密碼是6位的,將近20%的用戶密碼是7位的,30%左右的用戶密碼為8位及以上。如圖所示:

黑客也披露了谷歌、雅虎和微軟三大網站的用戶電子郵件的常用密碼:passwOrd、blahblah、iloveyou、666666、cheese。如圖所示:

也許雅虎郵箱是適宜向對方示愛的媒介,不然為什么有這么多人都用情意綿綿的“iloveyou(我愛你)”來做密碼呢?不過,不然你今天給女友發一封郵件說“我們結婚吧”,明天也許就會收到回信說“我們分手吧”。瞧,信息安全多重要!
ps:結果真是有點出乎意料,相信在中國,以中國網民的智商能力,結果更恐怖。梁蕭提示大家還是把密碼修改得復雜點,最常用的郵箱和軟件要定期修改密碼,查看登陸ip。
源地址;http://www.mittrchinese.com/single.php?p=5774
GFW變廢為寶篇,高實在是高
From:
Carray Lee <carray...@gmail.com>
Date: Fri, 24 Dec 2010 17:38:15 +0800
Local: Fri, Dec 24 2010 5:38 pm
Subject: GFW變廢為寶篇,高實在是高
How to use GFW to stop DDoS attacks from China
It’s a easy way to protect your website.
But it will block any request from China.
So please remove it after the attack.
<?php
if(strpos($_SERVER['REQUEST_URI'],'minghui') === false) {
header('Location:'. $_SERVER['REQUEST_URI'] . '?minghui');
exit;
}
?>
If you are in China, you can visit
http://vii.im/gfw-test.php to test.
http://vii.im/articles/639.html
audio.js is a drop-in JavaScript library that provides a more flexible HTML5's <audio>
tag usage.
It uses native <audio>
where available and falls back to an invisible flash player to emulate it for other browsers.

The player can be completely styled with CSS to provide a consistent user interface.
audio.js can only play mp3 files and can be extended in any way like playing a single file or a list of songs.
Special Downloads:
Ajaxed Add-To-Basket Scenarios With jQuery And PHP
Free Admin Template For Web Applications
jQuery Dynamic Drag’n Drop
ScheduledTweets
Advertisements:
Professional XHTML Admin Template ($15 Discount With The Code: WRD.)
Psd to Xhtml
SSLmatic – Cheap SSL Certificates (from $19.99/year)
Tags:
HTML5,
Javascript,
MP3
Related posts
【親歷“世界最大科學實驗”】 之 新發現
CERN科學家捕獲反氫原子
抓住“反物質”
歐洲核子研究中心(CERN)是一個龐大的科研機構,除了LHC的相關實驗之外,還有上百個實驗在同時進行,而大部分的實驗,最終的目的都是一個:解開宇宙起源之謎。我們知道建造LHC的最主要目的是為了尋找聞名卻未見的希格斯子,但CERN還有很多其他的事情要做。比如說按照現行理論,宇宙大爆炸時同時出現了物質和反物質,但是兩者卻無法共存,但為什么今天的宇宙只有物質但沒有反物質呢?反物質到底是什么東西?隨著技術的進步,這也成了物理界越來越引人注意的話題。
11月底,CERN發布的一個突破性消息引起了人們的廣泛關注。反氫激光物理設備(ALPHA)坐落于CERN的主樓群,僅有40位科學家為此工作。正是他們首次長時間捕捉到了反物質。盡管這個發現借用了LHC的成果,但其實驗和LHC的思想完全相反,不是加速,而是“減速”。
對稱定律解釋世界
ALPHA實驗室全景。圖/CERN
和其它物理界的發現一樣,反物質首先也是“思想實驗”。早在79年前,英國物理學家狄拉克就試圖把量子理論和狹義相對論結合在一起。這是兩個互不兼容的基本物理理論。狄拉克發現,反物質必定存在。1932年,人們在實驗中尋找到了狄拉克設想的正電子,其質量、帶電量與電子完全相同,只不過它帶的是正電(電子帶負電荷)。
隨后,人們逐漸發現了各種基本粒子對應的反物質。“反物質就像是物質在鏡子中的像。它和對應基本粒子的質量完全一樣,卻具有相反的其他量子性質。”ALPHA實驗發言人杰弗瑞(Jeffrey Hangst)在接受本報記者采訪時說,“質子帶正電,反質子帶負電;電子帶負電,正電子帶正電……”
按照目前解釋微觀世界最好的理論模型,宇宙大爆炸時,同時產生了物質和反物質。今天,NASA的天文學家們也觀察到,在遙遠的宇宙區域———也就是我們所能看到的早期的宇宙,似乎存在物質和反物質碰撞后產生的伽瑪射線蹤跡。不過今天的宇宙卻是由物質而非反物質組成的。“自然選擇了物質,反物質似乎消失了。沒有人知道為什么。”
宏觀世界中,很多東西都是對稱的。微觀世界也是這樣。在“標準模型”中,有著一個對稱定律,認為量子場論方程所有允許的解,都依據這個對稱定律,物質所遵循的物理法則,反物質也同樣遵循。這個對稱定律由三個字母組成:C、P、T,它們意味著三方面的對稱:電荷共軛變換、宇稱(左右)、時間反演。在隨后的歲月中,不少物理學家們靠研究對稱性問題拿下了nbl獎。其中很多人研究的是“對稱破壞”,即在一些物理過程中,一些對稱性(特別是C和P的對稱)被破壞了。
“CP對稱破壞”是描述今天宇宙中物質數量超過反物質的重要解釋之一。目前,有很多科學實驗都在對這個現象進行驗證,希望通過反物質研究了解到對稱性定律及標準模型的有效性。
最冷的反物質
ALPHA實驗室全景。圖/CERN
LHC的四大探測器之一LHCb研究的主要就是反物質和對稱性問題。但ALPHA實驗卻和LHC幾乎沒關系,和LHCb的實驗目的和方法也截然不同。在這里科學家們同樣選擇了氫,氫原子和反氫原子都只有一個質子和一個電子,結構非常簡單。
兩個反氫原子的原料分別是這么制作的,將定向質子束射向一小片銥,高能碰撞會生成反質子,再加以分階段冷卻。由放射性鈉衰變產生正電子也加以冷卻。“我們借用了對撞機中產生的反氫質子,所以我們還是依附于CERN的實驗。但設備和實驗都是我們自己設計。”杰弗瑞告訴本報記者。
在ALPHA 并不大的實驗室里,層層的管道連到磁場上方的探測器。在這里工作的科學家設計了一個改變速度的設備。它并不是另一個加速器,而是一個減速器。科學家將已有的反質子和正電子放在一起,令其生成反氫原子,然后讓它逐漸減速,以便在一個像浴缸一樣的磁場中將其“捕獲”。
反物質無法與物質共存,因為兩者一旦接觸,便會同時消失并轉化為能量,轉化的能量形式如光子,這個過程用術語叫做“湮滅”。該過程產生的能量十分巨大。
ALPHA的實驗結果卻跨過了這個門檻。首先,實驗必須在真空中進行,科學家設計了一個真空管道,排除了絕大部分的空氣物質。反氫原子是中性的,沒法通過電荷來捕獲,怎么逮住它呢?杰弗瑞介紹,盡管電中性,反氫原子還是帶有微弱的磁場,可以對磁場做出反應。
在熱力學上,溫度體現的是物質粒子的動能。理論上說,如果物質粒子達到絕對零度時,它應該完全靜止。所以,溫度越低,粒子的速度越慢。科學家們讓來自 LHC的高能反氫質子減速冷卻,最后讓-70℃左右的反質子束和更冷的正電子束進行對撞,一些反質子和正電子結合形成了反氫原子。如果說LHC的目的是令粒子更快、更熱、更重,那這個實驗中,原子則變得更冷更慢,其中速度最慢的反原子,溫度僅有-272.5℃。
這些超級冷的反原子,最后“陷”入了一個超導磁鐵構成的“磁場缸”里。“磁場越強,抓住的反原子也越多。”杰弗瑞說。他們共運行了335次實驗,由1000萬個反質子和7億個正電子結合。產生的反氫原子中,有38個被捕獲。
要觀察被“囚”的反物質的存在,唯一的方法就是“釋放”它。0.17秒后,科學家們關閉了磁場,反氫原子迅即與氫原子碰撞,湮滅無蹤。探測裝置及時地記錄下了這38次能量爆炸。這些爆炸都發生在反氫原子和產生磁場的缸狀容器壁上。反物質和物質湮滅后形成了新的粒子。實驗中,新產生的粒子是名為π介子的亞原子粒子。
杰弗瑞說,這是科學家第一次長時間“逮住”反物質。LHCb這樣的高能粒子實驗是沒法捕捉反物質的,因為高能量的反粒子會迅速與實驗設備相撞而消失,唯一能困住的,是低能、寒冷、運動緩慢的反粒子。
反物質不會炸毀地球
在高能物理的反物質實驗如LHCb,主要的實驗目的是尋找宇宙初期為何物質戰勝了反物質而存在。另一些反物質實驗,如CERN的另一實驗ATHENA,主要研究反物質和引力的關系,而ALPHA的主要目的是研究標準模型是否能夠同樣作用于反物質。
標準模型認為,反物質和物質遵循一樣的物理原則,比如反粒子應該和對應的粒子一樣能夠吸收同樣的光的顏色。因此,此次科學小組用激光照在反物質上,準備探究其是否和對應的物質一樣吸收同樣的光波。
“到目前為止,在量子層面上,‘CPT對稱定律’都表現得很好。但對于反物質,人們從來沒有在原子核層面測量過其對稱問題。”杰弗瑞說,“我們不知道為什么自然選擇了物質而不是反物質,也不知道標準模型是否能夠應用在反物質系統,或許標準模型能夠在反物質中被證實,或許我們會尋找到驚喜,因為我們不知道物理會往哪兒走。”
捕捉反物質的技術正在突飛猛進。杰弗瑞表示,明年年初,他們將能夠捕獲更多的反原子。CERN的另一個實驗項目ASACUSA,最近也在他們實驗的基礎上,通過新技術,將反氫原子引導到一個真空管中研究飛行速度。這個實驗的目的是制造足夠多的反物質,研究其運動行為。
即使這樣,反物質的取得基本上還是只存在于實驗室。79年前,狄拉克第一次提出了反物質的想法,這個名字就開始進入科幻小說。15年前,科學家制造出了反物質,但直到今天,人們才第一次較長時間捕捉到了反物質。雖然動用了大量昂貴的超導磁鐵,科學家也只逮住38個反氫原子,技術之艱難可見一斑。因此,對于媒體與文藝作品描述的,將反物質作用于航空、軍事等領域的設想,杰弗瑞表示這完全是天方夜譚,離科學現實還遠得很。
“要造出《星際迷航》或者《天使與魔鬼》中所描述的那么多反物質,我們所需要的時間甚至會超過宇宙的壽命。而且,為制造它們而消耗的能量要比它們最后產生的能量還要大。”他補充說,在小說《天使與魔鬼》中,就提到了ALPHA實驗使用的低能反物質。在拍攝同名電影的時候,導演曾來CERN咨詢相關科學細節,但最終還是為了保證良好的視覺效果,將故事嫁接在了LHC上———實際上,LHC是根本無法保留住反物質的。
另一方面,反物質研究可以推動技術進步。今天,反物質已經在醫學上的正子放射斷層掃描儀(PET)中發揮作用。但真正研究反物質的目的,還在于科學追求真理的本質。“人類的好奇心永遠無止境,我們想要知道宇宙爆炸時到底發生了什么。”杰弗瑞說。
本版采寫/本報記者 金煜
車作為一件工具,對我們的生活越來越重要,因為車除了開,還可以震……
在不同環境的野戰中,車震的刺激指數始終排行第一,尤其是如果你膽子大,在馬路邊車震,那種刺激可不是一點亮點可以形容滴……
不過,房車房車,畢竟不如房間,空間較為狹窄,所以車震是一項相當需要技巧的活兒。各種姿勢、道具等都和正常方式的SX不同。甚至于有不少車在設計時已經開始考慮用戶車震的需求,從而進行了一些特殊設計……
點擊圖片可查看大圖
看到排第一的mini cooper,我震精了,果然,豪車貴有貴的道理,外表實在不咋樣,內里如此給力,難怪二奶三奶都開它!國外的設計師就是牛X啊!
嘖嘖,不同的車有不同的震法,大有大的好,小有小的妙,色男色女們的智慧可真是不得了!
可惜這里的車都是進口車,國產車太少了,什么時候國內也為國產車出一個車震手冊就好了!
最后的注意事項大家要仔細看哦——假如你想學著車震……
如果車展上買車送美女,那么大家買了馬上就能震了,送福利圖一張,表示我對車震的深深怨念!
憤怒的小鳥(Angry Birds)這款游戲在Android手機平臺上非常火!近日Rovio公司發布了PC版的憤怒的小鳥,非常給力!憤怒的小鳥這款游戲的故事相當有趣,為了報復偷走鳥蛋的肥豬們,鳥兒以自己的身體為武器,仿佛炮彈一樣去攻擊肥豬們的堡壘。卡通的畫面,可愛的配音,玩起來相當有趣!游戲中有不同種類的小鳥,每種小鳥都有自己的特長,要好好配合利用才能順利過關。

游戲說明:
1、由于某些顯卡或顯示器分辨率不支持本游戲,為了更好的兼容性,軟件便利店提供的版本已經修改為窗口模式運行。
2、用記事本打開“config.lua”,把“fullscreen = false”改為“fullscreen = true”即可變回全屏模式。
3、游戲時,按“ALT+回車”可以在全屏和窗口模式之間切換。
4、游戲的存檔保存在以下路徑中:
XP系統:C:\Documents and Settings\你的用戶名\Application Data\Rovio\Angry Birds
WIN7系統:C:\Users\你的用戶名\AppData\Roaming\Rovio\Angry Birds
不會玩的朋友請看這里:
《憤怒的小鳥》完全解析:http://game.ali213.net/thread-3399935-1-1.html
《憤怒的小鳥》官方視頻攻略:http://game.ali213.net/thread-3399798-1-1.html
下載地址:Angry_Birds_Soft711.7z
xhEditor是一個基于jQuery開發的簡單迷你并且高效的可視化XHTML編輯器,基于網絡訪問并且兼容IE 6.0+,Firefox 3.0+,Opera 9.6+,Chrome 1.0+,Safari 3.22+。在眾多用戶不斷的問題回饋和意見反饋下,經過長達1年零3 個月的不斷完善后,v1系列的正式版本v1.1.3 Final終于正式對外發布。經過這么久的不斷開發修正和完善,v1.1.3 Final的BUG數量相對已經非常少,我們有自信可以給大家交上一份滿意的答卷。
我們不是最好的,但是我們會努力做的更好,我們愿意傾聽和接受所有用戶的心聲。最后,大家在使用過程中若發現任何的問題,或者有比較好的創意和想法,可以隨時向我們反饋(yanis.wang@gmail.com),我們會隨時傾聽大家的意見,xhEditor的發展離不開大家的支持。
查看最新版演示:http://xheditor.com/demo
更多官方在線演示:
1. 默認模式:http://xheditor.com/demos/demo01.html
2. 自定義按鈕:http://xheditor.com/demos/demo02.html
3. 皮膚選擇:http://xheditor.com/demos/demo03.html
4. 其它選項:http://xheditor.com/demos/demo04.html
5. Javascript交互:http://xheditor.com/demos/demo05.html
6. 非utf-8編碼網頁調用:http://xheditor.com/demos/demo06.html
7. UBB可視化編輯:http://xheditor.com/demos/demo07.html
8. Ajax文件上傳:http://xheditor.com/demos/demo08.html
9. 插件擴展:http://xheditor.com/demos/demo09.html
10.iframe調用文件上傳:http://xheditor.com/demos/demo10.html
11.異步加載:http://xheditor.com/demos/demo11.html
v1.1.3 Change (2011-1-1)
- 調整:取消刪除線的快捷鍵:Ctrl+S
- 修正:IE瀏覽器下無邊框的table沒有顯示輔助的虛線邊框問題的修正
- 修正:IE瀏覽器下光標定位在編輯器中,xheditor(false)卸載編輯器會造成當前頁面光標被鎖死問題的修正
- 修正:®和©被瀏覽器強制轉為字符問題的修正
- 修正:從其它網站復制粘貼WORD文檔和普通HTML混合的內容時,會導致圖片丟失問題的修正
- 修正:urlType參數開啟情況下,mailto:地址被轉絕對地址問題的進一步修正
- 修正:Flash和視頻不支持輸入百分比數值問題的修正
- 優化:優化Word自動文檔清理功能,進一步提高代碼處理效率并且兼容Excel文檔粘貼
- 優化:優化formatXHTML函數,極大提高代碼格式化效率
官方下載:
著名的Google安全黑客Michal Zalewski宣布,他的fuzzer工具發現了IE的一個新漏洞,fuzzer至今已經從IE、Firefox、Chrome、Safari等瀏覽器中發現了上百個漏洞。微軟周日表示正對此進行調查,它之前曾要求Zalewski推遲發布安全工具cross_fuzz發現的漏洞,但被拒絕。
Zalewski聲稱,他相信中國黑客正在利用這個新漏洞。證據是他在12月30日,發現來自中國的IP地址在Google.com.hk上搜索兩個MSHTML.DLL函數——BreakAASpecial和BreakCircularMemoryReferences——與新發現的漏洞有關,而中國黑客似乎對cross_fuzz不很熟悉,他下載了所有能訪問到的文件。
按:這幾天我一直在寫這篇東西,本來是胸有成竹,沒想到后來越寫越發現自己在這個題目下有太多話想說,而以我現在的能力又不能很好地概括總結,以至 于越寫越長,文章結構也變得混亂,到后來修改的時候每次都要考慮好久才能下筆,所以決定拆成兩部分來發,以便閱讀。這篇寫得我心力交瘁,質量不算好,湊合著看吧。
同樣是寫程序,不同的崗位工作內容不一樣,對程序質量以及工程師的要求也不一樣。程序開發大概可以劃分成兩類:開發和研發,相應也就有開發工程師和 研發工程師。很多人覺得做開發和做研發沒什么區別,“都是一樣對著電腦寫程序啊”,但其實這兩者是完全不一樣的,下面我想拋開公司對員工的期望、社會對工 程師的需求等其它因素,單純從國內互聯網行業“工程師個人發展”的角度來說一下我個人對這兩類工作的看法。
開 發一般是指產品開發,開發工程師直接為產品貢獻代碼。每個公司都有自己的產品線,拿 Google 來說吧,它有 Gmail, Chrome 等產品,每個產品都有很多開發工程師在后面支持,這些產品的開發、維護以及升級都是由相應的開發工程師負責的。由于開發工程師的工作直接關系到產品的質量 和在線情況,所以開發工程師的責任是很重的,他可能經常為了下個版本的發布而加班,為了產品的故障不得不在休假的時候打開電腦工作,甚至在過年的時候都會 接到領導的電話。所以你看到那些總抱怨加班太多,總是說自己是“IT民工”的,大部分都是開發工程師。在工程師當中,大部分人都是做產品開發的,畢竟公司 都是要靠產品盈利,招聘的大部分人也要直接為產品服務。
做開發是很辛苦,但也有好處,因為需要對產品線負責,所以會是公司的核心,裁員 對你威脅不大,如果你負責的產品恰好又是盈利產品的話,那么加薪、獎 金、集體出游等福利都不會少。如果你足夠幸運地加入了一家快速發展的創業公司,說不定一下子就發家了。還有很重要的一點是,作為產品的開發人員可以看到自 己做的東西被那么多人使用,那是一種莫大的鼓勵和肯定。
苦悶的開發工程師
盡管我很尊重開發工程師,但是我不得不承認,在國內大部分的 公司,做開發工程師是沒有前途的。首先,從微博到開心,有多少國內的產品不是山寨的?這 也罷了,最惡心的是有一些產品經理連產品設計圖都懶得自己畫,直接去截取別人產品的圖片,假如我是一個人人網的開發工程師,每天看到產品經理把 Facebook 新上線功能的截圖拿過來讓我做,你讓我如何對產品有榮譽感和認同感?而如果一個開發工程師對自己做的東西沒有榮譽感和認同感,那么他堅守自己的崗位要么是 因為公司給的錢多,要么是因為他還沒有找到下家。我個人認為,做開發最大的一個好處就是可以親手實現一個“自己的作品”,就算平時很累,但最后完成它的時 候也還是會無比滿足,這點被剝奪了之后,和飯店打工的服務員有什么兩樣?不一樣是為了糊口嗎?
我不知道別人怎樣,但我自參加工作以來就一直糾結于此——甚至開發的大部分產品都不好意思寫上自己的名字;直到前不久有機會去做一個公司內部使用 的 平臺,才終于有個作品讓自己覺得滿意。相信很多開發工程師參加工作之前都對互聯網上很多諸如Gmail, Facebook 等優秀的產品耳熟能詳,自己也常夢想做出那樣的產品,但萬萬沒有想到的是,工作之后要學習的第一課就是“不要對自己做的東西有感情”——有了感情你就不愿 意做廣告彈窗,不愿意看到它下線,不愿意為了短期利益傷害用戶。與此同時,你還要繼續聽產品經理和老大們滿懷激情地說“我們一定要讓用戶喜歡我們的產 品”。一個連開發工程師本人都覺得無聊的產品如何讓用戶真正喜歡呢?拿搜索巨人來說吧,Google 把社交網站看作是某種形式的娛樂而不是有用的工具,所以它會
在社交領域失敗,再牛的技術也無法遮蓋情感上的空白。不過話說回來,這好像對于國內大部分的公司都不是問題,因 為它們做一款產品只是想從用戶那里拿到錢,如果以后用戶流失了就下線,然后再開發一個新的。他們要的不是用戶的長期感情,而是一夜情,開發工程師就是一夜 情的工具。
其次,國內幾乎所有公司的技術流程和技術積累都做得很爛,大部分都只是片面地追求開發速度。我們在大學里受到的教育是“文檔和注釋很重要”,工作 之 后才發現文檔和注釋是很稀有的東西,只有特別負責任的工程師才會擠時間去寫。有一個很有意思的現象是,國內很多產品發布之后會特別自豪地說“XX 是我們開發團隊在時間緊迫的情況下,封閉開發了X 天就完成的!只有最牛的工程師才能創造這樣的奇跡!!多少個凌晨,XX寫字樓上只有我們辦公室的燈還亮著……”,然后你會覺得“好感動啊”,但冷靜下來想 一想,這種拼命趕工做出來的東西質量會過硬嗎?拋開產品質量不談,沒有時間寫文檔、沒有時間寫注釋、沒有時間做 code review, 沒有時間做階段總結……沒有了這些,作為一個開發工程師你通過這個項目可以提升多少呢?所以好多開發工程師一開始是“代碼民工”,過了幾年還是“代碼民 工”,而一個人年富力強的時間又有幾年呢?怪不得那么多人說工程師和妓女一樣,都是吃青春飯的。
發展方向
我個人認為,國內的開發工程師大概有三個發展方向:1.做管理。 2. 去做架構等與產品關系不那么緊密的研發。3. 提升其它方面的能力,做 “A+ Player”,然后自己創業。我對管理沒有研究,也沒有興趣,這里就不說了。研發我會在下篇中細說,這里主要說一下第三條。
為什么要關注代碼之外的事情
如果你只會埋頭寫代碼,那么代碼寫得再好也可能不會是一個好的開發工程師。做開發不是做學術研究,你的任務不是去鉆研技術,而是利用自己的技術把 產 品做出來。盡管技術能力是基礎,但如果無法把能力很好地應用到開發當中,那么你在團隊中就沒什么價值。舉個例子,如果你不能很好地理解產品需求,那么就會 根據自己的理解去做技術方面的架構和編碼,等到后來發現了再去修改就特別麻煩,這個時候技術能力強反而成了壞事,南轅北轍的故事我想大家都聽說過。
很多開發工程師屬于那種“很本分”的人,從來不會提出意見,不關心產品形態和細節,只是去做產品經理提出的需求。我覺得別人把工程師叫做“代碼民 工”也就算了,但是工程師對自己做的東西完全沒有看法,那就是甘心淪落為民工了。這也有文化的原因,國內的公司都喜歡那些不愛抱怨的員工,因為他們聽話而 且符合中國傳統的價值觀,但我更喜歡那些愛抱怨并且抱怨得有道理的人,因為國內(不只是互聯網上面)粗制濫造的東西實在太他媽的多了,不抱怨才不正常,有 不滿才會去思考如何做得更好。
曾經聽到有人談論如何管理技術人員的時候說:“管理技術人員很簡單,找一個比他們都牛的人就行了。” 這個人很了解工程師的脾氣。工程師去判斷其他工程師的時候,往往只看他的技術能力,覺得誰的技術好誰就最牛,其它的都無所謂。沒錯,技術牛的工程師寫的代 碼質量很高,但這只是一個方面而已,判斷一個人在團隊中是不是“很牛”要看他對團隊對產品的整體貢獻,而不是他的個人能力。他能很好地理解產品需求嗎?能 很好地理解設計師的意圖嗎?和團隊其他成員溝通順利嗎?寫出的代碼方便測試嗎?會對產品提出好的建議嗎?……這些都是判斷一個開發工程師的標準,整體素質 越高在團隊中的價值也就越大。
所以要想做一個好的開發工程師,就要在寫好代碼的同時努力提高其它方面的能力。我知道大部分的工程師都喜歡和機器而不是和人打交道,所以遇到和產 品 經理、設計師以及 QA 等部門協調溝通的時候就皺眉頭。協調溝通確實是一件鬧心的事情,但從另一方面來說,這是開發工程師的一個得天獨厚的優勢:你可以深入接觸產品生產線上的所 有環節。需求評審的時候,你可以了解產品設計;開發界面的時候,你可以了解到視覺和交互設計;測試的時候,你可以了解到產品測試的細節;上線的時候,你也 可以多觀察 Ops 同事的操作。如果你可以在協調溝通的時候學會換位思考,多從對方的角度看問題,多想一下“他為什么要這么做”,那么不知不覺就會對各個領域有一些了解,進 而發現原來每個領域都大有學問,就不會因為周圍那些學藝不精的人而輕視他們所在的領域。
學習設計
對于工程師來說,測試和上線都是技術性的工作,和開發有很多相通的地方,而產品設計、交互設計和視覺設計等設計領域則比較陌生。對于自己不了解的 東 西,我們的看法往往會趨于兩個極端:要么是看得高深莫測,要么是看得一文不值。其實對于大部分的東西,只要不笨并且愿意下功夫學習,總是可以學會的。盡管 達到大師的水平可能需要傳說中的“天賦”,但做到中等水平并不是特別困難。關于設計領域我一直在斷斷續續地在學習,到現在可能連略窺門徑也算不上,這里只 是說一下我個人對設計的理解和心得,供大家參考。
產品設計
產品設計看上去比較簡單,因為只要清楚自己想要做什么,那么自然可以慢慢勾勒出產品的形態和功能。要做好產品設計,就需要平時多下一些功夫,多研 究 一下互聯網上那些已有的產品,另外還需要多看一些諸如社會學、歷史等“閑書”,舉個例子,假如你想開發一款針對臺灣用戶的產品,那么了解一下臺灣的文化肯 定是有必要的。總之,學習產品設計是慢功夫,沒有什么速成的捷徑,只有一點一滴地不斷積累才能培養出敏銳的產品意識和深刻的洞察力。
工程師學習產品設計有一個優勢,那就是設計出來的產品是自己親手實現的,你可以在實現的過程中不斷重新反思原來的設計,然后加以修改和完善。這就 好 像寫文章一樣,很多時候你寫東西的時候并不清楚自己具體要寫什么,但只要是下筆開始寫,寫著寫著就會發現新的想法,寫作的過程同時也是思考的過程。寫作和 寫代碼很像,它們不僅可以表達想法,還可以創造想法。
視覺設計
很多工程師聽到視覺設計會立刻退避三舍,覺得自己“不會畫畫”、“不懂配色”是不可能學習視覺設計的。誠然,視覺設計是需要更多藝術方面的基本 功, 要完全掌握需要長期的訓練,但我們還是可以從簡單的學起,慢慢培養對設計的感覺。我個人在這方面所知非常有限,但是對視覺設計中的完美主義印象深刻。
編程的時候,如果你的某行代碼多了一個空行可能不會有什么問題,但在視覺設計中差了 1 個像素或者 10% 的透明度就是不可容忍的,很多設計師要求的都是 “Pixel-Perfect”——像素級別的完美。如果你不苛刻地追求完美,幾個這樣的“小瑕疵”就可以把整個作品毀掉。在我沒有接觸過視覺設計的時候 很難理解這一點,切頁面的時候并不會特別仔細地去看設計圖,而且為了降低技術難度會想當然地篡改設計師的意圖,比如把一些微小的漸變用純色代替,這是很無 知的做法。所以當設計師要求你做一個 1px 的修改的時候,即使會花掉你幾個小時的時間也要聽他的——只有這樣才可以把界面做到百分之一百的完美。當然,設計師自己做不到完美另當別論。
此外,作為一個頁面設計師,從職位名稱上來看他的最終作品應該是頁面,而不只是視覺效果圖。所以我覺得頁面設計師應該精通 CSS,只有自己才可以精確實現自己的設計意圖。對于那些沒有受過設計訓練的工程師來說,很難注意到頁面上色彩、字體和漸變的細節,讓他們精確實現一個設 計師的意圖幾乎是不可能的。精通 CSS 對于頁面設計師來說并不算一個過分的要求,很多國外的設計師甚至可以自己用 PHP 寫出產品原型,相比之下,國內的頁面設計師進化得實在太慢了。
交互設計
交互設計是有關行為的設計,它更關注如何讓產品更好用。舉個例子,網頁中一般都有很多超鏈接,當你把鼠標移動到超鏈接上的時候,鼠標形狀會變成手 型,暗示它是可以點擊的,而且訪問過的超鏈接和普通超鏈接的顏色是不同的,這樣就很好地引導了用戶行為。
之前我一直把設計和“視覺設計”等同起來,但在深入了解了之后發現,對于互聯網產品來說,交互設計要比視覺設計重要得多,而且交互設計相對于視覺 設 計也更加有跡可循,對“感覺”要求沒那么高,工程師完全可以把重點放在交互設計上。如果交互設計做得好,視覺設計遵循一些標準,那么完全可以做出一款“不 難看并且好用”的產品。沒有人特別夸贊 Google 的產品“好看”,但它們都特別好用,Google 注重的是易用、快速,用戶體驗是很棒的。
互聯網行業的大部分頁面設計師(Web Designer)都是學習平面設計出身的,但我覺得網頁和軟件設計更像是“顯示器里面的工業設計”。很多平面設計師設計出的頁面很好看,好像海報一樣, 非常適合打印出來,但往往對交互方面重視不夠。不太好看影響不會很大,但不好用就沒有辦法留住用戶,而且有時候太注重外觀的視覺效果反而會分散用戶的注意 力進而影響產品的使用,這種 “eye candy” 是糟糕的設計。現在專門培養交互設計師的機構不多,我很希望對互聯網有興趣的工業設計師們到這個行業中來。
關于設計我就說這么多,以后有機會再另外撰文專門探討這些主題。值得一提的是,沒有人可以真正把設計和開發全部精通,如果深入到細節,無論設計和 開 發都會占用你大量的時間和腦力。單從設計來說,需要掌握的就有顏色、字體排印(Typography)、排版(Layout)、交互設計等,其中每一種技 能又涵蓋無數細節,真的是要皓首窮經才可以在其中的某個領域成為大師。不過,即使你對這些知識只是有一個大致的了解,以后在看一款產品的時候也可以從功 能、交互、排版、頁面代碼、整體性能以及URL語義化等各個方面進行全面而細致的分析,明白它哪里做得好,哪里做得不好,而不是在那里想當然地說“真酷” 或者“狗屎”。真正了解什么是好的什么是差的,自己做東西的時候才會心中有數。
一專多能的好處
很多人可能會說:“一個人要是可以把所有事情都搞定,那還要其他人干嘛?我更相信團隊的力量。” 沒錯,一個人就算從設計到開發都精通,如果只有他一個人做東西,開發效率也不會高。但是若你真的花心思去了解那些“與代碼無關的事情”,你就會在寫代碼的 時候更多考慮到產品經理/設計師的想法,對產品經理/設計師疏忽的地方也可以及時提醒,讓自己真正地融入整個團隊。目標并不一定要實現,它是用來指明方向 的。開發工程師提高自己的產品意識和設計能力絕對不會是白費心血,不然的話你就只是一個實現產品的工具。你只會回答別人提出的問題,而好的問題要比好的答 案有價值得多。
當你各方面能力提高得差不多的時候,應該就可以出來創業了(注意,我說的是創業,不是去創業公司打工)。因為對各個領域都有一定的了解,平時也經 常 接觸到各個領域的人,那么在創業的時候你就很清楚自己需要什么樣的產品經理/設計師,知道具有什么樣能力的產品經理/設計師才是最好的,這樣就可以從一開 始就保證團隊的質量和氣質。很多互聯網的業界前輩都說過“要招聘最好的人”,但問題是你如何判斷一個人是不是該領域最好的呢?如果一個人對程序和設計一竅 不通,滿腦子都是商業運作,你覺得他有可能找出最好的工程師和設計師嗎?有一次和一個創業公司的CEO聊天,他和我講他們“只招聘 Geek”,后來我才發現他其實根本不知道什么是 Geek,只是不知道從那里聽到 Geek 這個詞,他真正想要的應該是那種只知道寫代碼愿意沒日沒夜任勞任怨給他當牛做馬的人。國內大部分的創業公司就是這樣,老大們喊著技術密集型的口號,實際上 做著勞動密集型的事情,金玉其外,敗絮其中。你可以和他們不一樣。
我自己并沒有創業的經歷,也沒有創業的打算,所以對創業的理解可能很片面而且天真。但是我相信,找到最好的人永遠都是關鍵,不然即便后來成功了, 也 不過是多了一家靠人數取勝的血汗工廠。假如你選擇成為移動互聯網的獨立開發者,對一個產品各個環節的全局把握也是有必要的。如果一個團隊的每個人都能獨當 一面并且可以很好地理解其他人的意圖和專業技能,就算最后在商業上失敗了,那也會是一個幸福的團隊,比那些除了盈利之外找不到任何亮點的團隊好太多。
對產品經理的偏見
在“開發”這個小節的最后,我想多說一點自己對產品經理這個角色的看法。在國內絕大多數公司,開發工程師的作用就是把產品經理的想法以代碼的方式 寫 出來,“代碼民工”這個稱呼倒是很恰當。我對互聯網行業的產品經理們一直感到很奇怪:他們沒有能力把自己的想法實現出來,但是卻幾乎總是認為自己比其他人 更理解產品;當工程師對產品提出自己的意見的時候,他們往往會心中不屑但盡量保持禮貌擠出微笑說一句:“呵呵,工程師不是普通用戶”。一個產品本來就是需 要很多人齊心協力一起完成的,產品經理和工程師的地位也是平等的,但是由于產品經理在工作流的上游,所以情況往往演變成工程師在為產品經理工作。如果產品 經理真的對產品負責也就罷了,可惜的是大公司的產品經理大部分是對KPI負責,小公司的產品經理大部分是對老板的個人好惡負責,結果就是工程師跟在產品經 理屁股后面做一些莫名其妙的事情。我接觸到的幾乎所有開發工程師都對他們的產品經理頭疼不已,據他們說,好的產品經理就像真正的愛情,是極為稀有和可遇不 可求的。
按照現在大部分公司的分工方式,產品經理是產品的總負責人。根據我個人的理解,產品經理之于產品,應該相當于導演之于電影,建筑師之于建筑。一個 導 演如果對拍攝一竅不通,那么就很難控制鏡頭的表現力;一個建筑師如果對建筑材料和結構一無所知,就不可能把握建筑整體的感覺。那為什么那么多人會覺得產品 經理可以不懂技術不懂視覺設計,只需要寫好文檔畫個框圖然后交給別人去做就可以做出好的產品呢?本來是一個需要對各個領域融會貫通最難做得好的角色,現在 反而被很多人視為清閑的差事,不愛干活的人紛紛想要轉去做產品經理,實在是可悲至極。
我一直堅信好的工程師是不需要產品經理的。如果一個產品非要有一個什么產品經理的話,Google 的很多產品都不會出現,DropBox 這種只招聘工程師的公司也早就完蛋了。很多偉大的產品都是幾個工程師想到一個點子然后慢慢做出來的,比如 Paypal 和 Google. 但需要說明的是,我討厭產品經理并不是說我推崇“技術導向”——無論怎樣產品都應該是讓用戶使用的,而不是用來炫耀技術的,只不過工程師不需要產品經理也 可以設計好一個產品并且實現它。產品設計不是產品經理的專利。
想知道懂得設計的工程師沒有產品經理的時候可以做出什么東西嗎?去看一下
Livid 做的
V2EX 就知道了。在國內,設計和代碼都有品味的網站可不多,我覺得
Livid 同學真是開發工程師的典范。
接下來我們說一下“研發”。(未完待續)
1月7日消息,中國移動今日在國內率先推出業務扣費主動提醒和增值業務0000統一查詢退訂 兩項“透明消費”服務舉措,今后客戶訂購增值業務后,在扣費之前能夠得到短信提醒,且只要發送短信“0000”到10086,就能便捷查詢和退訂已訂購的 包月類增值業務,兩項服務均免費。據了解,中國移動此次推出的“業務扣費主動提醒”服務是一項基于客戶行為的主動提醒服務,是在業務訂購二次確認的基礎上開展的一項深化服務,主要面向客戶新訂購的業務。
在客戶確認訂購某項個人增值業務后,在扣減該增值業務費用前,中國移動會通過“10086”向訂購客戶發送提醒短信;客戶如有疑問,可根據短信提示方便地進 行投訴或直接退訂,對于客戶退訂的業務,不予收費。目前,該服務涵蓋絕大部分個人增值業務,只有極個別業務因為產業鏈技術原因,暫時未能實施。此外,當客 戶訂購或變更套餐時、以及次月套餐生效時,中國移動也會通過“10086”向客戶發送提醒短信。
“增值業務0000統一查詢退訂”服務,是一項針對客戶已訂購業務的便捷查詢退訂服務。客戶只要發送短信“0000”到10086,即可快速查詢到客戶截止目前訂購的除套餐內包含業務外的包月類增值業務,這包括中國移動的自有業務和合作業務,如手機報、歌曲下載、天氣預報等。此外,通過該服務還可查詢集團彩鈴、校訊通、農信通、手機郵箱等集團客戶常用的業務。根據業務查詢結果,客戶可方便快捷的根據短信提示退訂某項、多項或全部已訂購的業務。
目前,業務扣費主動提醒和增值業務0000統一查詢退訂兩項服務均免費向中國移動客戶提供。
新業務全國后臺支撐升級工作完畢
據悉,中國移動自2010年初就開始著手實施這項“透明消費”服務專項行動,歷時近一年時間,逐一梳理了758個自有業務以及20多萬個合作業務,并投入大量人力、物力對后臺支撐系統等進行了全面升級。
截至目前,中國移動全國31個省、自治區、直轄市公司已完成兩項“透明消費”服務舉措的后臺支撐系統升級工作。
中 國移動副總裁沙躍家表示,將逐步建立起全面的“透明消費”服務體系,推出業務扣費主動提醒和增值業務0000統一查詢退訂兩項服務舉措是建立全面“透明消 費”服務體系的關鍵一步。近期,中國移動還將開展帳單、詳單、發票信息優化工作,使帳單、詳單、發票信息更加清晰明了,不斷提升客戶感知。
導讀:面試準備的重要性不用編者多言,大家都很清楚。本文是加拿大的一位程序員所寫。大家可以看看國外程序員是怎么準備面試。不管你是否認同他的說法,《詩經》中有句話非常好——“它山之石,可以攻玉”。如果你還有其他面試準備方法,不妨在評論或微博中和大家一起分享。
一、開門見山
一般來說,你(求職者)在面試中會花很多時間談論以前的經歷。如果你還沒有想出你的最具代表性的經歷/案例,那么你現在是時候該做了。下面有張問題 表,雖然很多問題看似比較低級,但相信我,看完這些問題后,你應當反思自己。即便面試時沒有碰到類似這張列表上的問題,你在面試也可以用上已準備好的答 案。
- 1. 說說你自己吧
- 2. 你的短期目標是什么?你2到5年內的目標是什么?
- 3. 你的愿景/使命是什么?
- 4. 你想從這個崗位中學到什么?
- 5. 你為什么認為自己能勝任這個崗位?
- 6. 除了這個崗位,你還在找哪些崗位?
- 7. 你有什么樣的管理或領導經驗?
- 8. 你有什么樣的團隊工作經驗?
- 9. 你最滿意/不滿意的經歷是什么?
- 10. 你的強項/弱項是什么?
- 11. 你最擅長處理哪一類的問題?
- 12. 你是如何減壓?如何平衡工作和生活?
- 13. 如果他人提出的要求有違你的道德準則或商業道德,你怎么處理?
- 14. 你上次試圖向他人出售點子有什么樣的結果?
- 15. 你為什么要應聘我們公司?你對我們公司了解多少?
- 16. 你認為加入我們公司有什么樣的利弊?
- 17. 你最看重雇主的哪一方面?
- 18. 你過去遇到的主管有哪些共同點?
- 19. 如果要在競爭中保持領先,你認為我們公司的員工最需要哪些品質?
- 20. 你最喜歡/不喜歡什么課程?為什么?
- 21. 你的兼職/暑假/實習經歷中有什么收獲?
- 22. 你有什么樣的深造計劃?
- 23. 為什么你的成績這么低?
- 24. 你是如何打發空余時間的?
- 25. 如果我讓你的朋友們描述你,你覺得他們會怎么說呢?
- 26. 什么事最讓你沮喪?
- 27. 你上次在工作中遇到惱火的事是什么時候?結果如何?
- 28. 你如何提高你的整體效益?
- 29. 去年你遇到最艱難的決定是什么?為什么它很艱難?
- 30. 你為什么到現在還沒有找到工作?
- 31. 你在哪些方面沒有任何經驗?比如:銷售、籌款或者簿記。
- 32. 我們為什么要雇用你?
-
上面這個列表中的問題需要深思和反省才能回答,所以在下一次面試之前很有必要提前想一想。有些問題可以有相同的答案。如果問題答案需要講述一段故事/經歷,你可以按如下方式來做:
- 1. 20秒描述情況。“代碼出問題了,整個團隊必須找出原因。”
- 2. 30秒描述你做了什么。“我認為是內存溢出,我注意到AbstractMemberCreationFactory本應該只有一個實例,但它有很多實例”。
- 3. 20秒描述結果。“我用一行代碼解決溢出問題,我們的產品如期上線。后來,我都會先測試確保不會再有類似問題”。
在每次面試前,瀏覽整個列表并大聲練習你的回答。這樣做讓你在面試中更加輕松自如,你就比其他應聘者有更多的優勢。比如,當在回答問題時,其他應聘者可能會先看著天花板說“嗯”,然后開始回憶過去5年中發生的一切。而你則可以微笑地看著面試官的眼睛,再陳述你的答案。
二、事先練習最常用的編程算法,以建立自信
鋼琴家在達到下一級水平之前,他們必須先學習一套短曲。這些短曲雖然不曾在聚會上彈奏,但他們要練習特定的部分,比如右手小指和切分音。同理,盡管有些算法你或許沒有在你的代碼中用過,但它們經常在編程面試中出現。比如:
- 1. 反轉單鏈表;
- 2. 反轉字符串或反轉段落中的單詞順序;
- 3. 利用星號輸出畫一個任意大小的圓;
- 4. 整數轉換為字符串,數字型的字符串轉換為整數;
- 5. 寫一個函數,返回任意整數對應二進制形式中的“1”的個數;
- 6. 寫一個函數,輸出字符串中字符的所有排序。(比如:abc acb bac bca cab cba)
一般來說,可以先不考慮算法的運行時間,都是先用最簡單有效算法。然后再盡量減少運行時間。能讓算法正常跑起來,總比你花大量時間想一步到位要好。(一步到位的想法雖好,但大部分時候都是事倍功半。)
提示:
做練習時,別自欺欺人看答案。
我第一次寫“反轉單鏈表”算法是利用課間時間。我并不急,從運行時間較長的方案到優化的方案,我用了半個小時。在驗證算法正確無誤后,我非常高興!我知道不看答案我也能解決問題了。(建立自信了!)在面試中,當遇到從未見過的問題時,我以前的經驗給了我信心。
三、練習解決問題能力
有些應聘者認為能解決腦筋急轉彎問題就有良好的編程技能。如果你也這么認為,那你應當培養猜謎這方面的興趣和技巧。你可以去圖書館或在網上找這方面的書。然后,挑一些有趣的問題,先別看解答。如果半個小時之內還想不出答案的,才可以查閱解答。
第四、展現出真正的熱情
另一個技巧就是要把真正的熱情展現出來。作為人,我們應該真誠和熱情與他人共處工作。另一方面,我們也要有看穿虛假笑臉的能力(沒有這種能力,也需要鍛煉出來),所以活出真我很重要。
最優秀的面試官會讓你討論一些你非常熱衷的事情,即使有些些事和你所應聘的崗位沒有直接關系。然而,大多數面試官卻沒有這么做。雖然如此,你還是應當 好好考慮那些你非常感興趣的事,并且要抓住機會來和面試官討論一番。如果面試官允許的話,一定要在面試過程中的前段時間內完成,如果能在第一時間展現出來 更佳。面試開始10分鐘后的效果可能就不怎么樣了,因為面試官已經給你打分了。
想象一下:你第一天去新崗位工作,轉向新的開發平臺,遇到一些有趣的新朋友,并且了解了公司的生活。(總之)在公司中會有很多讓你興奮的事,要不然,你為什么去應聘呢?
五、睡眠/休息
如果你缺覺的話,“舌尖現象”則會急劇上升,導致你在面試中就不能很好回憶事情。所以,面試前必須有個良好的睡眠。 到底睡多長時間最合適呢?請參考此文《
你的睡眠時間和睡眠質量達標了么?》。
編者注:“舌尖現象”非常普遍,它是因為大腦對記憶內容的暫時性抑制所造成的。這種抑制來自于多方面,比如對有關事物的其他部分特征的回憶掩蓋了所要 回憶的那部分特征,又比如回憶時的情境因素以及自身情緒因素的干擾等等。而消除了抑制,(如經他人提示、離開回憶困難時的情境、消除緊張情緒等,)舌尖現 象往往就會消失。很多人都有過這樣的經歷:一些平時很簡單、很熟悉的字、單詞或公式等話到嘴邊就是無法記起,考試過后卻突然憶起。再比如,遇到一個熟人, 就是叫不出名字來。心理學上稱這種特殊現象為記憶的“舌尖現象”,意思是回憶的內容到了舌尖,只差一點,就是無法憶起。
本文出處:
伯樂在線 -
職場博客
本文鏈接:
http://www.jobbole.com/entry.php/253
Via:
Steve 編譯:
伯樂在線 敏捷翻譯組 - 關關
1、調用沒有返回值和參數的JAVA方法
1.1、dwr.xml的配置
<dwr>
<allow>
<create creator="new" javascript="testClass" >
<param name="class" value="com.dwr.TestClass" />
<include method="testMethod1"/>
</create>
</allow>
</dwr>
<allow>標簽中包括可以暴露給javascript訪問的東西。
<create>標簽中指定javascript中可以訪問的java類,并定義DWR應當如何獲得要進行遠程的類的實例。creator="new"屬性指定java類實例的生成方式,new意味著DWR應當調用類的默認構造函數來獲得實例,其他的還有spring方式,通過與IOC容器Spring進行集成來獲得實例等等。javascript=" testClass "屬性指定javascript代碼訪問對象時使用的名稱。
<param>標簽指定要公開給javascript的java類名。
<include>標簽指定要公開給javascript的方法。不指定的話就公開所有方法。
<exclude>標簽指定要防止被訪問的方法。
1.2、javascript中調用
首先,引入javascript腳本
<script src=‘dwr/interface/ testClass.js‘></script>
<script src=‘dwr/engine.js‘></script>
<script src=‘dwr/util.js‘></script>
其中TestClass.js是dwr根據配置文件自動生成的,engine.js和util.js是dwr自帶的腳本文件。
其次,編寫調用java方法的javascript函數
Function callTestMethod1(){
testClass.testMethod1();
}
2、調用有簡單返回值的java方法
2.1、dwr.xml的配置
配置同1.1
<dwr>
<allow>
<create creator="new" javascript="testClass" >
<param name="class" value="com.dwr.TestClass" />
<include method="testMethod2"/>
</create>
</allow>
</dwr>
2.2、javascript中調用
首先,引入javascript腳本
其次,編寫調用java方法的javascript函數和接收返回值的回調函數
Function callTestMethod2(){
testClass.testMethod2(callBackFortestMethod2);
}
Function callBackFortestMethod2(data){
//其中date接收方法的返回值
//可以在這里對返回值進行處理和顯示等等
alert("the return value is " + data);
}
其中callBackFortestMethod2是接收返回值的回調函數
3、調用有簡單參數的java方法
3.1、dwr.xml的配置
配置同1.1
<dwr>
<allow>
<create creator="new" javascript="testClass" >
<param name="class" value="com.dwr.TestClass" />
<include method="testMethod3"/>
</create>
</allow>
</dwr>
3.2、javascript中調用
首先,引入javascript腳本
其次,編寫調用java方法的javascript函數
Function callTestMethod3(){
//定義要傳到java方法中的參數
var data;
//構造參數
data = “test String”;
testClass.testMethod3(data);
}
4、調用返回JavaBean的java方法
4.1、dwr.xml的配置
<dwr>
<allow>
<create creator="new" javascript="testClass" >
<param name="class" value="com.dwr.TestClass" />
<include method="testMethod4"/>
</create>
<convert converter="bean" match=""com.dwr.TestBean">
<param name="include" value="username,password" />
</convert>
</allow>
</dwr>
<creator>標簽負責公開用于Web遠程的類和類的方法,<convertor>標簽則負責這些方法的參數和返回類型。convert元素的作用是告訴DWR在服務器端Java 對象表示和序列化的JavaScript之間如何轉換數據類型。DWR自動地在Java和JavaScript表示之間調整簡單數據類型。這些類型包括Java原生類型和它們各自的封裝類表示,還有String、Date、數組和集合類型。DWR也能把JavaBean轉換成JavaScript 表示,但是出于安全性的原因,要求顯式的配置,<convertor>標簽就是完成此功能的。converter="bean"屬性指定轉換的方式采用JavaBean命名規范,match=""com.dwr.TestBean"屬性指定要轉換的javabean名稱,<param>標簽指定要轉換的JavaBean屬性。
4.2、javascript中調用
首先,引入javascript腳本
其次,編寫調用java方法的javascript函數和接收返回值的回調函數
Function callTestMethod4(){
testClass.testMethod4(callBackFortestMethod4);
}
Function callBackFortestMethod4(data){
//其中date接收方法的返回值
//對于JavaBean返回值,有兩種方式處理
//不知道屬性名稱時,使用如下方法
for(var property in data){
alert("property:"+property);
alert(property+":"+data[property]);
}
//知道屬性名稱時,使用如下方法
alert(data.username);
alert(data.password);
}
其中callBackFortestMethod4是接收返回值的回調函數
5、調用有JavaBean參數的java方法
5.1、dwr.xml的配置
配置同4.1
<dwr>
<allow>
<create creator="new" javascript="testClass" >
<param name="class" value="com.dwr.TestClass" />
<include method="testMethod5"/>
</create>
<convert converter="bean" match="com.dwr.TestBean">
<param name="include" value="username,password" />
</convert>
</allow>
</dwr>
5.2、javascript中調用
首先,引入javascript腳本
其次,編寫調用java方法的javascript函數
Function callTestMethod5(){
//定義要傳到java方法中的參數
var data;
//構造參數,date實際上是一個object
data = { username:"user", password:"password" }
testClass.testMethod5(data);
}
6、調用返回List、Set或者Map的java方法
6.1、dwr.xml的配置
配置同4.1
<dwr>
<allow>
<create creator="new" javascript="testClass" >
<param name="class" value="com.dwr.TestClass" />
<include method="testMethod6"/>
</create>
<convert converter="bean" match="com.dwr.TestBean">
<param name="include" value="username,password" />
</convert>
</allow>
</dwr>
注意:如果List、Set或者Map中的元素均為簡單類型(包括其封裝類)或String、Date、數組和集合類型,則不需要<convert>標簽。
6.2、javascript中調用(以返回List為例,List的元素為TestBean)
首先,引入javascript腳本
其次,編寫調用java方法的javascript函數和接收返回值的回調函數
Function callTestMethod6(){
testClass.testMethod6(callBackFortestMethod6);
}
Function callBackFortestMethod6(data){
//其中date接收方法的返回值
//對于JavaBean返回值,有兩種方式處理
//不知道屬性名稱時,使用如下方法
for(var i=0;i<data.length;i++){
for(var property in data){
alert("property:"+property);
alert(property+":"+data[property]);
}
}
//知道屬性名稱時,使用如下方法
for(var i=0;i<data.length;i++){
alert(data.username);
alert(data.password);
}
}
7、調用有List、Set或者Map參數的java方法
7.1、dwr.xml的配置
<dwr>
<allow>
<create creator="new" javascript="testClass" >
<param name="class" value="com.dwr.TestClass" />
<include method="testMethod7"/>
</create>
<convert converter="bean" match="com.dwr.TestBean">
<param name="include" value="username,password" />
</convert>
</allow>
<signatures>
<![CDATA[
import java.util.List;
import com.dwr.TestClass;
import com.dwr.TestBean;
TestClass.testMethod7(List<TestBean>);
]]>
</signatures>
</dwr>
<signatures>標簽是用來聲明java方法中List、Set或者Map參數所包含的確切類,以便java代碼作出判斷。
7.2、javascript中調用(以返回List為例,List的元素為TestBean)
首先,引入javascript腳本
其次,編寫調用java方法的javascript函數
Function callTestMethod7(){
//定義要傳到java方法中的參數
var data;
//構造參數,date實際上是一個object數組,即數組的每個元素均為object
data = [
{
username:"user1",
password:"password2"
},
{
username:"user2",
password:" password2"
}
];
testClass.testMethod7(data);
}
注意:
1、對于第6種情況,如果java方法的返回值為Map,則在接收該返回值的javascript回調函數中如下處理:
function callBackFortestMethod(data){
//其中date接收方法的返回值
for(var property in data){
var bean = data[property];
alert(bean.username);
alert(bean.password);
}
}
2、對于第7種情況,如果java的方法的參數為Map(假設其key為String,value為TestBean),則在調用該方法的javascript函數中用如下方法構造要傳遞的參數:
function callTestMethod (){
//定義要傳到java方法中的參數
var data;
//構造參數,date實際上是一個object,其屬性名為Map的key,屬性值為Map的value
data = {
"key1":{
username:"user1",
password:"password2"
},
"key2":{
username:"user2",
password:" password2"
}
};
testClass.testMethod(data);
}
并且在dwr.xml中增加如下的配置段
<signatures>
<![CDATA[
import java.util.List;
import com.dwr.TestClass;
import com.dwr.TestBean;
TestClass.testMethod7(Map<String,TestBean>);
]]>
</signatures>
3、由以上可以發現,對于java方法的返回值為List(Set)的情況,DWR將其轉化為Object數組,傳遞個javascript;對于java方法的返回值為Map的情況,DWR將其轉化為一個Object,其中Object的屬性為原Map的key值,屬性值為原Map相應的value值。
4、如果java方法的參數為List(Set)和Map的情況,javascript中也要根據3種所說,構造相應的javascript數據來傳遞到java中。
xhEditor是一個基于jQuery開發的簡單迷你并且高效的輕量可視化XHTML編輯器,基于網絡訪問并且兼容IE 6.0+,Firefox 3.0+,Opera 9.6+,Chrome 1.0+,Safari 3.22+。此次v1.1.0版主要變化在于提升編輯器用戶體驗,在修正大量問題的基礎上增加了各種提升用戶體驗的實用功能,例如HTML5功能支持下的直接將文件拖入編輯區域上傳功能,就能極大的提高用戶操作效率,改善使用體驗。
我們不是最好的,但是我們會努力做的更好,我們愿意傾聽和接受所有用戶的心聲。最后,大家在使用過程中若發現任何的問題,或者有比較好的創意和想法,可以隨時向我們反饋(yanis.wang@gmail.com),我們會隨時傾聽大家的意見,xhEditor的發展離不開大家的支持。
本次v1.1.0版本主要變化如下:
1,可自定義表情根路徑(emotPath參數)
2,提供本地圖片等資源文件的前后臺路徑不一致問題的解決方案(urlBase參數)
3,雙擊鏈接、圖片等直接打開修改界面
4,Word代碼粘貼過濾功能由原先的IE only改為跨瀏覽器兼容
5,強制粘貼為文本功能(forcePasteText參數)
6,將本地電腦直接拖入編輯區域即可上傳在當前光標處,此功能需要HTML5上傳支持(Firefox,Chrome)
完整更新列表如下:
ver 1.1.0 (2010-9-1)
1. 添加:添加由網友shiny原創設計的皮膚NoStyle
2. 添加:demo07 UBB演示頁面添加Google地圖插件,也作為不定寬按鈕的演示
3. 添加:添加urlType轉非相對路徑中合并“..”到上一級路徑的功能
4. 添加:添加emotPath初始化參數,以將表情指向其它自定義URL路徑下,注意路徑必需以“/”結尾
5. 添加:添加urlBase初始化參數,用來定義超鏈接、圖片及Flash等文件的相對根路徑,同時也是urlType參數的參考根路徑
6. 添加:經用戶反饋意見,重新添加“預覽”功能按鈕
7. 添加:添加雙擊超鏈接、圖片、Flash和多媒體可直接打開相應修改界面的功能,注:某些瀏覽器雙擊Flash和多媒體會有問題
8. 添加:打開面板時可按Esc鍵隱藏當前的面板
9. 添加:初始化參數添加disableContextmenu,用以禁用瀏覽器在編輯區域的默認右鍵菜單,設置為true禁用,默認不禁用
10.添加:Word粘貼自動過濾功能由原先的IE only增加為跨瀏覽器兼容
11.添加:添加強制粘貼為文本功能,初始化參數forcePasteText設置為true開啟此功能,默認不強制文本
12.添加:添加Pidgin和IPB兩套表情,并在demo05和demo07中添加相應的配置演示
13.添加:初始化參數添加editorRoot,在某些特殊情況下定位編輯器的根路徑
14.添加:將本地電腦中的多個文件拖放至編輯器的編輯區即可上傳并插入,此功能需要瀏覽器支持HTML5上傳(Firefox,Chrome)
1. 修正:showIframeModal上傳模式下onUpload接口無效問題的修正
2. 修正:使用無效按鈕名稱會導致JS出錯問題的修正
3. 修正:IE6,IE7在iframe框架中使用xhEditor會在頁面中出現_xhe_cursor問題的修正
4. 修正:IE瀏覽器在圖片、FLASH等控件上按Backspace會導致整個頁面后退問題的修正
5. 修正:回車BR模式在IE瀏覽器下,按下回車只顯示一個空格不換行問題的修正
6. 修正:IE瀏覽器中會造成內存泄漏問題的修正
7. 修正:WebKit內核瀏覽器回車換行在切換一次源代碼后會丟失問題的修正
1. 調整:皮膚框架進行了調整,支持不定寬按鈕,需要的用戶可自行設計修改
2. 調整:為使按鈕配置更直觀簡便,原按鈕分隔符Separator變更為“|”,原按鈕換行符BtnBr變更為“/”
3. 調整:原localUrl參數名變更為urlType
查看最新版演示:http://xheditor.com/demo
更多官方在線演示:
1. 默認模式:http://xheditor.com/demos/demo01.html
2. 自定義按鈕:http://xheditor.com/demos/demo02.html
3. 皮膚選擇:http://xheditor.com/demos/demo03.html
4. 其它選項:http://xheditor.com/demos/demo04.html
5. Javascript交互:http://xheditor.com/demos/demo05.html
6. 非utf-8編碼網頁調用:http://xheditor.com/demos/demo06.html
7. UBB可視化編輯:http://xheditor.com/demos/demo07.html
8. Ajax文件上傳:http://xheditor.com/demos/demo08.html
9. 插件擴展:http://xheditor.com/demos/demo09.html
10.iframe調用文件上傳:http://xheditor.com/demos/demo10.html
11.異步加載:http://xheditor.com/demos/demo11.html
最新v1.1.0下載地址:
http://xheditor.com/download
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<title>
exmpall
</title>
<meta content="text/html; charset=utf-8" http-equiv="content-type"/>
<STYLE type="text/css">
div{
padding: 0;
margin: 0;
position: absolute;
left:200px; /*左邊*/
top:0; /*上面*/
display: none;
width: 180px;
height: 150px;
border-style: solid;
border-color: #E6C963;
border-width: thin;
}
</STYLE>
<SCRIPT TYPE="text/javascript">
<!--
function myfunction1()
{
var my=document.getElementById("chenyi");
my.style.position = "absolute";
my.style.top = "50px"; /*上面*/
my.style.display = "inline";
my.style.backgroundColor = "#E4A17C";
}
function myfunction2()
{
var my=document.getElementById("chenyi");
my.style.position = "absolute";
my.style.top = "150px"; /*上面*/
my.style.display = "inline";
my.style.backgroundColor = "#A3935F";
}
function myfunction3()
{
var my=document.getElementById("chenyi");
my.style.position = "absolute";
my.style.top = "200px"; /*上面*/
my.style.display = "inline";
my.style.backgroundColor = "#79851A";
}
function myfunction4()
{
var my=document.getElementById("chenyi");
my.style.position = "absolute";
my.style.top = "300px"; /*上面*/
my.style.display = "inline";
my.style.backgroundColor = "#ACACA9";
}
function myfunction5()
{
var my=document.getElementById("chenyi");
my.style.position = "absolute";
my.style.top = "400px"; /*上面*/
my.style.display = "inline";
my.style.backgroundColor = "#B38DD9";
}
// -->
</SCRIPT>
</head>
<body>
<FORM method="post" action="">
<br /><br />
<INPUT name="text1" type="text" onmouseover="myfunction1()"><br /><br /><br /><br />
<INPUT name="text2" type="text" onmouseover="myfunction2()"><br /><br /><br /><br />
<INPUT name="text3" type="text" onmouseover="myfunction3()"><br /><br /><br /><br />
<INPUT name="text4" type="text" onmouseover="myfunction4()"><br /><br /><br /><br />
<INPUT name="text5" type="text" onmouseover="myfunction5()"><br /><br />
</FORM>
<div id="chenyi">
<ol>
<li><a >高興</a></li>
<li>php</li>
<li>asp.net</li>
<li>javaEE</li>
<li>javascript</li>
</ol>
</div>
</body>
</html>
一個屢獲大獎的專業 PHP 集成開發環境,具備功能強大的專業編輯工具和調試工具,支持PHP語法加亮顯示,支持語 法自動填充功能,支持書簽功能,支持語法自動縮排和代碼復制功能,內置一個強大的PHP代碼調試工具,支持本地和遠程兩種調試模式,支持多種高級調試功 能。
New! in Studio V7.2.1:
Software Updates:
* Zend Framework 1.10.6
Resolved Tickets:
* Ticket 187947 - The Zend Framework Example project is configured with the correct buildpath entries
* Ticket 187838 - If one of the parameters is a function call parameter, the hint tooltip now shows the right hint
* Ticket 188440 - The Processing Dirty Regions error is no longer triggered with java.lang.StackOverflowError exception
* Ticket 187975 - The Zend Framework Tool no longer fails with the error "No tokenizer support"
* Ticket 188418 - In ODBC, db2 related functions are now shown in PHP Language libraries
* Ticket 186867 - The Zend Tool error "A project profile was not found" no longer appears
Resolved Bugs:
* 30047 - In the Registration dialog, the "User Name / " section has been removed, with the "Order #" section remaining in its place
* 30155 - The Semantic analyzer no longer shows an error/warning for duplicate class constants
* 30046 - To help troubleshoot Zend Studio issues, you can now add a "showlocation" flag to the ZendStudio.ini (on Windows and Linux)
Homepage - http://www.zend.com/en/products/studio/
Size: 316 MB
下載:Zend Studio 7.2.1
下載:Zend Studio 7.2.1 (IBM 1)
如 果平時主要開發控制臺類、組件、后端服務等程序,可以嘗試在Linux類操作系統下搭建C#.Net開發環境,好處是在Linux環境里你不用擔心朋友或同事拿你的電腦來玩魔獸世界或者一不小心被裝了一大堆流氓軟件 ;-)先看看本篇文章最終效果:在 Ubuntu 里跑的開發環境 MonoDevelop:
如 果平時主要開發控制臺類、組件、后端服務等程序,可以嘗試在Linux類操作系統下搭建C#.Net開發環境,好處是在Linux環境里你不用擔心朋友或 同事拿你的電腦來玩魔獸世界或者一不小心被裝了一大堆流氓軟件 ;-)
1、Linux發行版的選擇
在Linuxux操作系統里只要安裝Mono環 境就可以開發C#程序,Linux的眾多發行版RedHat/CentOS/Fedora、OpenSuse、Debian、Ubuntu都可以安裝 Mono。
鑒于 目前 Ubuntu 容易安裝、界面漂亮而且比較多人用作桌面環境,所以這里推薦使用 Ubuntu 10.04 。官方網站是:http://www.ubuntu.com/
在官方網站下載回來的是一個光盤映像文件 (ISO格式),這里需要注意的是 Ubuntu 共有4個不同版本的ISO文件:Desktop版、Alternative版、Netbook版、 Server版。一般下載Desktop就可以了。如果你想通過網絡啟動安裝程序或者使用硬盤安裝則需要下載Alternative版。
如果你的電腦硬件配置比較低(內存少于等于 512MB),還可以下載一個輕量級的衍生版:Xubuntu(http://www.xubuntu.org/),如果你的電腦只有256MB內存,那還可以 下載另一個衍生版Lubuntu(http://lubuntu.net/),這個更加輕量級,平時系統啟動后只占用 70~100MB內存。
2、安裝Ubuntu
安裝Ubuntu 的方法非常簡單,跟裝 WinXP差不多,只需點5,6次“下一步”過10來分鐘就可以完成。因為關于安裝Ubuntu的過程已經有大量的文章介紹,這里就不再贅述了,下面主要 列舉一下安裝方式,大家可以根據自己的具體情況選擇合適的:
(1)虛擬機安裝
如果你的電腦速度飛快,內存比較大,用這種方式安裝最快,虛擬機軟件推薦使用免費 的 VirtualBox。先裝好虛擬機軟件,然后創建一個新的虛擬機,把下載回來的 ISO文件掛靠到虛擬機,啟動之后就可以安裝了。
(2)嘗試性安裝
如果你僅僅想嘗試一下在Linux環境開發C# 的感覺,并不打算長期使用,則可以使用這種安裝模式。這種安裝模式不需要調整硬盤分區(因為整個Linux將安裝到一個“虛擬硬盤”文件里頭)、不會弄壞 你的現有的系統和軟件,只是性能會稍微減低一些。
首先你的系統必須是WinXP/Vista/Win7,然后把ISO文件和一個 Wubi Installer (http://wubi-installer.org/) 的軟件放在同一個目錄,運行 Wubi installer,選擇Ubuntu的安裝位置,然后就開始復制文件了,重啟計算機會多出一項啟動項“Ubuntu install”,選擇 它就開始真正的安裝過程了。
下 面的安裝方式需要先在硬盤騰出一塊空白的空間(最好準備至少10GB),主分區以外的自由空間或者擴展分區的自由空間都可以,你可以用PQMagic軟件慢慢 調整自己硬盤的分區大小。在安裝過程中程序會詢問你將Ubuntu安裝在何處,選擇使用“最大連續空間”即可。
(3)光盤安裝
這種安裝方式最簡單,將下載回來的ISO文件刻 錄成光盤,設置從光盤啟動并重啟計算機。
(4) 硬盤安裝
要下載Alternative版的ISO文件, 放到C盤根目錄,然后下載“UNetbootin
”(http://unetbootin.sourceforge.net/)軟件,也放在C盤根目錄,運 行 UNetbootin,在發行版類型項選擇Ubuntu和MediaHD即開始復制文件,重啟電腦開始安裝。
(5)用U盤安裝/安裝到U盤
先使用安裝光盤啟動計算機,選擇“試用”進入 LiveCD模式的Ubuntu,然后在“系統”->“系統管理”點擊“制作啟動盤”,準備一個1GB以上的U盤,啟動盤制作程序會把Ubuntu 的所有文件復制到U盤,然后就可以使用這個U盤啟動其他電腦并安裝系統了。也可以直接從這個U盤啟動進入系統。
(6)通過網絡安裝
如果你的電腦沒有光驅也不支持U盤啟動,而帶有 從網卡啟動(PXE)功能。或者有一批電腦需要批量安裝,則可以使用這種安裝模式,具體的請見:http://kalashnicov.javaeye.com/blog/663337
3、安裝開發環境 MonoDevelop
安裝好Ubuntu 10.04之后會發現系統已經自帶Mono運行和編譯環境,而且還有部分Ubuntu系統自帶的軟件是C#寫的,比如tomboy便利帖、IQ測試游戲gbrainy、照片查看和管理程序F-Spot
如果你已經習慣了Win7的任務欄,推薦另外一 個任務欄軟件“Docky”,它也是C#寫的
MacOS的同學請淡定。
記住在Ubuntu里安裝軟件是不需要去什么軟 件下載網站的,所有需要的軟件都可以在“Ubuntu軟件中心”找到、安裝、卸載。
運行“Ubuntu軟件中心”,輸入需要安裝的軟件名稱,比如 “MonoDevelop”,然后點擊“安裝”,程序會自動上網下載并安裝。
好了,現在就已經搭建好C#開發環境了,試試寫一個HelloWorld吧(效果圖 片見文章開頭處)
4、其他
MonoDevelop除了能寫C#程序之外, 還能寫C,C++,Java等程序,只要安裝相應的插件和編譯器即可,
附錄:
mono項目主頁: http://mono-project.com
控制臺、窗口、Web的HelloWorld演示程序:http://mono-project.com/Mono_Basics
mono 與 ms.net 的兼容性列表: http://mono-project.com/Compatibility