--sunfruit
介紹了JAVA的反射機制,比較全面
Java Reflection (JAVA反射)
Reflection 是 Java 程序開發語言的特征之一,它允許運行中的 Java 程序對自身進行檢查,或者說“自審”,并能直接操作程序的內部屬性。例如,使用它能獲得 Java 類中各成員的名稱并顯示出來。
Java 的這一能力在實際應用中也許用得不是很多,但是在其它的程序設計語言中根本就不存在這一特性。例如,Pascal、C 或者 C++ 中就沒有辦法在程序中獲得函數定義相關的信息。
JavaBean 是 reflection 的實際應用之一,它能讓一些工具可視化的操作軟件組件。這些工具通過 reflection 動態的載入并取得 Java 組件(類) 的屬性。
1. 一個簡單的例子
考慮下面這個簡單的例子,讓我們看看 reflection 是如何工作的。
import java.lang.reflect.*;
public class DumpMethods {
public static void main(String args[]) {
try {
Class c = Class.forName(args[0]);
Method m[] = c.getDeclaredMethods();
for (int i = 0; i < m.length; i++)
System.out.println(m[i].toString());
} catch (Throwable e) {
System.err.println(e);
}
}
}
按如下語句執行:
java DumpMethods java.util.Stack
它的結果輸出為:
public java.lang.Object java.util.Stack.push(java.lang.Object)
public synchronized java.lang.Object java.util.Stack.pop()
public synchronized java.lang.Object java.util.Stack.peek()
public boolean java.util.Stack.empty()
public synchronized int java.util.Stack.search(java.lang.Object)
這樣就列出了java.util.Stack 類的各方法名以及它們的限制符和返回類型。
這個程序使用 Class.forName 載入指定的類,然后調用 getDeclaredMethods 來獲取這個類中定義了的方法列表。java.lang.reflect.Methods 是用來描述某個類中單個方法的一個類。
2.開始使用 Reflection
用于 reflection 的類,如 Method,可以在 java.lang.relfect 包中找到。使用這些類的時候必須要遵循三個步驟:第一步是獲得你想操作的類的 java.lang.Class 對象。在運行中的 Java 程序中,用 java.lang.Class 類來描述類和接口等。
下面就是獲得一個 Class 對象的方法之一:
Class c = Class.forName("java.lang.String");
這條語句得到一個 String 類的類對象。還有另一種方法,如下面的語句:
Class c = int.class;
或者
Class c = Integer.TYPE;
它們可獲得基本類型的類信息。其中后一種方法中訪問的是基本類型的封裝類 (如 Integer) 中預先定義好的 TYPE 字段。
第二步是調用諸如 getDeclaredMethods 的方法,以取得該類中定義的所有方法的列表。
一旦取得這個信息,就可以進行第三步了——使用 reflection API 來操作這些信息,如下面這段代碼:
Class c = Class.forName("java.lang.String");
Method m[] = c.getDeclaredMethods();
System.out.println(m[0].toString());
它將以文本方式打印出 String 中定義的第一個方法的原型。
在下面的例子中,這三個步驟將為使用 reflection 處理特殊應用程序提供例證。
模擬 instanceof 操作符
得到類信息之后,通常下一個步驟就是解決關于 Class 對象的一些基本的問題。例如,Class.isInstance 方法可以用于模擬 instanceof 操作符:
class A {
}
public class instance1 {
public static void main(String args[]) {
try {
Class cls = Class.forName("A");
boolean b1 = cls.isInstance(new Integer(37));
System.out.println(b1);
boolean b2 = cls.isInstance(new A());
System.out.println(b2);
} catch (Throwable e) {
System.err.println(e);
}
}
}
在這個例子中創建了一個 A 類的 Class 對象,然后檢查一些對象是否是 A 的實例。Integer(37) 不是,但 new A() 是。
3.找出類的方法
找出一個類中定義了些什么方法,這是一個非常有價值也非常基礎的 reflection 用法。下面的代碼就實現了這一用法:
import java.lang.reflect.*;
public class method1 {
private int f1(Object p, int x) throws NullPointerException {
if (p == null)
throw new NullPointerException();
return x;
}
public static void main(String args[]) {
try {
Class cls = Class.forName("method1");
Method methlist[] = cls.getDeclaredMethods();
for (int i = 0; i < methlist.length; i++) {
Method m = methlist[i];
System.out.println("name = " + m.getName());
System.out.println("decl class = " + m.getDeclaringClass());
Class pvec[] = m.getParameterTypes();
for (int j = 0; j < pvec.length; j++)
System.out.println("param #" + j + " " + pvec[j]);
Class evec[] = m.getExceptionTypes();
for (int j = 0; j < evec.length; j++)
System.out.println("exc #" + j + " " + evec[j]);
System.out.println("return type = " + m.getReturnType());
System.out.println("-----");
}
} catch (Throwable e) {
System.err.println(e);
}
}
}
這個程序首先取得 method1 類的描述,然后調用 getDeclaredMethods 來獲取一系列的 Method 對象,它們分別描述了定義在類中的每一個方法,包括 public 方法、protected 方法、package 方法和 private 方法等。如果你在程序中使用 getMethods 來代替 getDeclaredMethods,你還能獲得繼承來的各個方法的信息。
取得了 Method 對象列表之后,要顯示這些方法的參數類型、異常類型和返回值類型等就不難了。這些類型是基本類型還是類類型,都可以由描述類的對象按順序給出。
輸出的結果如下:
name = f1
decl class = class method1
param #0 class java.lang.Object
param #1 int
exc #0 class java.lang.NullPointerException
return type = int
-----
name = main
decl class = class method1
param #0 class [Ljava.lang.String;
return type = void
-----
4.獲取構造器信息
獲取類構造器的用法與上述獲取方法的用法類似,如:
import java.lang.reflect.*;
public class constructor1 {
public constructor1() {
}
protected constructor1(int i, double d) {
}
public static void main(String args[]) {
try {
Class cls = Class.forName("constructor1");
Constructor ctorlist[] = cls.getDeclaredConstructors();
for (int i = 0; i < ctorlist.length; i++) {
Constructor ct = ctorlist[i];
System.out.println("name = " + ct.getName());
System.out.println("decl class = " + ct.getDeclaringClass());
Class pvec[] = ct.getParameterTypes();
for (int j = 0; j < pvec.length; j++)
System.out.println("param #" + j + " " + pvec[j]);
Class evec[] = ct.getExceptionTypes();
for (int j = 0; j < evec.length; j++)
System.out.println("exc #" + j + " " + evec[j]);
System.out.println("-----");
}
} catch (Throwable e) {
System.err.println(e);
}
}
}
這個例子中沒能獲得返回類型的相關信息,那是因為構造器沒有返回類型。
這個程序運行的結果是:
name = constructor1
decl class = class constructor1
-----
name = constructor1
decl class = class constructor1
param #0 int
param #1 double
-----
5.獲取類的字段(域)
找出一個類中定義了哪些數據字段也是可能的,下面的代碼就在干這個事情:
import java.lang.reflect.*;
public class field1 {
private double d;
public static final int i = 37;
String s = "testing";
public static void main(String args[]) {
try {
Class cls = Class.forName("field1");
Field fieldlist[] = cls.getDeclaredFields();
for (int i = 0; i < fieldlist.length; i++) {
Field fld = fieldlist[i];
System.out.println("name = " + fld.getName());
System.out.println("decl class = " + fld.getDeclaringClass());
System.out.println("type = " + fld.getType());
int mod = fld.getModifiers();
System.out.println("modifiers = " + Modifier.toString(mod));
System.out.println("-----");
}
} catch (Throwable e) {
System.err.println(e);
}
}
}
這個例子和前面那個例子非常相似。例中使用了一個新東西 Modifier,它也是一個 reflection 類,用來描述字段成員的修飾語,如“private int”。這些修飾語自身由整數描述,而且使用 Modifier.toString 來返回以“官方”順序排列的字符串描述 (如“static”在“final”之前)。這個程序的輸出是:
name = d
decl class = class field1
type = double
modifiers = private
-----
name = i
decl class = class field1
type = int
modifiers = public static final
-----
name = s
decl class = class field1
type = class java.lang.String
modifiers =
-----
和獲取方法的情況一下,獲取字段的時候也可以只取得在當前類中申明了的字段信息 (getDeclaredFields),或者也可以取得父類中定義的字段 (getFields) 。
6.根據方法的名稱來執行方法
文本到這里,所舉的例子無一例外都與如何獲取類的信息有關。我們也可以用 reflection 來做一些其它的事情,比如執行一個指定了名稱的方法。下面的示例演示了這一操作:
import java.lang.reflect.*;
public class method2 {
public int add(int a, int b) {
return a + b;
}
public static void main(String args[]) {
try {
Class cls = Class.forName("method2");
Class partypes[] = new Class[2];
partypes[0] = Integer.TYPE;
partypes[1] = Integer.TYPE;
Method meth = cls.getMethod("add", partypes);
method2 methobj = new method2();
Object arglist[] = new Object[2];
arglist[0] = new Integer(37);
arglist[1] = new Integer(47);
Object retobj = meth.invoke(methobj, arglist);
Integer retval = (Integer) retobj;
System.out.println(retval.intvalue());
} catch (Throwable e) {
System.err.println(e);
}
}
}
假如一個程序在執行的某處的時候才知道需要執行某個方法,這個方法的名稱是在程序的運行過程中指定的 (例如,JavaBean 開發環境中就會做這樣的事),那么上面的程序演示了如何做到。
上例中,getMethod 用于查找一個具有兩個整型參數且名為 add 的方法。找到該方法并創建了相應的 Method 對象之后,在正確的對象實例中執行它。執行該方法的時候,需要提供一個參數列表,這在上例中是分別包裝了整數 37 和 47 的兩個 Integer 對象。執行方法的返回的同樣是一個 Integer 對象,它封裝了返回值 84。
7.創建新的對象
對于構造器,則不能像執行方法那樣進行,因為執行一個構造器就意味著創建了一個新的對象 (準確的說,創建一個對象的過程包括分配內存和構造對象)。所以,與上例最相似的例子如下:
import java.lang.reflect.*;
public class constructor2 {
public constructor2() {
}
public constructor2(int a, int b) {
System.out.println("a = " + a + " b = " + b);
}
public static void main(String args[]) {
try {
Class cls = Class.forName("constructor2");
Class partypes[] = new Class[2];
partypes[0] = Integer.TYPE;
partypes[1] = Integer.TYPE;
Constructor ct = cls.getConstructor(partypes);
Object arglist[] = new Object[2];
arglist[0] = new Integer(37);
arglist[1] = new Integer(47);
Object retobj = ct.newInstance(arglist);
} catch (Throwable e) {
System.err.println(e);
}
}
}
根據指定的參數類型找到相應的構造函數并執行它,以創建一個新的對象實例。使用這種方法可以在程序運行時動態地創建對象,而不是在編譯的時候創建對象,這一點非常有價值。
8.改變字段(域)的值
reflection 的還有一個用處就是改變對象數據字段的值。reflection 可以從正在運行的程序中根據名稱找到對象的字段并改變它,下面的例子可以說明這一點:
import java.lang.reflect.*;
public class field2 {
public double d;
public static void main(String args[]) {
try {
Class cls = Class.forName("field2");
Field fld = cls.getField("d");
field2 f2obj = new field2();
System.out.println("d = " + f2obj.d);
fld.setDouble(f2obj, 12.34);
System.out.println("d = " + f2obj.d);
} catch (Throwable e) {
System.err.println(e);
}
}
}
這個例子中,字段 d 的值被變為了 12.34。
9.使用數組
本文介紹的 reflection 的最后一種用法是創建的操作數組。數組在 Java 語言中是一種特殊的類類型,一個數組的引用可以賦給 Object 引用。觀察下面的例子看看數組是怎么工作的:
import java.lang.reflect.*;
public class array1 {
public static void main(String args[]) {
try {
Class cls = Class.forName("java.lang.String");
Object arr = Array.newInstance(cls, 10);
Array.set(arr, 5, "this is a test");
String s = (String) Array.get(arr, 5);
System.out.println(s);
} catch (Throwable e) {
System.err.println(e);
}
}
}
例中創建了 10 個單位長度的 String 數組,為第 5 個位置的字符串賦了值,最后將這個字符串從數組中取得并打印了出來。
下面這段代碼提供了一個更復雜的例子:
import java.lang.reflect.*;
public class array2 {
public static void main(String args[]) {
int dims[] = new int[]{5, 10, 15};
Object arr = Array.newInstance(Integer.TYPE, dims);
Object arrobj = Array.get(arr, 3);
Class cls = arrobj.getClass().getComponentType();
System.out.println(cls);
arrobj = Array.get(arrobj, 5);
Array.setInt(arrobj, 10, 37);
int arrcast[][][] = (int[][][]) arr;
System.out.println(arrcast[3][5][10]);
}
}
例中創建了一個 5 x 10 x 15 的整型數組,并為處于 [3][5][10] 的元素賦了值為 37。注意,多維數組實際上就是數組的數組,例如,第一個 Array.get 之后,arrobj 是一個 10 x 15 的數組。進而取得其中的一個元素,即長度為 15 的數組,并使用 Array.setInt 為它的第 10 個元素賦值。
注意創建數組時的類型是動態的,在編譯時并不知道其類型。
--sunfruit
提供了獲得漢字的拼音首字母的方法
JDK版本 無版本限制
功能 實現了獲得一個漢字的拼音首字母功能,為漢字排序提供了方便
歡迎大家提意見,交流
代碼如下:
/**
* Title:獲得漢字的拼音首字母
* Description: GB 2312-80 把收錄的漢字分成兩級。第一級漢字是常用漢字,計 3755 個,
* 置于 16~55 區,按漢語拼音字母/筆形順序排列;第二級漢字是次常用漢字,
* 計 3008 個,置于 56~87 區,按部首/筆畫順序排列,所以本程序只能查到
* 對一級漢字的聲母。同時對符合聲母(zh,ch,sh)只能取首字母(z,c,s)
* Copyright: Copyright (c) 2004
* Company:
* @author not attributable
* @version 1.0
*/
public class GetFirstLetter {
// 國標碼和區位碼轉換常量
private static final int GB_SP_DIFF = 160;
//存放國標一級漢字不同讀音的起始區位碼
private static final int[] secPosvalueList = {
1601, 1637, 1833, 2078, 2274, 2302, 2433, 2594, 2787,
3106, 3212, 3472, 3635, 3722, 3730, 3858, 4027, 4086,
4390, 4558, 4684, 4925, 5249, 5600};
//存放國標一級漢字不同讀音的起始區位碼對應讀音
private static final char[] firstLetter = {
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'j',
'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's',
't', 'w', 'x', 'y', 'z'};
//獲取一個字符串的拼音碼
public static String getFirstLetter(String oriStr) {
String str = oriStr.toLowerCase();
StringBuffer buffer = new StringBuffer();
char ch;
char[] temp;
for (int i = 0; i < str.length(); i++) { //依次處理str中每個字符
ch = str.charAt(i);
temp = new char[] {
ch};
byte[] uniCode = new String(temp).getBytes();
if (uniCode[0] < 128 && uniCode[0] > 0) { // 非漢字
buffer.append(temp);
}
else {
buffer.append(convert(uniCode));
}
}
return buffer.toString();
}
/** 獲取一個漢字的拼音首字母。
* GB碼兩個字節分別減去160,轉換成10進制碼組合就可以得到區位碼
* 例如漢字"你"的GB碼是0xC4/0xE3,分別減去0xA0(160)就是0x24/0x43
* 0x24轉成10進制就是36,0x43是67,那么它的區位碼就是3667,在對照表中讀音為‘n'
*/
private static char convert(byte[] bytes) {
char result = '-';
int secPosvalue = 0;
int i;
for (i = 0; i < bytes.length; i++) {
bytes[i] -= GB_SP_DIFF;
}
secPosvalue = bytes[0] * 100 + bytes[1];
for (i = 0; i < 23; i++) {
if (secPosvalue >= secPosvalueList[i] &&
secPosvalue < secPosvalueList[i + 1]) {
result = firstLetter[i];
break;
}
}
return result;
}
}
--sunfruit
在面試的時候會問及如何不用第三個變量來交換a,b的值,下面給出答案
a=a^b;
b=b^a;
a=a^b;
使用了位操作,至于為什么可以,列舉下面的示例你就會明白
1^1=0;
0^0=0;
1^0=1;
0^1=1;
是不是明白了,呵呵,要是面試的時候再有人問你你就可以從容的回答了,而且不怕他問為什么
--sunfruit
一段令人深有感觸地話
一個老工程師的話
諸位,咱當電子工程師也是十余年了,不算有出息,環顧四周,也沒有看見幾個有出息的!回顧工程師生涯,感慨萬千,愿意講幾句掏心窩子的話,也算給咱們師弟師妹們提個醒,希望他們比咱們強!
[1]好好規劃自己的路,不要跟著感覺走!根據個人的理想決策安排,絕大部分人并不指望成為什么院士或教授,而是希望活得滋潤一些,爽一些。那么,就需要慎重安排自己的軌跡。從哪個行業入手,逐漸對該行業深入了解,不要頻繁跳槽,特別是不要為了一點工資而轉移陣地,從長遠看,這點錢根本不算什么,當你對一個行業有那么幾年的體會,以后錢根本不是問題。頻繁地動蕩不是上策,最后你對哪個行業都沒有摸透,永遠是新手!
[2]可以做技術,切不可沉湎于技術。千萬不可一門心思鉆研技術!給自己很大壓力,如果你的心思全部放在這上面,那么注定你將成為孔乙己一類的人物!適可而止為之,因為技術只不過是你今后前途的支柱之一,而且還不是最大的支柱
[3]不要去做技術高手,只去做綜合素質高手!在企業里混,我們時常瞧不起某人,說他“什么都不懂,憑啥拿那么多錢,憑啥升官!”這是普遍的典型的工程師的迂腐之言。8051很牛嗎?人家能上去必然有他的本事,而且是你沒有的本事。你想想,老板搞經營那么多年,難道見識不如你這個新兵?人家或許善于管理,善于領會老板意圖,善于部門協調等等。因此務必培養自己多方面的能力,包括管理,親和力,察言觀色能力,攻關能力等,要成為綜合素質的高手,則前途無量,否則只能躲在角落看示波器!技術以外的技能才是更重要的本事!!從古到今,美國日本,一律如此!
[4]多交社會三教九流的朋友!不要只和工程師交往,認為有共同語言,其實更重要的是和其他類人物交往,如果你希望有朝一日當老板或高層管理,那么你整日面對的就是這些人。了解他們的經歷,思維習慣,愛好,學習他們處理問題的模式,了解社會各個角落的現象和問題,這是以后發展的巨大的本錢
[6]抓住時機向技術管理或市場銷售方面的轉變!要想有前途就不能一直搞開發,適當時候要轉變為管理或銷售,前途會更大,以前搞技術也沒有白搞,以后還用得著。搞管理可以培養自己的領導能力,搞銷售可以培養自己的市場概念和思維,同時為自己以后發展積累龐大的人脈!應該說這才是前途的真正支柱!!!
[7]逐漸克服自己的心里弱點和性格缺陷!多疑,敏感,天真(貶義,并不可愛),猶豫不決,膽怯,多慮,臉皮太薄,心不夠黑,教條式思維。。。這些工程師普遍存在的性格弱點必須改變!很難嗎?只在床上想一想當然不可能,去幫朋友守一個月地攤,包準有效果,去實踐,而不要只想!不克服這些缺點,一切不可能,甚至連項目經理都當不好--盡管你可能技術不錯!
[8]工作的同時要為以后做準備!建立自己的工作環境!及早為自己配置一個工作環境,裝備電腦,示波器(可以買個二手的),仿真器,編程器等,業余可以接點活,一方面接觸市場,培養市場感覺,同時也積累資金,更重要的是準備自己的產品,咱搞技術的沒有錢,只有技術,技術的代表不是學歷和證書,而是產品,拿出象樣的產品,就可技術轉讓或與人合作搞企業!先把東西準備好,等待機會,否則,有了機會也抓不住!
[9]要學會善于推銷自己!不僅要能干,還要能說,能寫,善于利用一切機會推銷自己,樹立自己的品牌形象,很必要!要創造條件讓別人了解自己,不然老板怎么知道你能干?外面的投資人怎么相信你?提早把自己推銷出去,機會自然會來找你!搞個個人主頁是個好注意!!特別是培養自己在行業的名氣,有了名氣,高薪機會自不在話下,更重要的是有合作的機會...
[10]該出手時便出手!永遠不可能有100%把握!!!條件差不多就要大膽去干,去闖出自己的事業,不要猶豫,不要彷徨,干了不一定成功,但至少為下一次沖擊積累了經驗,不干永遠沒出息,而且要干成必然要經歷失敗。不經歷風雨,怎么見彩虹,沒有人能隨隨便便成功!
--sunfruit
獲得系統提供的所有字體
GraphicsEnvironment eq = GraphicsEnvironment.getLocalGraphicsEnvironment();
String[] fontNames = eq.getAvailableFontFamilyNames();
說明:如果在linux下需要安裝界面相關的包,具體的那個包記不清了,如果不安裝可能會無法獲得字體列表.
當時的版本是red hat 7.0,至于現在的版本默認安裝是否包括需要的包就不知道了
--sunfruit
成長中的應該知道的。。。追求忘我
不要把自己當做鼠,否則肯定被貓吃。
1858年,瑞典的一個富豪人家生下了一個女兒。然而不久,孩子染患了一種無法解釋的癱瘓癥,喪失了走路的能力。
一次,女孩和家人一起乘船旅行。船長的太太給孩子講船長有一只天堂鳥,她被這只鳥的描述迷住了,極想親自看一看。于是保姆把孩子留在甲板上,自己去找船長。孩子耐不住性子等待,她要求船上的服務生立即帶她去看天堂鳥。那服務生并不知道她的腿不能走路,而只顧帶著她一道去看那只美麗的小鳥。奇跡發生了,孩子因為過度地渴望,竟忘我地拉住服務生的手,慢慢地走了起來。從此,孩子的病便痊愈了。女孩子長大后,又忘我地投入到文學創作中,最后成為第一位榮獲諾貝爾文學獎的女性,也就是茜爾瑪·拉格蘿芙。
溫馨提示:忘我是走向成功的一條捷徑,只有在這種環境中,人才會超越自身的束縛,釋放出最大的能量。
--sunfruit
成長中的應該知道的。。。心中的頑石
阻礙我們去發現、去創造的,僅僅是我們心理上的障礙和思想中的頑石。
從前有一戶人家的菜園擺著一顆大石頭,寬度大約有四十公分,高度有十公分。到菜園的人,不小心就會踢到那一顆大石頭,不是跌倒就是擦傷。
兒子問:“爸爸,那顆討厭的石頭,為什么不把它挖走?”
爸爸這么回答:“你說那顆石頭喔?從你爺爺時代,就一直放到現在了,它的體積那么大,不知道要挖到到什么時候,沒事無聊挖石頭,不如走路小心一點,還可以訓練你的反應能力。”
過了幾年,這顆大石頭留到下一代,當時的兒子娶了媳婦,當了爸爸。
有一天媳婦氣憤地說:“爸爸,菜園那顆大石頭,我越看越不順眼,改天請人搬走好了。”
爸爸回答說:“算了吧!那顆大石頭很重的,可以搬走的話在我小時候就搬走了,哪會讓它留到現在啊?”
媳婦心底非常不是滋味,那顆大石頭不知道讓她跌倒多少次了。
有一天早上,媳婦帶著鋤頭和一桶水,將整桶水倒在大石頭的四周。
十幾分鐘以后,媳婦用鋤頭把大石頭四周的泥土攪松。
媳婦早有心理準備,可能要挖一天吧,誰都沒想到幾分鐘就把石頭挖起來,看看大小,這顆石頭沒有想像的那么大,都是被那個巨大的外表蒙騙了。
溫馨提示:你抱著下坡的想法爬山,便無從爬上山去。如果你的世界沉悶而無望,那是因為你自己沉悶無望。改變你的世界,必先改變你自己的心態。
--sunfruit
為JAVA的圖形界面的字體設置統一的格式
執行下列代碼
//設置系統的默認字體
private static void setUIFont() {
Font myFont = new Font("宋體", 9, 12);
javax.swing.plaf.FontUIResource fontRes = new javax.swing.plaf.
FontUIResource(myFont);
java.util.Enumeration keys = UIManager.getDefaults().keys();
while (keys.hasMoreElements()) {
Object key = keys.nextElement();
Object value = UIManager.get(key);
if (value instanceof javax.swing.plaf.FontUIResource) {
UIManager.put(key, fontRes);
}
}
}
--sunfruit
成長中的應該知道的。。。成功并不像你想像的那么難
并不是因為事情難我們不敢做,而是因為我們不敢做事情才難的。
1965年,一位韓國學生到劍橋大學主修心理學。在喝下午茶的時候,他常到學校的咖啡廳或茶座聽一些成功人士聊天。這些成功人士包括諾貝爾獎獲得者,某一些領域的學術權威和一些創造了經濟神話的人,這些人幽默風趣,舉重若輕,把自己的成功都看得非常自然和順理成章。時間長了,他發現,在國內時,他被一些成功人士欺騙了。那些人為了讓正在創業的人知難而退,普遍把自己的創業艱辛夸大了,也就是說,他們在用自己的成功經歷嚇唬那些還沒有取得成功的人。
作為心理系的學生,他認為很有必要對韓國成功人士的心態加以研究。1970年,他把《成功并不像你想像的那么難》作為畢業論文,提交給現代經濟心理學的創始人威爾;布雷登教授。布雷登教授讀后,大為驚喜,他認為這是個新發現,這種現象雖然在東方甚至在世界各地普遍存在,但此前還沒有一個人大膽地提出來并加以研究。驚喜之余,他寫信給他的劍橋校友--當時正坐在韓國政壇第一把交椅上的人--樸正熙。他在信中說,“我不敢說這部著作對你有多大的幫助,但我敢肯定它比你的任何一個政令都能產生震動。”
后來這本書果然伴隨著韓國的經濟起飛了。這本書鼓舞了許多人,因為他們從一個新的角度告訴人們,成功與“勞其筋骨,餓其體膚”、“三更燈火五更雞”、“頭懸梁,錐刺股”沒有必然的聯系。只要你對某一事業感興趣,長久地堅持下去就會成功,因為上帝賦予你的時間和智慧夠你圓滿做完一件事情。后來,這位青年也獲得了成功,他成了韓國泛業汽車公司的總裁。
溫馨提示:人世中的許多事,只要想做,都能做到,該克服的困難,也都能克服,用不著什么鋼鐵般的意志,更用不著什么技巧或謀略。只要一個人還在樸實而饒有興趣地生活著,他終究會發現,造物主對世事的安排,都是水到渠成的。
--sunfruit
成長中的應該知道的。。。永遠的坐票
生活真是有趣:如果你只接受最好的,你經常會得到最好的。
有一個人經常出差,經常買不到對號入坐的車票。可是無論長途短途,無論車上多擠,他總能找到座位。
他的辦法其實很簡單,就是耐心地一節車廂一節車廂找過去。這個辦法聽上去似乎并不高明,但卻很管用。每次,他都做好了從第一節車廂走到最后一節車廂的準備,可是每次他都用不著走到最后就會發現空位。他說,這是因為像他這樣鍥而不舍找座位的乘客實在不多。經常是在他落座的車廂里尚余若干座位,而在其他車廂的過道和車廂接頭處,居然人滿為患。
他說,大多數乘客輕易就被一兩節車廂擁擠的表面現象迷惑了,不大細想在數十次停靠之中,從火車十幾個車門上上下下的流動中蘊藏著不少提供座位的機遇;即使想到了,他們也沒有那一份尋找的耐心。眼前一方小小立足之地很容易讓大多數人滿足,為了一兩個座位背負著行囊擠來擠去有些人也覺得不值。他們還擔心萬一找不到座位,回頭連個好好站著的地方也沒有了。與生活中一些安于現狀不思進取害怕失敗的人,永遠只能滯留在沒有成功的起點上一樣,這些不愿主動找座位的乘客大多只能在上車時最初的落腳之處一直站到下車。
溫馨提示:自信、執著、富有遠見、勤于實踐,會讓你握有一張人生之旅永遠的坐票。