java 中 try 与 catch 的使用

本贴最后更新于 2406 天前,其中的信息可能已经时移俗易

转自 CSDN

try{

//代码区
}catch(Exception e){
//异常处理
}
代码区如果有错误,就会返回所写异常的处理。

首先要清楚,如果没有 try 的话,出现异常会导致程序崩溃。
而 try 则可以保证程序的正常运行下去,比如说:
try{
int i = 1/0;
}catch(Exception e){
........
}
一个计算的话,如果除数为 0,则会报错,如果没有 try 的话,程序直接崩溃。用 try 的话,则可以让程序运行下去,并且输出为什么出错!

try catch 是捕捉 try 部分的异常,当你没有 trycatch 的时候,如果出现异常则程序报错,加上 trycatch,出现异常程序正常运行,只是把错误信息存储到 Exception 里,所以 catch 是用来提取异常信息的,你可以在 Catch 部分加上一句 System.out.println(e.ToString());,如果出现异常可以把异常打印出来

Java 的异常处理机制(try…catch…finally)

1 引子
try…catch…finally 恐怕是大家再熟悉不过的语句了,而且感觉用起来也是很简单,逻辑上似乎也是很容易理解。不过,我亲自体验的“教训”告诉我,这个东西可不是想象中的那么简单、听话。不信?那你看看下面的代码,“猜猜”它执行后的结果会是什么?不要往后看答案、也不许执行代码看真正答案哦。如果你的答案是正确,那么这篇文章你就不用浪费时间看啦。
public class TestException
{
public TestException()
{
}
boolean testEx() throws Exception
{
boolean ret = true;
try
{
ret = testEx1();
}
catch (Exception e)
{
System.out.println("testEx, catch exception");
ret = false;
throw e;
}
finally
{
System.out.println("testEx, finally; return value=" + ret);
return ret;
}
}
boolean testEx1() throws Exception
{
boolean ret = true;
try
{
ret = testEx2();
if (!ret)
{
return false;
}
System.out.println("testEx1, at the end of try");
return ret;
}
catch (Exception e)
{
System.out.println("testEx1, catch exception");
ret = false;
throw e;
}
finally
{
System.out.println("testEx1, finally; return value=" + ret);
return ret;
}
}
boolean testEx2() throws Exception
{
boolean ret = true;
try
{
int b = 12;
int c;
for (int i = 2; i >= -2; i--)
{
c = b / i;
System.out.println("i=" + i);
}
return true;
}
catch (Exception e)
{
System.out.println("testEx2, catch exception");
ret = false;
throw e;
}
finally
{
System.out.println("testEx2, finally; return value=" + ret);
return ret;
}
}
public static void main(String[] args)
{
TestException testException1 = new TestException();
try
{
testException1.testEx();
}
catch (Exception e)
{
e.printStackTrace();
}
}
}
你的答案是什么?是下面的答案吗?
i=2
i=1
testEx2, catch exception
testEx2, finally; return value=false
testEx1, catch exception
testEx1, finally; return value=false
testEx, catch exception
testEx, finally; return value=false
如果你的答案真的如上面所说,那么你错啦。^_^,那就建议你仔细看一看这篇文章或者拿上面的代码按各种不同的情况修改、执行、测试,你会发现有很多事情不是原来想象中的那么简单的。
现在公布正确答案:
i=2
i=1
testEx2, catch exception
testEx2, finally; return value=false
testEx1, finally; return value=false
testEx, finally; return value=false

2 基础知识

2.1 相关概念
例外是在程序运行过程中发生的异常事件,比如除 0 溢出、数组越界、文件找不到等,这些事件的发生将阻止程序的正常运行。为了加强程序的鲁棒性,程序设计时,必须考虑到可能发生的异常事件并做出相应的处理。C 语言中,通过使用 if 语句来判断是否出现了例外,同时,调用函数通过被调用函数的返回值感知在被调用函数中产生的例外事件并进行处理。全程变量 ErroNo 常常用来反映一个异常事件的类型。但是,这种错误处理机制会导致不少问题。
Java 通过面向对象的方法来处理例外。在一个方法的运行过程中,如果发生了例外,则这个方法生成代表该例外的一个对象,并把它交给运行时系统,运行时系统寻找相应的代码来处理这一例外。我们把生成例外对象并把它提交给运行时系统的过程称为抛弃(throw)一个例外。运行时系统在方法的调用栈中查找,从生成例外的方法开始进行回朔,直到找到包含相应例外处理的方法为止,这一个过程称为捕获(catch)一个例外。
2.2 Throwable 类及其子类
 用面向对象的方法处理例外,就必须建立类的层次。类 Throwable 位于这一类层次的最顶层,只有它的后代才可以做为一个例外被抛弃。图 1 表示了例外处理的类层次。
