: o5 t6 _1 F: g9 \* T7 I2 I zhangxiuyong 来自 <a href="http://www.ucancode.com" target="_blank" >http://www.ucancode.com</A> : 3 V6 }0 q& s2 u% w4 v5 U 9 K/ \1 K. i8 j8 t6 C B 其实我认为,对于Visual C++本身的理解不是向你上面谈到的那么简单,Microsoft / ^7 g- ?" g3 y4 ]- K在开发Visual C++的时候是希望为其开发人员提供一个可靠的开发平台,便于用户可以 7 s2 ]7 i V$ l3 g为Windows上面编写各个方面应用程序,包括:数据库应用程序,硬件驱动程序,网络程 9 K$ l' t/ K, n+ E5 g" t: d
序,多媒体程序,游戏程序等等方方面面,试想如果一个开发平台要同时完成这么多个 ! V; @' |2 ^) D6 F方面的开发任务,是需要考虑多少的问题,因此Visual C++在设计的时候就考虑了提供 " G8 ^) `6 H, W( U9 m `* `
一套类库而不是直接提供黑匣子式的开发组件来完成开发任务,提供的类库MFC具有很灵 5 m' }8 }" K V$ i
活的设计结构,以及良好的继承性,同时配合DVS文挡视图结构来组织程序开发,虽然我 / i' [$ ~9 z% w# s( V8 `/ f
们承认利用VC开发程序(数据库方面的程序)没有其他的RAD开发工具来的快,但是如果 [0 K3 v7 F6 `# d2 L$ q+ o你真正利用VC来开发的话,你会觉得你不会去选用其他的开发工具的,对了各位听说个 " T! C. }5 Z* L/ [6 p& e/ @
多少开发人员是从VC熟练的开发师转向VB,Dephi的开发工具的吗,当然DVS结构本身也有 8 M) h& H9 [- [. M
其很大的弱点,如很难重用。同时在CView中再嵌套CView的变得不可能。不过对于开发 6 s2 W @4 j. s. s中小型的程序(代码在50万行以内的程序却是可以的了)。对于特大型的程序我想最好 0 C' |8 X/ ~1 u7 o' i9 x可以借鉴一种新的技术叫做MVC的开发技术来组织你的程序吧。好了各位此些文字,仅代 $ B* U% }6 D O( F表个人之言,如果各位感兴趣可以到:http://www.ucancode.com上面看看。 ' Q( b4 I# h5 x4 s- p; s . d+ T, ?' \# i% u* ^- e6 L: M5 Q
wenyy 来自 <a href="http://www.vchelp.net" target="_blank" >http://www.vchelp.net</A> : , y' [/ u' D4 ]5 J ?1 z - ^* s& O0 j0 C2 |# S 我一定程度上同意 恶魔吹着笛子来 的说法, ( g% l1 k# V2 a2 N ; g3 } W$ }; K" h1 b Z 毕竟VC开发速度是比较慢的, 9 y+ e: _" S3 L
7 C0 S# \/ C3 g 而且硬件速度的大规模提升也为使用JAVA开辟了道路, 0 a) Y0 e$ u- J( o) P
4 w* E* K9 Q- E* l- L2 [# } 不过microsoft.net的目的是一定程度上改变MS的经营性质,和开发关系不是很大,但 # D7 m- G0 r5 G5 f- f. F是MS的一贯方针都是在平台上为开发人员提供方便, 0 z* `& C8 s0 c: y ! G" b# J* h+ H% o
所以C#是为了.net服务的。 o3 K9 L% b- i" x. S6 l o4 }) R
. C- P- _# G& z 9 \; x6 t; Q: E) I1 U9 v; o
此外我想我没有精力再搞个c#help.net了。:-P 7 E l: c. v8 V6 p & ~7 @# A$ \6 _7 w4 A! T$ T. q 果子 来自 http:// : + X' }4 b% j" v3 O; `* P, d7 U: t ' H! x$ O- Z3 W" m1 J/ x2 ?
"恶魔吹着笛子来"是比较“前卫”的一类程序员。我就听业界的人多次说过JAVA也是 6 V; z0 j" W; j8 \! u 4 b- l% M2 n) M+ p% [ _- W # c! y$ c1 q. \: P' Z- O
个吹得很响的东西,但实际如何,大家都看得见。至于认为C/C++开发工具(VC, + }& m$ z& d1 Q" O
0 D/ f! K3 M' {" I7 f
BCB等)会在一两年内退出市场,就是无稽之谈了。 # Z% L! {* Y, O' N2 V" g3 z0 E. [, i$ l 1 P+ M9 E5 j$ E' |/ E) [0 q& q3 i" R. U
Wesley 来自 http:// : 8 X! |, d$ L) E) C$ e6 ~3 D
- ~' ~; h0 S- g+ P! l5 f/ ]- t
恶魔吹着笛子来,你的观点很有启发性。能不能写一篇或推荐一篇剖析、比较Java开 $ y. {8 H0 b! k! p$ X: `发工具的文章?比如Visual J++, JBuilder,以及Symantec和IBM的对应工具。(可能和 ; z6 T8 e8 Z) |6 n9 Q本站的初衷有些不合^o^) S" ?( R/ U& }8 P6 w$ |: h2 F0 ] 0 a6 m' b: I& d) O7 i# P
LeoCN 来自 http:// : $ V9 V; r Q( x) X 8 Z6 \/ \4 y1 a. M$ |* k It's not a time for us to determine which language will more better! 5 [4 w+ [" Q1 L& |8 J2 S
0 M7 e$ I6 t% x! I3 H" J in factly,In China,too many corporation just writting some codes for 5 O% i! v% c, M0 t8 H$ c
9 m& C. Z" s! [ V' Y
enterprise's MIS,OA,ERP or other application.It do not need so speed 3 R# C* K) p" C6 n {3 K: B# C8 m1 b. x
and do not need so good original code. just want more data,more easy and m 7 i. B% @# [0 i" x' u3 U
ore quickly. 4 T7 U. k7 S5 m5 ~3 E0 C8 R6 _
3 v0 X& d& K4 L$ I so c++ is not a choice in such enviroment. and u know,many codes we write ' `% J8 `6 v& f0 ]" h3 S6 ^' ntoday will be useless.and there r so many easy tools such as VB ) x5 c; z9 K0 S$ ] E) n/ F& y3 U% T
: A) Z$ w( ]) O! V! x5 P for windows designer, Developer/2000 or PB for database,Domino Designer fo $ a2 u5 H$ ~0 n4 M" Kr OA application,why c++??? o( o9 S9 ]1 X( D* S! h$ b / B `/ b1 `# F in DOS mode. i like Turbo c2.0, with it and MASM i can do everything. 3 ~ G8 C& d+ G& A
' ?- h( D% l5 C2 z* w
but now i hate c++, it has waste my time! my corporation do not need 4 b; m; Y- C: H" F) W+ i' D# v: x. M4 w/ k
) i% d+ Z% Y, I- T$ I @6 ^1 W
c++,just need java,xml,php,pb,vb,delphi,developer/2000,domino designer etc 5 K' j3 G" c" t* o/ {+ j" l0 `; `
. ! D/ D" n% q4 P6 s7 K3 I1 ` M / G8 |9 d6 M Q2 j" f; [ so, a tool is just a tool,if the advantages in some aspect of the tool * F6 b+ I, _. K1 C& l7 r
; W+ z/ ?( g: t. G
u needed. it's will be a good tool for u. others it can bring u unfortunat , B5 |# @( @$ j. k- h0 xly! 3 p K1 o! ]/ h: Y
0 N/ K4 m$ I9 O0 K, e * l9 d* @* f9 X$ M+ M u1 g& m, Z2 @ \7 m 恶魔吹着笛子来 来自 http:// : / i3 Q/ b$ u* B5 x$ U 6 a/ ]4 @6 t! A4 k- z u) h! @: \ Wesley你好.关于Java开发工具的问题.从我的观点来看,目前的Java开发工具没有一个 3 Z9 @8 K, u! G: _6 ]) G, }( U令人满意的.最主要的是,在技术上考虑的太多,却不像MS的开发工具考虑到程序员的方便 1 u, o3 ]* d% Z' b+ f1 I- G" i(vj++是另外一会事情我后面会讲). ( |( {. }' ], r 7 M! u+ D$ b& o' _ F0 n( B 基本上流行的是sun的jdk,ibm的visual age for jave,samtic 的visual cafe,和bor % Y/ K+ \/ t' Q2 @$ p, aland的jbuilder(vj++基本上没有什么人用). 1 x/ j& G7 c, O' o1 z4 u5 z
5 \0 g& b& N5 H3 I6 `) o 在这几个工具来讲,jdk是老大哥,但是仅仅是一个command line compile.在某些方面 1 }$ f% ?0 Q- s: ]7 W/ w
用ultreditor+jdk会比较方便,譬如你的机器的配置比较的低(memory<64M).一般来说,几 0 L+ |/ C1 y. l& z9 e) _% p乎所有的Java工具需要的机器配置都比较高. 5 _, k) Z( M. z9 \. i
. y' s) v3 t+ y
visual cafe是第一个可以使用的Java IDE工具,我当初学习Java的时候就是用这个.它 $ k3 ^) j7 @# l8 n4 x i4 ]# |
的配置要求比较低.一些比较低的版本譬如1.5 2.032M就可以使用了.但是现在最新的版 / }2 H# x* f @1 o/ H本5.0的要求就比较高了,可惜2.0以后的版本没有用过.cafe的IDE开发也不是很方便,懂 ' V( ?0 u: R* c" g7 U
一个窗口西一个窗口比较的乱.而且bug还很多.有的时候trace到一定的地方 7 O7 r' D+ s# a! p' Z 5 F+ ]: S: q5 c4 l6 N 就会crash.samtic是一个系统安全公司不知道为什么cafe却那么不稳定.而且从技术上 5 G4 j/ h5 x1 U来说到目前为止还没有完全支持java2.更不要说j2ee了.从帮助来说cafe的帮助基本上还 1 t+ P. @3 w G$ Z u' N
是jdk的帮助没有什么特别的地方. 8 B' V, y+ s4 U7 E! z, } 6 f3 o6 N* A9 }! [7 O6 E7 i6 ]3 R
IBM的东西往往是吹的比做的好.visual age很复杂功能也很多.支持100%pure Java和 5 N7 j: S: k2 f$ e$ o" X% c9 eJ2EE.但是使用起来不方便,当初为了设一个class path找了半天的help都没有结果.后来 - D) x$ y3 D6 H( C4 l
听别人说要在nt下面设置环境变量才能成功.而且与其说是visual age还不如说是comma ' a+ V% t* W. m5 s2 n J" P" |
nd line套了一个windows壳子.做application还要自己写layout代码更本就不visual. : e! F) d5 A6 m4 D$ ]4 t
% G ~% @8 K7 ]
Jbuilder是我目前遇到最好的一个,它的界面基本上和delphi c++duilder差不多.他是 # _1 @% }8 p* D$ R% l第一个真正的java的rad系统,第一个全面支持j2ee 13项Java技术的工具(bean,jsp,rmi 0 i3 o9 t/ F# k: j8 N3 c, r6 d
都实现了).100%的pure Java.相当全面的help document. " {5 n5 W* e0 X T: w ) [. C, a. h. |+ @5 f
但是他最大的缺点是系统要求实在高,没有128M别想用.64M下面慢的像乌龟,help更本 ) ~) P' n( C7 g# v' |不能开(它的help都是java写的64m下面打开help慢的能够看到一格一格awt画窗口的过程 6 E. r+ V2 J4 k( ^) c" p).但是不管怎么说他是一个比较理想的系统. ' s, D9 H) o6 c$ c4 S2 T - h+ U. D, h$ Q7 E. l 至于visual j++.MS更本不是想用他来打开java市场,而是想用他来分裂java.从很大程 ; ~2 u2 S. X6 V
度上来说vj是一个windows 程序的java开发工具他不是100%的pure java.在windows平台 ; x5 @# U6 r3 d3 h
上他是最visual的.用他开发application,你不必用复杂的layout,只要像vb一样填写坐 * y, S1 c0 C9 y( A标,而且开发的windows程序速度很快完全100%的本地代码.你可以把它看成java版的vb. : ]0 l( R8 q7 i
他的wfc库仅仅在windows上能够用,而且使java和com捆在一起.他自己开发jvm,java库. " v0 u, b) A3 c& E0 }1 } q但是ms污染java的策略相当的成功,不仅把java逼的走投无路还在法庭上赢了sun的java ) R1 [: m- |0 s' G
官司.因此ms的目的一达倒就把vj便卖给另一个公司而且随着c#得开发和得不到sun的j2 " U0 N4 B4 X$ ]
ee的许可我想ms不会再开发任何关于java的工具.如果你开发java的同时还想使用ms下的 3 f' W2 u% v; W3 N" D3 D# Xcom,ado那么vj可以适合你的需要. 8 G& T7 F) [; x3 g6 C
9 i- \6 x* ?( m' f4 T , Y! \6 @4 d, [/ m7 t9 D 9 S7 V2 K& e$ {6 H
1 h$ v( b( U8 Q
C- w! e% M6 b. [* p - f" n. I8 }; ^4 j( ]/ t # l8 @* r2 k" {8 s U/ B 7 F& F( T+ O* R% ~/ j/ H4 ]
chenxiqi 来自 <a href="http://chenxiqi@yeah.net" target="_blank" >http://chenxiqi@yeah.net</A> : ! r# K3 T9 `, Q! k# n; z+ L6 |( V A' U q% q7 q/ e7 t1 _) A
VC++开发数据库软件确实比较慢,可有许多软件只能用C/C++来开发,如果VC++退出历 : E R; p! V3 v& J* |2 _史舞台,那岂不是说只有数据库软件才叫软件,我想世界不会如此单一。 . S* g, |$ E O' t4 s- n( E- x $ k8 V* m% z: ]2 k5 ~3 ?( x1 I 4 }" [' `) F" Z2 ?+ F ]7 K2 c
zhangxiuyong 能告诉我什么是MVC的开发技术吗 & X: H( y2 y2 ^8 h9 R% I : b3 N7 x7 M$ s
恶魔吹着笛子来 来自 : " x; A! Y; `" G, Y9 G) E! k
% L2 N( N4 Y$ o/ H( s0 j9 k" G* w 什么样的的软件只能用c/c++开发? . I' ?! o6 G% G: H; m7 D F4 { 1 v: _. r' R- y
操作系统?apple的OS7,os8,os9都是PASCAL开发的. . i5 v+ c! i4 }' @; S
9 v; F& V1 G2 A# A. A5 J
数据库?oracle8i就是JAVA开发的 m7 |' y/ P {: o ; S8 N! X6 I- y, ^ 游戏?你也许没有见过用DELPHI开发的<笑傲江湖><风云>,甚至有VB开发的<神龙教> 3 f( _7 e/ ]* u! h' H
& S+ K8 W( S8 }$ v c" D
同时VB7.0全面支持direx8.0.可想而知游戏的难度会大大的降低吧. 3 }8 e% ^/ w. b% ]/ C, d z: q( h, B5 i5 I x. o9 e6 ~
MVC=Model, View, Controller Design Pattern 7 O1 o8 ?) w: }
9 Y- c2 S1 }6 e( n4 v/ H
& H( X( ?, u) H
% y* a q6 d n6 H& M 恶魔吹着笛子来 来自 : - c" ?+ q3 y6 A/ H' k
" c9 U5 g: {) _9 W, q2 X2 H 什么样的的软件只能用c/c++开发? ( G; m) t' l) Z2 o9 X; W
1 W, U: w+ L0 J% v6 Z: E 操作系统?apple的OS7,os8,os9都是PASCAL开发的. 0 I: r( A) M+ T 4 \& K/ ~7 M c+ x 数据库?oracle8i就是JAVA开发的 + j Y$ u8 m9 l 9 s0 O, h m3 e; h- k 游戏?你也许没有见过用DELPHI开发的<笑傲江湖><风云>,甚至有VB开发的<神龙教> " {* \4 C8 j4 V8 M 0 c9 q4 L; v7 Z( Y+ }' P* l
同时VB7.0全面支持direx8.0.可想而知游戏的开发难度会大大的降低吧. * D3 N1 E- N" P" r; H$ y( r7 n , b- g! B: t, }* V 我的意思不是说c/c++会消失而是应用的范围将会大大的降低并且将会进行脱胎换骨的 ) Q Q# V' g& W& {0 _5 N2 e升级(用了20几年升升级总可以吧,java的升级不算太成功,但是是一个不错的先例我想c - Z; J0 W/ h2 v9 x
#的前景会更好). # J9 [$ _4 j/ u! _ o8 y
2 c* u8 f8 t- n# J% Y, m BTW: ' @1 i# g. Z0 U2 S' [/ P5 Y* o
( p$ o! D9 y$ b7 c MVC=Model, View, Controller Design Pattern ! O: |/ D8 P) @' P4 j# Z" B" T . n8 a- o t9 J+ t- O5 ? 9 b4 \9 o0 H3 T, Z* g+ t( k/ P + }+ e6 }$ x- v) u
xubin 来自 http:// : 6 L/ D3 f, C) H, _% c7 K) z1 s
: [- D' R/ U. t* P S5 z 在工业控制中,直接对I/O地址操作,就要用C++。 6 L; T( ?$ z/ }' y) h5 [' d 6 d( p' Q0 V3 h, K: ?7 a# L7 T 恶魔吹着笛子来 来自 : , H; C2 r; u$ ~" o$ _ r2 F D7 N Y
6 {: E. T. p. v: |
俺有一个同学毕业设计用VB做单片机。你这不是在讨论问题是在抬杠。 " q, r# k a# {6 Z
$ o0 v- I# V9 F3 {: ` L+ x% C
wenyy 来自 <a href="http://www.vchelp.net" target="_blank" >http://www.vchelp.net</A> : & [* e( I) |+ ]3 w; x0 h ! j7 s$ v5 c$ R 我想一种语言并不会因为其他语言的出现而消失, 7 y9 d5 r/ F& ]( U # C) m$ m. e0 W& I* h: Z$ W: U! _2 r" F 比如说c与C++,C++与C#的关系。 ( L( j6 P5 H% I, S
: z0 y+ t* T$ ~# D4 P 所以我想讨论问题时首先是要排除敌视, ; I& Q* N$ v3 V- r3 H
( D6 I8 j0 u( g3 v% `
然后才是透彻的分析。 b3 Q, Y# P, T1 G" ^& A) n2 c+ k
$ c. \8 `: f+ ` O* j Z# q& U
IT世界不光只有网络,还有其他很多。 8 ^, d- ~0 A2 v$ m) E) O
7 s$ _1 C* e# w' M6 @4 F' x
所以某些工具在一定范围内适用是正常的, 8 P; z( _+ y7 r 2 {; ]! O- ~% _- Z. t6 I9 T
其实在国外, ; Q/ m; H" D7 [$ Y: @' g" u. V ( A5 c/ ~6 M6 v9 S- t
SERVER端软件大都用JAVA,而CLIENT却没有多少用JAVA, / L! {) I3 z+ `
) A6 ]5 ^ I2 Z; v( o* m( A- q
这和速度有关,当然也与MS对JAVA的态度有关。 ' N3 J5 {0 t4 d# {" i& C) t; X7 y / r/ P) v$ v$ L( J% `- E9 W8 |
5 |5 i+ v' _4 Y) Q
不过我一直认为C/C++不会因为JAVA的出现而消失。 _. R, S/ h: b) o # z0 R6 W. H3 Y7 v- a! ? 就象COBOL目前为止还在使用一样, 6 R1 D+ z4 {8 Z' r6 L3 j 4 p0 ?* ?: p+ A8 V5 n, P! s 7 Q G/ B# u: L! g. k) y
不过以后会有愈来愈多的解释性语言出现,因为解释语言比编译语言的兼容性好,这 ! g1 f X/ \; }9 `/ S, t
是不得不承认的。 . c+ o# d6 h% j
8 f8 m# d5 u* J c0 c; U, e" |6 S
恶魔吹着笛子来 来自 http:// : ' q: H' V! g0 q6 F/ |0 Y, m3 A# d & Y- Q3 | }) G- D3 p1 v: ?
是的wenny.也许我说c/c++的消失有点夸张化了,但是实事求是的说.java和c#的出现 0 s- v0 l0 m% v3 c! N
+ d% R5 W- {% A2 i/ I- j c/c++的升级换代是在所难免的.对么. / y3 \! D2 o/ o2 }/ I
3 J0 Q$ V3 h7 v
恶魔吹着笛子来 来自 http:// : % ` a0 ~' R1 t, U+ v 5 P+ J$ o5 J3 } 而且我一直认为java和c#不是另外一种语言而是c++的升级.就象是c到c++的升级一样 5 t/ E, {% b0 S5 U* O
.对不对. : D# r6 q* s2 p* u5 L 6 `! e" w, t* L3 M, i6 v, R xcc 来自 http:// : # ?9 ]+ p+ h" ^4 ]
5 ]- H ~, c6 P: M
同意恶魔吹着笛子,你简直是我的偶像,顺便贴一篇关于C#和.NET专访 8 a& i" \5 s4 M+ J( C M ! [# C$ }/ O7 J3 Z# @ NET and C# Questions with Jeffrey Richter 7 x$ w3 T( q& R: x4 R
6 K# m& i' _0 u; I In the weeks after Microsoft made a huge splash in the development communi : h& p' t* N: E m7 R4 ]! q5 r. ety with their .NET and C# announcments at the July 2000 PDC, Jeffrey Richter 1 L6 }! w. J* L) q* }& d1 H) [; o: K* J accepted our request to field 20 questions from our readers about these new ' ~% H& I0 [3 C& o: c8 X technologies. As many of you already know, Jeffrey is a cofounder of Wintel ' P S* X! [- `" e% ulect, a company that specializes in Windows & Microsoft.Net training and deb - c5 A9 `7 D8 x% y9 y& O, ]
ugging. Jeff is also a consultant at Microsoft working on the Microsoft.NET ) y/ P/ e% R+ g( XCommon Runtime Language (CLR) team in which C# and Visual Basic 7 applicatio - g9 \0 r. O Z" ^' Z6 n* Zns operate. Below are the 20 most popular questions that were sent in and Je " b: \+ P) w) Yffrey's responses. 5 B5 ?6 m# F: H- T5 F' h # b, \/ `+ Z' s2 M E
For Visual C++ developers everywhere still trying to get a handle on all t 0 \. j* i. C, L
his: Thanks Jeff!! # K# v$ f; ^' }! f# d . k9 Y- C e9 ?0 a$ S& ?1 z* l 9 ^( i X3 K9 s ? Question #1 Is .NET a runtime service or a development platform? `) h2 A, d3 }2 x! `0 r. u2 Y: a- n
3 p: H5 u- v+ Q# y/ H
Answer It's both and actually a lot more. Microsoft .NET is a company-wide 7 H4 a9 z2 W4 l+ O7 S& d6 z initiative. It includes a new way of delivering software and services to bu , @; L Q/ W7 s9 Vsinesses and consumers. A part of Microsoft.NET is the .NET Frameworks. The + i& k: {+ G2 R4 m( j( \frameworks is the first part of the MS.NET initiate to ship and it was given " @& m( x/ \; l- F9 U% Z
out to attendees at the PDC in July. The .NET frameworks consists of two pa / r! H* G" X* b$ M8 t% z5 orts: the .NET common language runtime and the .NET class library. These two 6 x# s5 L. V" `9 C s
components are packaged together into the .NET Frameworks SDK which will be 5 i N1 P; H! E) H P: T q9 ^& {
available for free download from Microsoft's MSDN web site later this month. 4 T% I& E9 T" d W: {
In addition, the SDK also includes command-line compilers for C#, C++, JScr 8 m: ~, r8 y! D
ipt, and VB. You use these compilers to build applications and components. T . U- Z' z1 Y0 [+ [1 ^! i0 G: fhese components require the runtime to execute so this is a development plat 9 a5 ^8 f O! s
form. When Visual Studio.NET ships, it will include the .NET SDK and a GUI e : N H4 d* Q- o( ^
ditor, wizards, tools, and a slew of other things. However, Visual Studio.NE + Y% R5 w* o) {4 M, R. W1 p# dT is NOT required to build .NET applications. : }, h5 w' j( n; t
# a. J1 \* g1 [ 3 o" x5 b% U6 m& l7 w Question #2 How likely it is for C# to become a general-purpose (meaning: + O4 \( R. e1 Y; Q1 _2 Inot MS-specific) language and if so, have any other vendors committed to pro ( P' o* ^1 n7 S% y- Y
viding compilers on any non-Windows platforms? . e' C: l. a6 B; Y
6 y3 X% u) H1 C" c/ q6 n, G8 S Answer It's hard to answer this right now. I have been programming in C# a " M; J" }4 T6 x/ T1 F
lmost exclusively for about the past year and I love it. It only took me a f 1 f- X) M: A* O) I( F
ew days to learn most of it since it is very similar to C++. It was designed 0 \6 m7 A+ I8 L3 Z; U* Z
to compliment the common language runtime and I think that it's unlikely to ' C j" q; [7 D" H9 E
gain much momentum if decoupled from the runtime. However, you never know. " E7 j6 `4 D* n( e+ \- KMicrosoft is submitting C# to the ECMA standards body so any company will ea ) u* ]2 T1 K }, \* f% E
sily be able to produce their own C# compiler however, without a runtime, th % w# R; z4 G- d! s* u, \* P
e compiler itself is not that useful. I'm not aware of any companies current 1 W" l" ^% o9 P9 oly working on their own C# compiler. Certainly, porting the runtime to anoth 7 m' N( Y. v! v7 k. l
er OS is no small undertaking. - q5 i. e0 v0 F. a" L1 x
, r$ E# P) a5 @, v ~3 m" N
9 W% P2 [& V6 a; O Question #3 Can you tell us specific practical problems that C# can fix be 9 k5 ?, S U) G0 n: h( \9 E5 n
tter than Java? " D, w% P0 a# s6 y & ~/ }1 m$ J- h* P4 I: b Answer I must be honest with you: I have never programmed in Java. I know # E$ }) \6 A+ f4 _# y2 l& A6 ?6 C3 nwhat C# offers the C/C++ programmer: simpler syntax, components that seamles : [* T- {& z, @# w7 Q: K3 J' Gsly fit together, type safety, and so on. Other people should be able to add # L7 ~2 e2 y* ]: n
ress the C# <-> Java comparison. ! s# b1 k' ^7 F: @8 d4 h 4 E7 ]1 W% p! H, ^9 Q4 r' T- y * i% r) n: u1 u3 f, {: M
Question #4 Will ADO+ be the preferred and most efficient method to access / A' y; h( k; Y/ V databases from C# or will it have it own (or .NET) class wrappers for the O + h8 _$ A3 U" L/ R/ g0 Q4 I6 ALEDB API? " s3 z8 M" _8 s& I
8 |; {4 T% h3 c* H" [5 y! U7 U4 s Answer The .NET class library includes a System.Data namespace with many t / ~3 P6 N& e, J( }( ^2 p
ypes for database access. These wrappers will be the best (and most efficien ' `4 k/ l% I( k. d
t) way for a C# programmer to access data. 3 I( ?; w- n$ t) { B6 T3 c$ l2 [
S4 |, Q7 o0 g: A; W" N
& K0 g" c( }; d D4 D k7 F) h. ?2 l x
Question #5 Can C# be used to develop Windows applications or is it soley B& a3 ^4 u$ s1 z% [6 [# A
used for developing distributed applications? " L& ?, \- C1 `, p
( Z% `* z+ M$ X7 e b& r0 t
Answer C# can absolutely be used to develop classic-style Windows applicat 6 v- ^4 G; p3 c% j! w A# s% \ions. Actually, this is more a function of the runtime, not the language. So & B4 `$ y9 Q) f3 I( |. }, the runtime supports console apps, GUI applications, NT Service applicatio 6 E. m$ e* D% p) ~2 t- ]/ [' @. `
ns, simple components which can be used in applications, web pages and so on & u: [7 K( ?5 H- b. You can't write a device driver but that's about all I can think of that t # g# W( t F6 _0 B0 ^, _he runtime doesn't support. + ~7 `1 d1 p6 W( f2 s2 `
2 ~: q( V# {( _0 A$ {
% M' \* H6 G/ }+ O6 h" E# H
Question #6 What is the C# relationship to WinForms? * @ Y, _" ^3 E+ ^ 8 ?0 S$ R# Y+ U0 `6 e: ~) v1 t
Answer Win Forms is a set of classes in the .NET class library that wrap W - {$ Z+ t+ O7 @in32 windows, brushes, pens, etc. Any language targeting the runtime (includ 9 |5 M1 G/ [. G ding C#) can construct instances of these types and manipulate them. This is ! l9 e1 y6 ~, n1 _how you would create an app like Notepad, Calc, or Wordpad. I know that Win * h* }5 G( s; n$ X+ V
Forms has similarity to J++'s WFC library but I also know that there have be 1 B- E7 f$ F; j1 ]1 B1 J
en some major changes. , p( R5 M; U! V3 r. I7 W9 n
5 t/ A! U2 z" Q, W& ]0 y; ]; b
% V# X: Q0 L( V; e/ x. j4 s Question #7 Rumor has it that the C# language has been submitted to the EC ' G: W- n; @4 p3 B7 N$ i5 B+ I
MA for ratification. Is this true and what impact do you see that having on . W4 w- \7 a0 V. B" `: X3 u
other companies adopting it as a general language (such as C and C++)? $ C0 N! M5 J! P; f. H0 s 9 A* S2 I H* I) C: h, i$ k
Answer Yes, it is true. I pretty much answered this in question 2. ; z- ]/ L x! i2 N5 Z" s . {5 \5 b" P# V, G( ^
9 N; O% e6 B, V
Question #8 Which will be the role of ATL and COM in the new .NET technolo ) ^! h+ L( W4 _& J! `gies? ( D/ [" h, ]2 H4 ^9 U4 c
. U7 n. G5 K8 D9 n: X: T
Answer The .NET frameworks offers a replacement for many existing librarie 7 n7 I4 ~3 z0 X
s, like ATL, MFC, C runtime library, standard template library and so on. .N 8 U/ {6 t9 k" o# @- @' q* Q
ET programming is significantly easier than using any of these older technol 4 c$ h: \2 E* Nogies. For this reason, I suspect many developers will move away from using 0 c$ m/ o W: F/ \! D3 |
the older technologies. The older technologies can buy you performance howev . @! Z" G" j5 R' T ?( _, Ker; so, some people that are very concerned about this will stick with what' 6 e7 N' E$ Y5 F5 J6 z, f7 ~ L
s around. As for COM, developing components with .NET is orders of magnitude % g2 T. S' y5 R- k# F
easier and the interoperation between components pretty much happens for fr ; d" Z( h2 S* m% C7 R& P
ee. Again performance may be an issue for some. And, for the time being COM+ + x4 d4 P# a$ t7 C o/ N( M% \ services, like transactions, are not being offered directly to .NET code. Y ' S8 `$ [* @# X/ o
ou can still access these COM+ services but .NET code must incur an interope - H. r7 M4 c" a$ @
rability transition, which translates to a performance hit. ' Y$ h5 I% N5 k
5 V# |& J3 | r( Z# `) v
. x: @; w8 o2 Q D3 D( j Question #9 Why was the templates feature not carried over from C++ to C#? 4 J" O7 [( s* r/ g * n8 F- y# e9 w& S
; C" y0 R( I# G" e. C2 a# |8 I" B Answer Again, this is more of a runtime issue than a C# issue. First, temp ' b* @/ |) p- |8 ]% x, mlates are difficult to implement and Microsoft choose not to do the work for & h9 B f- E5 w. x* K9 t7 I
Version 1 of the product. They may do templates or something similar in fut ! S7 \6 U9 r" x* t# T" k/ B8 L7 xure versions. Second, since the runtime is a multi-language runtime, introdu ; {. c' D$ @! N& zcing templates means that all languages targeting the runtime would be requi 1 r" f7 D8 ]- C) N; z' n# A2 e
red to support templates in some form. There are a lot of issues here that n # l1 C4 {. _: e8 K4 x5 qeed to be carefully considered. 1 Z1 E! ?5 r3 p' \" A x0 M; g- t8 h& ], g 4 J Q F1 \4 b6 [, T7 V! {
Question #10 Will C# replace the pseudo keywords that clutter ATL COM code 8 H, _# A9 k: v+ A, [ with real keywords? Examples: OLE_COLOR, BOOL, VARIANT_BOOL, and DISPID_XXX % y* ]/ a& O3 L. D9 \" [
XXX. / `) V* k: V3 H6 X; U' X
$ w* D3 E. l& P0 [ Answer Absolutely, all types have new names as provided by the .NET class / f* E# N; }7 {0 y- k0 ~1 ]4 z3 Ilibrary. $ l" r c; V& ]$ V$ o" {' N/ w
+ P7 ]' n3 b' O1 K w
! H% P. r5 g4 }" t$ o; b Question #11 We've seen managed extensions, but aside from that, what futu 0 i7 L5 l% E+ `/ N7 u6 |re does C++ have at MS and in .NET? ; Z2 R& A$ c1 S* C( Q ! M5 T# {7 Z9 ?' Q- y* f
Answer C++ is unique in that it is the only Microsoft language that allows + i: A4 T$ P' N- g+ P/ q the developer to write managed and unmanaged code. So, I can easily see dev + N" `8 o! Q* f; j: t
elopers writing in unmanaged C++ for performance-critical algorithms and the ) ]/ c5 h. C" d1 m. F \
n using managed C++ for type-safety and component interoperability. I'm sure ) x* X5 V! E% |" e8 ] p
Microsoft will keep C++ going for years to come: device drivers need it, Wi # o! G' }* k; }! x! ]* E" A, Vndows is built with it, SQL Server< Exchange, and other BackOffice products / A+ g) f' \$ twill probably use C++ for a long, long time. ) v0 e9 i+ N! [ K: m ! S6 x2 l' J5 b& ]+ i1 w
" C A, A6 g1 ^: e% e Question #12 If .NET supports ActiveX/COM, how will security be assured if : z1 ?. v" V% d a C# application runs from within a browser? 7 d" r4 m$ w0 K# R8 W 7 Q! V$ E- F* R Answer The .NET runtime offers code access security, which allows an admin 0 W# a8 \6 ~* w& f# v
istrator/user to configure security based on code identify. By default, any % R. z" `. E* O4 {- Z6 D$ Q+ Ucode downloaded via the Internet or intranet is untrusted and will not be ab # e8 ^, q' ]2 y5 s" G/ O4 }
le to access files and other resources. In fact, when I build a console appl N. N5 k1 H$ V& @' h3 K- f1 a4 [- ]
ication and run it from a network share, I get an exception when it tries to : C* y4 O5 o: M- m) E- f8 M" @ access certain resources. If I copy the same file to a local disk directory 6 c# {6 ?1 J/ L
and run it, it runs fine. Code access security is integrated with the runti 6 V$ G, N# h$ \% m7 e/ x
me and is too deep a subject to cover here. ( ~7 s1 \6 D' `3 l5 N( l . u- j0 U, F* t, y) z
9 O/ X8 W j" X! P Question #13 With regards to the .NET runtime, do I need it on the machine " r! }$ _# v1 E5 y2 p that I deploy C# apps on? ; A/ f! s3 J0 w2 n) t0 y3 H+ \4 o1 X
8 s* j0 x# `8 g$ g Answer Yes. All managed apps need a manager; the runtime is the manager. M & F1 |0 I; T! |" }4 s6 D; _
icrosoft will eventually package the runtime so that it is freely redistribu # ]6 O Q% N9 s4 l
ted. For now, end-users will have to install the full .NET SDK from MSDN web 2 `0 \) V- O# }- e; w& N site (when available). This is similar to how VB developer must ship the VB ) C4 N6 W0 b$ ?* F$ B7 T0 e
runtime today. 3 Y- P. ^/ [' `8 ^2 P' U8 z " f9 U7 U- W% h' _0 ~7 P i P1 s2 P- W/ o* L$ b Question #14 There has been mention of being able to derive C# classes fro ) \) h( H8 }6 W
m VB classes. Is this true and where can we see an example of how to do this 6 W) j9 [/ F6 w4 x% }
? / ~, C- M5 B$ F% T9 K8 s( k $ M- Z- Q( T8 \8 G( h1 A Answer This is true. In fact, any language that targets the runtime can de ( [. L- r# Z% y( A6 q
rive from any type created in another language. Also, the Visual Studio debu 0 r* p4 A% `8 C. p% C
gger fully supports debugging across languages. Each entry in the call stack . ~# r/ R. T# r: [. E- r( s
window shows the function on the stack and the language that the function w + E) l& X/ r4 \3 U- _, B" x5 Zas written in. This is very cool and got a round of spontaneous applause whe 0 g: i5 u6 F" ]7 T1 X) w: G6 ?. r. Mn shown at the PDC. There are samples in the .NET SDK that demonstrate how t " e3 w* O. B: I$ ]$ g' S! j" g/ No do this. It's really quite simple. Actually it just happens, there is noth , c1 p Y0 g7 w
ing for you to do. You can also throw exception across language boundaries a 4 V5 W; a- `9 Q/ js well for error handling. % X5 `, g/ I& v, q ) g8 `9 D! K# L+ n0 P3 B 4 x( ?3 D3 P; O. v- e
Question #15 Can I derive a C# class from a C++ class? If so, how? - u9 N6 P1 J' {( m8 k. {
, {% q) T0 L. ~6 n, V Answer Same as the answer above: Any managed language can inherit from a t 9 h) Y* S7 p% [" P& @
ype in another other managed language. If you use native C++, then you can't & |' v4 X" C! m# c* _* G do this, however. & ^, ]0 U9 C0 A7 R 3 _8 }: {" N/ E m: C3 N # s+ j; k3 `7 Q' c% N
Question #16 Will the new version of MFC have the option of working in a m 1 X- ]* L! i* P" ^+ H9 N, {anaged environment? + ~" A1 ~, h( C% C4 P
; ?" Y6 [& }8 ]8 j- h8 V3 ~3 t Answer I haven't been tracking the new version of MFC but I'm pretty sure - E( @6 A$ S6 ]" u
the answer is no. MFC is all unmanaged just like it has always been. For man " ?5 w# p- a; O6 Aaged applications, Win Forms is the window manager that people should use. ( m( l: U3 D5 S! h . |1 E2 I2 L8 e8 X/ L: A. _
3 J- N2 s8 C0 j& n
Question #17 If the new version of MFC will operate in a managed environme s6 o2 _/ u0 n: l" s7 M; b
nt, will it have the option of building desktop Win32 apps and not needing . . j+ i* J0 R6 I# O N" E" `6 tNET runtime support? 3 D8 f& W, N e' L/ m3 ]
4 Q& |/ m# [0 G" d Answer I'm pretty sure MFC is unmanaged and will never require the runtime / H3 x8 ^1 ]/ ?$ ~. Z
. / E( Q4 C8 H7 `% R; y' \% J5 [$ Z$ B& t6 m & o J1 o: R7 c u$ j8 ~; v' [ 1 R6 B4 _ r1 b: R Question #18 Stroustrup has been quoted as saying "I have not expressed a / v1 w" m% d; t1 v3 U4 t
technical opinion on C#, and I don't plan to do so. C# is yet another propri 9 G. _; _7 [8 W" u! cetary language specialized for Microsoft's Windows system." Do you agree or " I5 p6 m5 x. ?1 V4 k. Ydo you think C# is more of a generic language open to other platforms? ' l! p1 r$ @7 `; z8 t6 Y# h * [9 _1 G# T1 O
Answer C# is a language designed for the common language runtime; not Wind 7 |" p- O; X% m" L( Vows. The CLR can be ported to other operating system like Linux and Solaris , O" Q4 z) K0 C! P
and if the CLR is there, then C# will probably be there as well. In the gran ! m, U9 ?7 T. h5 \d scheme of things, C# is not that important or interesting. It is a syntax % X! ^* k- W/ E2 N- n
checker that spits out intermediate language consumable by the runtime. You ' B+ n5 h) V, B
can love C# or hate C# - your choice. I happen to love it and think is the b * o$ _% e. e- b1 a* e5 r, Zest programming language for the types of applications I write. 1 M/ ~' ?- t8 c* Z6 ^7 [% L 0 D6 O+ x8 e+ o6 x
3 z, z% p) x9 |6 G2 L, m* m& M+ i
Question #19 I heard a rumor that VB7 will allow static linking of the run 5 s& T: H% F" B( W
time, like MFC. Is there any truth in this? If so, will C# also be able to c 5 H+ f6 p( \# H; x7 v
reate standalone apps? : i% h2 ~, I, \ c9 T; @! ]
) ]# c- f& \. n( b9 X) m; M8 E
Answer This is absolutely not true. No language will able to statically li / p1 Q" [' x. }7 P
nk to the runtime. 1 l6 S" H" _2 n6 e/ Y) N* Y 3 w$ p1 Z3 o7 r8 U " G; \ m6 k& N1 B
Question #20 Does C# still use resource files? If not, what mechanism is p ~" t4 j; P1 _6 ]
rovided to allow for localization? % I; }7 N, ^ _" w) Z
0 A- ~; s) H' _" V# k; @* s( T Answer The .NET frameworks designers have created a new resource model. Re + N4 v* x( F3 |8 H5 n1 U. Usources can be embedded in EXE or DLL files the way Win32 resources are or r 0 S% X6 \( H5 |! J- ]5 H1 a
esources files can now be stand-alone files like a single jpg or bmp file. T # W& V) H$ k& xhere is also the concept of fall-back cultures. If the Swiss German resource , K L& e t7 {- u
can't be found, the runtime looks for the German resource. If the German re % s3 @) x1 i) V; T
source can't be fond, it looks for the "default" resource. Each language wil : i! y' m7 h' y9 {3 Al typically be built and shipped as a separate assembly rather than packagin 1 A3 E" f6 M4 W. p% n9 Xg everything up into a single file. Like code access security, a full discus 8 _7 X; x& R$ D6 ]5 d. b
sion of the new resource model is too much to put here. 1 I8 a T, I% @8 C, H& \" y: m
) p, |+ H2 L) N( r2 Z4 e % S, B' J" V5 O# F
$ i1 ~1 l$ a `- y& c$ x 1 G% e; l4 S; R8 _. |; w e! p+ d
wenyy 来自 <a href="http://www.vchelp.net" target="_blank" >http://www.vchelp.net</A> : $ R C! x! p( s; R: x
& j# g/ G& k5 Z- [" T! [
我想应该这样说,一种新语言的出现会在一定的功能领域上替代其他的开发语言,以 $ B7 r8 a. q/ t- V) p/ s
前的开发语言的使用范围会缩小,但不会消失。(就算是出于保护现有资源的目的) 3 z. S! y# n }9 X/ e6 h# q 9 n1 _$ }2 t+ I N 但没有一中语言是十全十美的, 1 f) x+ @. |8 C9 {- V
9 ]( X. @" ^$ J4 H) ~0 c, |
JAVA,C#都不是。 3 [% }6 L9 J( ?# x6 }1 [# ? 4 E; P& Z0 |0 g" I
- h* K% @' g4 y7 e X 5 P' h# O" [& \& u) U* H wenyy 来自 <a href="http://www.vchelp.net" target="_blank" >http://www.vchelp.net</A> : & U4 i7 m, M& T6 v4 ^4 X + i2 \4 j3 D1 \7 i+ H, v0 @, E; J
》》恶魔吹着笛子来 5 k8 | [0 k. t: s `" j
9 v9 Y8 ]9 Z: k% H; _ 你好, ) b. Q& D' ]. c% ]6 A5 V5 b6 N I0 V9 {) }9 P9 r 很高兴能够与你进行讨论, ( I% Z+ ~4 F9 X% V . h# W1 V. I2 r$ t$ h
虽然本站名字叫做vchelp.net V( M9 T' A; p* Z + p H. \$ N3 F, @ 但我不排斥其他的开发语言,只是自己的能力有限不能将本站内容扩展到其他的语言 0 k8 c2 y, Q) C1 u: A
, - L/ b" v$ g: v6 Y1 N- n4 C / V- z/ B0 h2 k6 B
但我很希望大家在本站对开发中可能遇到的问题和矛盾进行讨论,不论是关于语言还 4 Z* N+ {& P0 n& i, o ~
是开发方法的。 , o# l U" z4 o! v q- H
9 E/ @, \& B. f/ W! H0 o- f
我想邀请你成为本站个人专栏的作者, 9 Q3 Q4 `! j S# k
/ _3 Z/ z9 M; f4 [
你可以发表一些你关于开发的想法,就算是与VC无关也没关系。当然在时间上也没有 . N n% h B% g5 U/ i: `要求,你有时间就写写。 7 G: Z' e$ _1 B+ s+ `7 T * d6 r2 {/ s4 `+ X8 R0 A+ N
盼复:<a href="mailtwyy_cq@21cn.com" target="_blank" >wyy_cq@21cn.com</A> ; j9 \5 x* N9 u2 [: T
. {# O* J4 H( |! [" F& N) k/ z! o! b
cuixue 来自 http:// : 2 U1 ]/ U3 e: S6 ]2 j 0 I7 k$ A1 d. P# `
看了各位大侠的话,觉得好像在讨论java,其实历来有两派,smth几乎天天在吵, : \; U! ~ t' O2 ]' E" t& }6 {
3 C) ^' _" S' g- r6 ?7 d! L+ V& R 喜欢java的同志到各个地方布道,连perl也不放过。呵呵。我个人觉得java先天有一 5 T/ Q$ i4 M2 Y; P& H6 M; q6 y, \些劣势使得他无法取代c/c++的,他的垃圾收集只不过通过一个线程来完成,这对实时系 7 |! ^: o# g. z4 s( b
统是来不及的,EJB的推出也说明java原来是不适合企业级开发的,没有语言是天生完美 9 \8 I3 x! T- c: O; F; U
的。java最大的困难我觉得来自microsoft的刁难,c#的推出无疑会夺走windows平台上 # }' s( G0 i4 z" c: W" u
的java份额。java的速度也就不说了。jbuidler的速度不能够忍受阿,可是这样一个产 4 g5 O. D7 q' x品就是java写的。由于个人见识不够,实在不能理解海量吞吐的 ! L4 g; o) R9 R
3 W& N* H$ N7 O8 C' } server用java.oracle用java是实现了ejb的集成把,他的数据库engine是不是java 的 3 J: L2 S5 X: O; P5 N% j
那?请大侠指点。而且当时号称8i不要操作系统,结果市场反应平平,还好 1 Q" q/ _( t" L4 x/ F, T " k C5 g" d, T5 d; J 搭上了e-commerce这班车,:) # S& @" A9 O) r! W. Y* X' s+ b4 t " J& U) N* R' r3 d* n 在说说我对vc和bcb的看法,这两样我都算粗粗用过,紫云影说得挺好的,比较公正。 p5 c C" r. ?( D6 r0 J. r C7 ^MFC的确稳定,ATL未免有点复杂,要不WTL就不会出来了。vcl的源码有一部分是pascal 0 L) o5 y% Q$ Q5 R1 p; P; G
写的,这点有点差,不过他的扩展性很好,用用就知道了,决不是好多人认为的vb式的 1 P6 C" o% J7 s$ y
傻瓜工具。道理很简单,应为他是符合ansi标准的c/c++语言。其实vc是不够ansi的,C ( {3 B; }+ c/ z! E$ B4 s
String就是不符合的,所以bcb用了 AnsiString.可惜bcb不够稳定。 # W) w9 N! k% c& \, g/ g% v
+ b$ {( d6 A x 提示太慢。帮助的问题我是这样看得,msdn不是专门给vc的,他是windows开发的指南 ' G6 h7 z, I0 i/ a* v,用bcb一样也很有用,是个宝贝。 " a/ h. b" D1 K
& c" R1 y2 h) c& w3 [
好了,不说了,反正按需所取把。 i1 V8 |! _' [; j& l
6 T8 r8 `2 F1 I cuixue 来自 http:// : % L w s* {3 Z0 r3 u5 @
6 O( ]5 O, }7 i2 X) r* i xml远程调用无疑是平台无关调用的一大进步,可是这也不能说corba就要消失了, - y0 ]/ S& q6 Z , ^' |# ^% u" @6 s1 m
xml这种标记语言虽然提供了强大的标志检索的能力,可是它本身的缺点是与以前系统 & z) [# \3 X2 ^% T% y) j
的兼容性,所以最近推出了xhtml以兼容以前的应用。电子商务的应用有不同的类型, - e( Q: S9 ], G
/ p w2 B+ w) S0 ~! s% d- S
对于一般的b2c的应用,sun e1000上跑跑java或许可以,如果是银行的主机,起码 & |" t; A" P( s4 R. }: H* f
, f# l# g K4 h0 J# t( ] 1000笔每秒,java是不是可以 那?硬件的提高不是没有限度的,而且现在数据中心和 + D' V A/ o- D" B# b4 \' dOLAP的流行,对实时的要求更高了,实际上对于单位应用硬件资源并没有什么起色。而 8 _0 C4 l$ R W, a
且数据发掘的应用要求对原有资源的兼容,对于中间件而言java开发是有优势的,corb " ~" b$ z w$ Y! Ta提供了对异构网络的良好支持,ejb也在向它靠,毕竟在这个年代,不可能只存在一个 + P& C$ P! }4 m
系统,一种语言,对自身的改造和对异构网络的支持以及原有应用的支持是每种语言都 ! r% y/ z- G7 V0 ?1 I8 l要面对的难题。 9 r; x' e1 V" ^ 2 @1 }5 y& G" X& g7 R. m- m# @
: P/ m' T) h) Q( U) g / Q: L+ I7 V D( c5 Z. E3 t- z 杨宁 来自 http:// : k2 K9 R- Q; e, G) R m
2 ^1 R. e$ m9 R K" h% G( W6 d 世界是多样性的世界。 4 i* |, e7 ^. q9 m% O2 u& q) f5 I7 ?$ m