Ⅰ java初学者到精通需要掌握哪些知识点
Java涵盖的知识点很多,想要成为满足企业需求的Java工程师你不仅要掌握理论知识,更需要具备实战开发经验。不过事有轻重缓急,知识点也有主次之分,Java编程中哪些知识点最重要?下面一同来看看吧。
1、IDE。IDE(Integrated Development Environment,集成开发环境),是用于程序开发环境的应用程序,一般包括代码编辑器、编译器、调试器和图形用户界面工具。该程序可以独立运行,也可以和其它程序并用,Java IDE常用的有eclipse、Myeclipse、NetBeans、jbuilder等。
2、数据类型。Java语言提供了八种基本类型:六种数字类型(四个整数型byte、short、int、long,两个浮点型float、double),一种字符类型char,还有一种布尔型boolean,你需要熟练掌握这些数据类型的使用方法。
3、访问控制。访问控制在面向对象技术中处于很重要的地位,合理的使用访问控制符,可以通过降低类和类之间的耦合性(关联性)来降低整个项目的复杂度,也便于整个项目的开发和维护。
4、流程控制。Java流程控制包括顺序控制、条件控制和循环控制,你需要区别三者有什么不同,需要掌握的有:if、switch、loop、for、while等流程控制的语法。
5、面向对象。这是Java的核心概念,对于任何Java开发者都需要熟练掌握。主要知识点包括有:面向对象三大特性、各自的定义概念及其使用方法。
6、对象和实例。Java编程初学者需要了解class和instance的概念以及之间的差别。
7、Static 静态属性。需要掌握静态属性的定义、使用,以及类加载时如何初始化,静态方法的定义和使用,静态类的定义和使用,静态代码块的定义和初始化时机。
当然,随着学习的深入,Java编程初学者还需要掌握Java的集合框架、异常框架、IO流等知识点。如果你想快速入门Java,短期内积攒更多的实战开发经验,建议你来参加专业的学习。
Ⅱ java 锁有几种
乐观锁/悲观锁
乐观锁与悲观锁不是指具体的什么类型的锁,而是指看待并发同步的角度。
悲观锁认为对于同一个数据的并发操作,一定是会发生修改的,哪怕没有修改,也会认为修改。因此对于同一个数据的并发操作,悲观锁采取加锁的形式。悲观的认为,不加锁的并发操作一定会出问题。
乐观锁则认为对于同一个数据的并发操作,是不会发生修改的。在更新数据的时候,会采用尝试更新,不断重新的方式更新数据。乐观的认为,不加锁的并发操作是没有事情的。
从上面的描述我们可以看出,悲观锁适合写操作非常多的场景,乐观锁适合读操作非常多的场景,不加锁会带来大量的性能提升。
公平锁/非公平锁
公平锁是指多个线程按照申请锁的顺序来获取锁。
非公平锁是指多个线程获取锁的顺序并不是按照申请锁的顺序,有可能后申请的线程比先申请的线程优先获取锁。
优点:在于吞吐量比公平锁大。
缺点:可能会造成优先级反转或者某些线程饥饿现象(一直拿不到锁)。
对于Java ReentrantLock而言,通过构造函数指定该锁是否是公平锁,默认是非公平锁。
对于Synchronized而言,也是一种非公平锁。由于其并不像ReentrantLock是通过AQS的来实现线程调度,所以并没有任何办法使其变成公平锁。
可重入锁
可重入锁的概念是自己可以再次获取自己的内部锁。
举个例子,比如一条线程获得了某个对象的锁,此时这个对象锁还没有释放,当其再次想要获取这个对象的锁的时候还是可以获取的(如果不可重入的锁的话,此刻会造成死锁)。说的更高深一点可重入锁是一种递归无阻塞的同步机制。
对于Java ReentrantLock而言, 他的名字就可以看出是一个可重入锁,其名字是Re entrant Lock重新进入锁。
对于Synchronized而言,也是一个可重入锁。可重入锁的一个好处是可一定程度避免死锁。
独享锁/共享锁
独享锁是指该锁一次只能被一个线程所持有。
共享锁是指该锁可被多个线程所持有。
对于Java ReentrantLock(互斥锁)而言,其是独享锁。
但是对于Lock的另一个实现类ReadWriteLock(读写锁),其读锁是共享锁,其写锁是独享锁。读锁的共享锁可保证并发读是非常高效的,读写,写读 ,写写的过程是互斥的。
对于Synchronized而言,当然是独享锁。
分段锁
分段锁其实是一种锁的设计,并不是具体的一种锁。对于ConcurrentHashMap而言,其并发的实现就是通过分段锁的形式来实现高效的并发操作。
我们以ConcurrentHashMap来说一下分段锁的含义以及设计思想,ConcurrentHashMap中的分段锁称为Segment,它即类似于HashMap(JDK7与JDK8中HashMap的实现)的结构,即内部拥有一个Entry数组,数组中的每个元素又是一个链表;同时又是一个ReentrantLock(Segment继承了ReentrantLock)。
当需要put元素的时候,并不是对整个hashmap进行加锁,而是先通过hashcode来知道他要放在那一个分段中,然后对这个分段进行加锁,所以当多线程put的时候,只要不是放在一个分段中,就实现了真正的并行的插入。
但是,在统计size的时候,可就是获取hashmap全局信息的时候,就需要获取所有的分段锁才能统计。
分段锁的设计目的是细化锁的粒度,当操作不需要更新整个数组的时候,就仅仅针对数组中的一项进行加锁操作。
互斥锁:
无法获取琐时,进线程立刻放弃剩余的时间片并进入阻塞(或者说挂起)状态,同时保存寄存器和程序计数器的内容(保存现场,上下文切换的前半部分),当可以获取锁时,进线程激活,等待被调度进CPU并恢复现场(上下文切换下半部分)
上下文切换会带来数十微秒的开销,不要在性能敏感的地方用互斥锁
读写锁:
1)多个读者可以同时进行读
2)写者必须互斥(只允许一个写者写,也不能读者写者同时进行)
3)写者优先于读者(一旦有写者,则后续读者必须等待,唤醒时优先考虑写者)
自旋锁:
自旋锁是指尝试获取锁的线程不会立即阻塞,而是采用循环的方式去尝试获取锁,这样的好处是减少线程上下文切换的消耗,缺点是循环会消耗CPU。
Ⅲ Java鍒濆﹁呭叆闂ㄥ︿粈涔堬纻
寰埚钦ava缂栫▼鍒濆﹁呭湪鍒氭帴瑙Java璇瑷绋嫔簭镄勬椂鍊欙纴涓岖煡阆撹ュ︿範鎺屾彙鍝浜涘繀瑕佺殑锘虹鐭ヨ瘑銆傚皬缂栨荤粨浜嗛浂锘虹瀛︿範Java缂栫▼璇瑷镄勫嚑涓锘虹鐭ヨ瘑瑕佺偣銆傚笇链涜兘澶熷瑰垰鍏ラ棬镄凧ava鏂版坠链夊府锷┿
1鍏堜简瑙d粈涔堟槸Java镄勫洓涓鏂归溃
鍒濆﹁呭厛寮勬竻杩欎簺Java镄勫熀链姒傚康涔熸槸蹇呬笉鍙灏戠殑锛屾昏扮‖鑳岃偗瀹氭槸涓嶈岀殑锛岄吨鍦ㄧ悊瑙o纴鐞呜В瀹冧滑涔嬮棿镄勫尯鍒涓庤仈绯伙纴鍒嗗埆链夊摢浜涘簲鐢ㄣ傛兂𨱍宠繖浜涗唬镰佷腑鐢ㄥ埌浜嗗摢浜涚煡璇嗙偣銆备笉瑕佷竴锻冲湴镦х潃涔︽湰鏁蹭唬镰併傝屼笉铡荤悊瑙c
1.Java缂栫▼璇瑷锛屽嵆璇娉曘
2.Java鏂囦欢镙煎纺锛屽嵆钖勭嶆枃浠跺す銆佹枃浠剁殑钖庣紑銆
3.Java铏氭嫙链(JVM)锛屽嵆澶勭悊*.class鏂囦欢镄勮В閲婂櫒銆
4.Java搴旂敤绋嫔簭鎺ュ彛(JavaAPI)銆
2鎺屾彙闱欐佹柟娉曞拰灞炴
闱欐佹柟娉曞拰灞炴х敤浜庢弿杩版煇涓绫诲硅薄缇や綋镄勭壒寰侊纴钥屼笉鏄鍗曚釜瀵硅薄镄勭壒寰併侸ava涓澶ч噺搴旂敤浜嗛润镐佹柟娉曞拰灞炴э纴杩欐槸涓涓阃氩父镄勬妧宸с备絾鏄杩欑嶆妧宸у湪寰埚氲瑷涓涓嶈棰戠箒鍦颁娇鐢ㄣ
鐞呜В闱欐佹柟娉曞拰灞炴у逛簬鐞呜В绫讳笌瀵硅薄镄勫叧绯绘槸鍗佸垎链夊府锷╃殑锛屽湪澶ч噺镄凧ava瑙勮寖涓锛岄润镐佹柟娉曞拰灞炴ц棰戠箒浣跨敤銆傚洜姝ゅ︿範钥呭簲璇ョ悊瑙i润镐佹柟娉曞拰灞炴с侸ava鍦ㄦ柟娉曞拰灞炴х殑璋幂敤涓婃槸涓镊寸殑锛屽尯鍒鍙琛ㄧ幇鍦ㄥ0鏄庣殑镞跺欙纴杩椤拰c++鏄涓嶅悓镄勚
3鍒濆﹁呰缮闇鏄庣槠JAVA镄勪笁涓鎶链骞冲彴镄勫叧绯
Java鍒嗕负涓変釜浣撶郴锛屽垎鍒涓筼avaSE锛圝2SE锛孞ava2PlatformStandardEdition锛屾爣鍑嗙増锛夈侸avaEE锛圝2EE锛孞ava2Platform,EnterpriseEdition锛屼紒涓氱増锛夈侸avaME锛圝2ME锛孞ava2PlatformMicroEdition锛屽井鍨嬬増锛夈
瑕佺煡阆搄ava鏄鍒嗕袱閮ㄥ垎镄勶细涓涓鏄缂栬疟锛屼竴涓鏄杩愯屻
javac锛氲礋璐g殑鏄缂栬疟镄勯儴鍒嗭纴褰撴墽琛宩avac镞讹纴浼氩惎锷╦ava镄勭紪璇戝櫒绋嫔簭銆傚规寚瀹氭墿灞曞悕镄.java鏂囦欢杩涜岀紪璇戙傜敓鎴愪简jvm鍙浠ヨ瘑鍒镄勫瓧鑺傜爜鏂囦欢銆备篃灏辨槸class鏂囦欢锛屼篃灏辨槸java镄勮繍琛岀▼搴忋
java锛氲礋璐h繍琛岀殑閮ㄥ垎.浼氩惎锷╦vm.锷犺浇杩愯屾椂镓闇镄勭被搴,骞跺筩lass鏂囦欢杩涜屾墽琛.涓涓鏂囦欢瑕佽镓ц,蹇呴’瑕佹湁涓涓镓ц岀殑璧峰嬬偣,杩欎釜璧峰嬬偣灏辨槸main鍑芥暟銆
4鎺屾彙JAVA浠g爜镄勫熀链镙煎纺
1銆丣ava娉ㄩ喷灏藉彲鑳藉叏闱
瀵逛簬鏂规硶镄勬敞閲婂簲璇ュ寘钖璇︾粏镄勫叆鍙傚拰缁撴灉璇存槑锛屾湁寮傚父鎶涘嚭镄勬儏鍐典篃瑕佽︾粏鍙栾堪锛氱被镄勬敞閲婂簲璇ュ寘钖绫荤殑锷熻兘璇存槑銆佷綔钥呭拰淇鏀硅呫
2銆佸氭′娇鐢ㄧ殑鐩稿悓鍙橀噺链濂藉綊绾虫垚甯搁噺
澶氩勪娇鐢ㄧ殑鐩稿悓鍊肩殑鍙橀噺搴旇ュ敖閲忓綊绾充负涓涓甯搁噺锛屾柟渚挎棩钖庣殑缁存姢銆
3銆佸敖閲忓皯镄勫湪寰鐜涓镓ц屾柟娉曡皟鐢
灏介噺鍦ㄥ惊鐜涓灏戝仛涓浜涘彲阆垮厤镄勬柟娉曡皟鐢锛岃繖镙峰彲浠ヨ妭鐪佹柟娉曟爤镄勫垱寤恒备緥濡傦细
for锛坕nti=0;i<list.size锛堬级锛沬++锛墈
System.out.println锛坕锛夛绂
}
鍙浠ヤ慨鏀逛负锛
for锛坕nti=0,size=list.size锛堬级锛沬<size;i++锛墈
System.out.println锛坕锛夛绂
}
4銆佸父閲忕殑瀹氢箟鍙浠ユ斁鍒版帴鍙d腑
鍦↗ava涓锛屾帴鍙i噷鍙鍏佽稿瓨鍦ㄥ父閲忥纴锲犳ゆ妸甯搁噺鏀惧埌鎺ュ彛涓澹版槑灏卞彲浠ョ渷铡籶ublicstaticfinal杩椤嚑涓鍏抽敭璇嶃
Ⅳ JAVA语言是什么时候诞生的谁有详细资料
JAVA语言是1995年诞生。
任职于太阳微系统(Sun Microsystems)的詹姆斯·高斯林等人于1990年代初开发Java语言的雏形,最初被命名为Oak,目标设置在家用电器等小型系统的编程语言,应用在电视机、电话、闹钟、烤面包机等家用电器的控制和通信。
由于这些智能化家电的市场需求没有预期的高,Sun公司放弃了该项计划。随着1990年代互联网的发展,Sun公司看见Oak在互联网上应用的前景,于是改造了Oak,于1995年5月以Java的名称正式发布。Java伴随着互联网的迅猛发展而发展,逐渐成为重要的网络编程语言。
(4)java读者写者扩展阅读
特点
1、Java看起来设计得很像C++,但是为了使语言小和容易熟悉,设计者们把C++语言中许多可用的特征去掉了,这些特征是一般程序员很少使用的。
2、Java设计成支持在网络上应用,它是分布式语言。Java既支持各种层次的网络连接,又以Socket类支持可靠的流网络连接,所以用户可以产生分布式的客户机和服务器。
3、Java编译程序生成字节码(byte-code),而不是通常的机器码。Java字节码提供对体系结构中性的目标文件格式,代码设计成可有效地传送程序到多个平台。