从图中可以看出,类 Throwable 有两个直接子类:Error 和 Exception。Error 类对象(如动态连接错误等),由 Java 虚拟机生成并抛弃(通常,Java 程序不对这类例外进行处理);Exception 类对象是 Java 程序处理或抛弃的对象。它有各种不同的子类分别对应于不同类型的例外。其中类 RuntimeException 代表运行时由 Java 虚拟机生成的例外,如算术运算例外 ArithmeticException(由除 0 错等导致)、数组越界例外 ArrayIndexOutOfBoundsException 等;其它则为非运行时例外,如输入输出例外 IOException 等。Java 编译器要求 Java 程序必须捕获或声明所有的非运行时例外,但对运行时例外可以不做处理。

2.3  异常处理关键字
Java 的异常处理是通过 5 个关键字来实现的:try,catch,throw,throws,finally。JB 的在线帮助中对这几个关键字是这样解释的:
Throws: Lists the exceptions a method could throw.
Throw: Transfers control of the method to the exception handler.
Try: Opening exception-handling statement.
Catch: Captures the exception.
Finally: Runs its code before terminating the program.
2.3.1 try 语句 
try 语句用大括号{}指定了一段代码,该段代码可能会抛弃一个或多个例外。
2.3.2 catch 语句 
catch 语句的参数类似于方法的声明,包括一个例外类型和一个例外对象。例外类型必须为 Throwable 类的子类,它指明了 catch 语句所处理的例外类型,例外对象则由运行时系统在 try 所指定的代码块中生成并被捕获,大括号中包含对象的处理,其中可以调用对象的方法。
catch 语句可以有多个,分别处理不同类的例外。Java 运行时系统从上到下分别对每个 catch 语句处理的例外类型进行检测,直到找到类型相匹配的 catch 语句为止。这里,类型匹配指 catch 所处理的例外类型与生成的例外对象的类型完全一致或者是它的父类,因此,catch 语句的排列顺序应该是从特殊到一般。
也可以用一个 catch 语句处理多个例外类型,这时它的例外类型参数应该是这多个例外类型的父类,程序设计中要根据具体的情况来选择 catch 语句的例外处理类型。 
2.3.3 finally 语句 
try 所限定的代码中,当抛弃一个例外时,其后的代码不会被执行。通过 finally 语句可以指定一块代码。无论 try 所指定的程序块中抛弃或不抛弃例外,也无论 catch 语句的例外类型是否与所抛弃的例外的类型一致,finally 所指定的代码都要被执行,它提供了统一的出口。通常在 finally 语句中可以进行资源的清除工作。如关闭打开的文件等。
2.3.4 throws 语句 
throws 总是出现在一个函数头中,用来标明该成员函数可能抛出的各种异常。对大多数 Exception 子类来说,Java 编译器会强迫你声明在一个成员函数中抛出的异常的类型。如果异常的类型是 Error 或 RuntimeException, 或它们的子类,这个规则不起作用, 因为这在程序的正常部分中是不期待出现的。 如果你想明确地抛出一个 RuntimeException,你必须用 throws 语句来声明它的类型。
2.3.5 throw 语句 
throw 总是出现在函数体中,用来抛出一个异常。程序会在 throw 语句后立即终止,它后面的语句执行不到,然后在包含它的所有 try 块中(可能在上层调用函数中)从里向外寻找含有与其匹配的 catch 子句的 try 块。

3 关键字及其中语句流程详解

3.1 try 的嵌套
你可以在一个成员函数调用的外面写一个 try 语句,在这个成员函数内部,写另一个 try 语句保护其他代码。每当遇到一个 try 语句,异常的框架就放到堆栈上面,直到所有的 try 语句都完成。如果下一级的 try 语句没有对某种异常进行处理,堆栈就会展开,直到遇到有处理这种异常的 try 语句。下面是一个 try 语句嵌套的例子。
class MultiNest {
static void procedure() {
try {
int a = 0;
int b = 42/a;
} catch(java.lang.ArithmeticException e) {
System.out.println("in procedure, catch ArithmeticException: " + e);
}
}
public static void main(String args[]) {
try {
procedure();
} catch(java.lang. Exception e) {
System.out.println("in main, catch Exception: " + e);
}
}
}
这个例子执行的结果为:
in procedure, catch ArithmeticException: java.lang.ArithmeticException: / by zero
成员函数 procedure 里有自己的 try/catch 控制,所以 main 不用去处理 ArrayIndexOutOfBoundsException;当然如果如同最开始我们做测试的例子一样,在 procedure 中 catch 到异常时使用 throw e;语句将异常抛出,那么 main 当然还是能够捕捉并处理这个 procedure 抛出来的异常。例如在 procedure 函数的 catch 中的 System.out 语句后面增加 throw e;语句之后,执行结果就变为:
in procedure, catch ArithmeticException: java.lang.ArithmeticException: / by zero
in main, catch Exception: java.lang.ArithmeticException: / by zero

3.2 try-catch 程序块的执行流程以及执行结果
相对于 try-catch-finally 程序块而言,try-catch 的执行流程以及执行结果还是比较简单的。
首先执行的是 try 语句块中的语句,这时可能会有以下三种情况:
1.如果 try 块中所有语句正常执行完毕,那么就不会有其他的“动做”被执行,整个 try-catch 程序块正常完成。
2.如果 try 语句块在执行过程中碰到异常 V,这时又分为两种情况进行处理:
--> 如果异常 V 能够被与 try 相应的 catch 块 catch 到,那么第一个 catch 到这个异常的 catch 块(也是离 try 最近的一个与异常 V 匹配的 catch 块)将被执行;如果 catch 块执行正常,那么 try-catch 程序块的结果就是“正常完成”;如果该 catch 块由于原因 R 突然中止,那么 try-catch 程序块的结果就是“由于原因 R 突然中止(completes abruptly)”。
--> 如果异常 V 没有 catch 块与之匹配,那么这个 try-catch 程序块的结果就是“由于抛出异常 V 而突然中止(completes abruptly)”。
3. 如果 try 由于其他原因 R 突然中止(completes abruptly),那么这个 try-catch 程序块的结果就是“由于原因 R 突然中止(completes abruptly)”。

3.3 try-catch-finally 程序块的执行流程以及执行结果
try-catch-finally 程序块的执行流程以及执行结果比较复杂。
首先执行的是 try 语句块中的语句,这时可能会有以下三种情况:
1.如果 try 块中所有语句正常执行完毕,那么 finally 块的居于就会被执行,这时分为以下两种情况:
--> 如果 finally 块执行顺利,那么整个 try-catch-finally 程序块正常完成。
--> 如果 finally 块由于原因 R 突然中止,那么 try-catch-finally 程序块的结局是“由于原因 R 突然中止(completes abruptly)”
2.如果 try 语句块在执行过程中碰到异常 V,这时又分为两种情况进行处理:
--> 如果异常 V 能够被与 try 相应的 catch 块 catch 到,那么第一个 catch 到这个异常的 catch 块(也是离 try 最近的一个与异常 V 匹配的 catch 块)将被执行;这时就会有两种执行结果:
--> 如果 catch 块执行正常,那么 finally 块将会被执行,这时分为两种情况:
--> 如果 finally 块执行顺利,那么整个 try-catch-finally 程序块正常完成。
--> 如果 finally 块由于原因 R 突然中止,那么 try-catch-finally 程序块的结局是“由于原因 R 突然中止(completes abruptly)”
--> 如果 catch 块由于原因 R 突然中止,那么 finally 模块将被执行,分为两种情况:
--> 如果如果 finally 块执行顺利,那么整个 try-catch-finally 程序块的结局是“由于原因 R 突然中止(completes abruptly)”。
--> 如果 finally 块由于原因 S 突然中止,那么整个 try-catch-finally 程序块的结局是“由于原因 S 突然中止(completes abruptly)”,原因 R 将被抛弃。
(注意,这里就正好和我们的例子相符合,虽然我们在 testEx2 中使用 throw e 抛出了异常,但是由于 testEx2 中有 finally 块,而 finally 块的执行结果是 complete abruptly 的(别小看这个用得最多的 return,它也是一种导致 complete abruptly 的原因之一啊——后文中有关于导致 complete abruptly 的原因分析),所以整个 try-catch-finally 程序块的结果是“complete abruptly”,所以在 testEx1 中调用 testEx2 时是捕捉不到 testEx1 中抛出的那个异常的,而只能将 finally 中的 return 结果获取到。
如果在你的代码中期望通过捕捉被调用的下级函数的异常来给定返回值,那么一定要注意你所调用的下级函数中的 finally 语句,它有可能会使你 throw 出来的异常并不能真正被上级调用函数可见的。当然这种情况是可以避免的,以 testEx2 为例:如果你一定要使用 finally 而且又要将 catch 中 throw 的 e 在 testEx1 中被捕获到,那么你去掉 testEx2 中的 finally 中的 return 就可以了。
这个事情已经在 OMC2.0 的 MIB 中出现过啦:服务器的异常不能完全被反馈到客户端。)
--> 如果异常 V 没有 catch 块与之匹配,那么 finally 模块将被执行,分为两种情况:
--> 如果 finally 块执行顺利,那么整个 try-catch-finally 程序块的结局就是“由于抛出异常 V 而突然中止(completes abruptly)”。
--> 如果 finally 块由于原因 S 突然中止,那么整个 try-catch-finally 程序块的结局是“由于原因 S 突然中止(completes abruptly)”,异常 V 将被抛弃。
3.如果 try 由于其他原因 R 突然中止(completes abruptly),那么 finally 块被执行,分为两种情况:
--> 如果 finally 块执行顺利,那么整个 try-catch-finally 程序块的结局是“由于原因 R 突然中止(completes abruptly)”。
--> 如果 finally 块由于原因 S 突然中止,那么整个 try-catch-finally 程序块的结局是“由于原因 S 突然中止(completes abruptly)”,原因 R 将被抛弃。
3.4 try-catch-finally 程序块中的 return
从上面的 try-catch-finally 程序块的执行流程以及执行结果一节中可以看出无论 try 或 catch 中发生了什么情况,finally 都是会被执行的,那么写在 try 或者 catch 中的 return 语句也就不会真正的从该函数中跳出了,它的作用在这种情况下就变成了将控制权(语句流程)转到 finally 块中;这种情况下一定要注意返回值的处理。
例如,在 try 或者 catch 中 return false 了,而在 finally 中又 return true,那么这种情况下不要期待你的 try 或者 catch 中的 return false 的返回值 false 被上级调用函数获取到,上级调用函数能够获取到的只是 finally 中的返回值,因为 try 或者 catch 中的 return 语句只是转移控制权的作用。
3.5 如何抛出异常
如果你知道你写的某个函数有可能抛出异常,而你又不想在这个函数中对异常进行处理,只是想把它抛出去让调用这个函数的上级调用函数进行处理,那么有两种方式可供选择:
第一种方式:直接在函数头中 throws SomeException,函数体中不需要 try/catch。比如将最开始的例子中的 testEx2 改为下面的方式,那么 testEx1 就能捕捉到 testEx2 抛出的异常了。
boolean testEx2() throws Exception{
boolean ret = true;
int b=12;
int c;
for (int i=2;i>=-2;i--){
c=b/i;
System.out.println("i="+i);
}
return true;
}
第二种方式:使用 try/catch,在 catch 中进行一定的处理之后(如果有必要的话)抛出某种异常。例如上面的 testEx2 改为下面的方式,testEx1 也能捕获到它抛出的异常:
boolean testEx2() throws Exception{
boolean ret = true;
try{
int b=12;
int c;
for (int i=2;i>=-2;i--){
c=b/i;
System.out.println("i="+i);
}
return true;
}catch (Exception e){
System.out.println("testEx2, catch exception");
Throw e;
}
}
第三种方法:使用 try/catch/finally,在 catch 中进行一定的处理之后(如果有必要的话)抛出某种异常。例如上面的 testEx2 改为下面的方式,testEx1 也能捕获到它抛出的异常:
boolean testEx2() throws Exception{
boolean ret = true;
try{
int b=12;
int c;
for (int i=2;i>=-2;i--){
c=b/i;
System.out.println("i="+i);
throw new Exception("aaa");
}
return true;
}catch (java.lang.ArithmeticException e){
System.out.println("testEx2, catch exception");
ret = false;
throw new Exception("aaa");
}finally{
System.out.println("testEx2, finally; return value="+ret);
}
}
4 关于 abrupt completion
前面提到了 complete abruptly(暂且理解为“突然中止”或者“异常结束”吧),它主要包含了两种大的情形:abrupt completion of expressions and statements,下面就分两种情况进行解释。
4.1 Normal and Abrupt Completion of Evaluation
每一个表达式(expression)都有一种使得其包含的计算得以一步步进行的正常模式,如果每一步计算都被执行且没有异常抛出,那么就称这个表达式“正常结束(complete normally)”;如果这个表达式的计算抛出了异常,就称为“异常结束(complete abruptly)”。异常结束通常有一个相关联的原因(associated reason),通常也就是抛出一个异常 V。
与表达式、操作符相关的运行期异常有:
-->A class instance creation expression, array creation expression , or string concatenation operatior expression throws an OutOfMemoryError if there is insufficient memory available.
-->An array creation expression throws a NegativeArraySizeException if the value of any dimension expression is less than zero.
-->A field access throws a NullPointerException if the value of the object reference expression is null.
-->A method invocation expression that invokes an instance method throws a NullPointerException if the target reference is null.
-->An array access throws a NullPointerException if the value of the array reference expression is null.
-->An array access throws an ArrayIndexOutOfBoundsException if the value of the array index expression is negative or greater than or equal to the length of the array.
-->A cast throws a ClassCastException if a cast is found to be impermissible at run time.
-->An integer division or integer remainder operator throws an ArithmeticException if the value of the right-hand operand expression is zero.
-->An assignment to an array component of reference type throws an ArrayStoreException when the value to be assigned is not compatible with the component type of the array.
4.2 Normal and Abrupt Completion of Statements
正常情况我们就不多说了,在这里主要是列出了 abrupt completion 的几种情况:
-->break, continue, and return 语句将导致控制权的转换,从而使得 statements 不能正常地、完整地执行。
--> 某些表达式的计算也可能从 java 虚拟机抛出异常,这些表达式在上一小节中已经总结过了;一个显式的的 throw 语句也将导致异常的抛出。抛出异常也是导致控制权的转换的原因(或者说是阻止 statement 正常结束的原因)。
如果上述事件发生了,那么这些 statement 就有可能使得其正常情况下应该都执行的语句不能完全被执行到,那么这些 statement 也就是被称为是 complete abruptly.
导致 abrupt completion 的几种原因:
-->A break with no label
-->A break with a given label
-->A continue with no label
-->A continue with a given label
-->A return with no value
-->A return with a given value A
-->throw with a given value, including exceptions thrown by the Java virtual machine
5 关于我们的编程的一点建议
弄清楚 try-catch-finally 的执行情况后我们才能正确使用它。
如果我们使用的是 try-catch-finally 语句块,而我们又需要保证有异常时能够抛出异常,那么在 finally 语句中就不要使用 return 语句了(finally 语句块的最重要的作用应该是释放申请的资源),因为 finally 中的 return 语句会导致我们的 throw e 被抛弃,在这个 try-catch-finally 的外面将只能看到 finally 中的返回值(除非在 finally 中抛出异常)。(我们需要记住:不仅 throw 语句是 abrupt completion 的原因,return、break、continue 等这些看起来很正常的语句也是导致 abrupt completion 的原因。)

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    61 引用 • 29 回帖 • 8 关注
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    108 引用 • 153 回帖 • 1 关注
  • PWL

    组织简介

    用爱发电 (Programming With Love) 是一个以开源精神为核心的民间开源爱好者技术组织,“用爱发电”象征开源与贡献精神,加入组织,代表你将遵守组织的“个人开源爱好者”的各项条款。申请加入:用爱发电组织邀请帖
    用爱发电组织官网:https://programmingwithlove.stackoverflow.wiki/

    用爱发电组织的核心驱动力:

    • 遵守开源守则,体现开源&贡献精神:以分享为目的,拒绝非法牟利。
    • 自我保护:使用适当的 License 保护自己的原创作品。
    • 尊重他人:不以各种理由、各种漏洞进行未经允许的抄袭、散播、洩露;以礼相待,尊重所有对社区做出贡献的开发者;通过他人的分享习得知识,要留下足迹,表示感谢。
    • 热爱编程、热爱学习:加入组织,热爱编程是首当其要的。我们欢迎热爱讨论、分享、提问的朋友,也同样欢迎默默成就的朋友。
    • 倾听:正确并恳切对待、处理问题与建议,及时修复开源项目的 Bug ,及时与反馈者沟通。不抬杠、不无视、不辱骂。
    • 平视:不诋毁、轻视、嘲讽其他开发者,主动提出建议、施以帮助,以和谐为本。只要他人肯努力,你也可能会被昔日小看的人所超越,所以请保持谦虚。
    • 乐观且活跃:你的努力决定了你的高度。不要放弃,多年后回头俯瞰,才会发现自己已经成就往日所仰望的水平。积极地将项目开源,帮助他人学习、改进,自己也会获得相应的提升、成就与成就感。
    1 引用 • 487 回帖 • 1 关注
  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 612 关注
  • 职场

    找到自己的位置,萌新烦恼少。

    127 引用 • 1708 回帖
  • GitLab

    GitLab 是利用 Ruby 一个开源的版本管理系统,实现一个自托管的 Git 项目仓库,可通过 Web 界面操作公开或私有项目。

    46 引用 • 72 回帖
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • CAP

    CAP 指的是在一个分布式系统中, Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可兼得。

    12 引用 • 5 回帖 • 635 关注
  • OpenStack

    OpenStack 是一个云操作系统,通过数据中心可控制大型的计算、存储、网络等资源池。所有的管理通过前端界面管理员就可以完成,同样也可以通过 Web 接口让最终用户部署资源。

    10 引用 • 4 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    301 引用 • 768 回帖
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    240 引用 • 224 回帖
  • Redis

    Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

    284 引用 • 248 回帖
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 40 关注
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    35 引用 • 468 回帖 • 760 关注
  • 负能量

    上帝为你关上了一扇门,然后就去睡觉了....努力不一定能成功,但不努力一定很轻松 (° ー °〃)

    89 引用 • 1251 回帖 • 390 关注
  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 726 关注
  • frp

    frp 是一个可用于内网穿透的高性能的反向代理应用,支持 TCP、UDP、 HTTP 和 HTTPS 协议。

    17 引用 • 7 回帖 • 2 关注
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 74 关注
  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    210 引用 • 2040 回帖
  • ngrok

    ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道。

    7 引用 • 63 回帖 • 659 关注
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 616 关注
  • Word
    13 引用 • 41 回帖 • 1 关注
  • Docker

    Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。

    498 引用 • 934 回帖
  • Kubernetes

    Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。

    118 引用 • 54 回帖 • 12 关注
  • 分享

    有什么新发现就分享给大家吧!

    248 引用 • 1795 回帖
  • 浅吟主题

    Jeffrey Chen 制作的思源笔记主题,项目仓库:https://github.com/TCOTC/Whisper

    2 引用 • 32 回帖 • 1 关注
  • Oracle

    Oracle(甲骨文)公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。1989 年正式进入中国市场。2013 年,甲骨文已超越 IBM,成为继 Microsoft 后全球第二大软件公司。

    107 引用 • 127 回帖 • 339 关注