作家吴晓波把难以被机器替代的能力,称为“柔软的能力”。目前看上去,有三种能力,机器不大可能实现。
机器提供的服务是没有人性的,也不会有人格魅力,更不会感动人心。这注定了,有些感受是机器无法提供的。最简单的一个例子,老奶奶在街上突然摔倒了,你会感到心痛和惊慌,要是一台机器突然故障了,你大概不会对机器产生同情心。所以,一个富有人格魅力和人性的人,在计算机主导的时代,是有优势的;相反的,一个没有个性、人云亦云、千面一律、会消失在流水线上的人,则天然具有竞争劣势。
计算机只能根据算法,做出下一步行为,没法超出算法的范围。这意味着,只要掌握了算法,就掌握了计算机的一举一动。人类则是难以预测的,常常会有天马行空的创意。机器最难以与人类竞争的,就是创造力。目前,还没有一种软件,能够写出一部人类爱看的小说,估计将来也难有。另外,科学家曾经有过争论,计算机会不会“顿悟”?目前看上去,大概也是不会的。
美国经济学家熊彼得曾经说过,生产力增加的主要原因,除了资本和劳动力,就是企业家能力。一个优秀的领导者,可以团结所有资源,创造出超额利润,最典型的就是乔布斯那样的人物。计算机没有办法团结领导一群人,齐心协力完成一个使命。
作为个人来说,人生规划的时候,应该尽量发展这些能力,才能避免与机器“抢工作”。
首先在报错的仓库本地打开命令行(CMD),然后:
git pull origin master --allow-unrelated-histories
add
和 commit
相应文件git push origin master
此时就能够上传成功了
学习Nacos配置启动,用的Windows,部署集群刚开始用的8846-8847-8848
三个端口,结果8847
一直报端口占用,cmd查看端口并没有被占用。把8846
和8848
都停掉后,就没占用了,但是如果先启动8847
,8846
和8848
都起不来了。。。。刚开始以为不能用同一台机器部署集群,但是百度很多都是用同一个电脑测试的集群,把8847
端口改成8850
就可以了,越想越奇怪,我又增加了个8847
,结果还是不行,把8847
改成8844
又可以了。。。。。
不知道这是不是个官方Bug,记录一下吧。有懂的大佬欢迎指点解答~~
PS:后来知道是官方的设定导致的。。文末有答案。。
application.properties
和cluster.conf
)的修改!Nacos版本2.0.3
代码内含有测试main方法,可直接复制运行。
javapackage top.oldmoon.api.compiler;
import com.itranswarp.compiler.JavaStringCompiler;
import lombok.extern.slf4j.Slf4j;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.Map;
/**
* @Description java编译器工具类
* @Author dingdangdog
* @Date 2021/8/25 16:38
*/
@Slf4j
public class CompilerUtilOm {
/**
* 动态编译
*
* @param className 类名
* @param packageName 包名
* @param classSource 类源码
* @return java.lang.Class
* @author dingdangdog
* @date 2021/8/26 10:08
*/
public static Class compiler(String className, String packageName, String classSource) throws IOException, ClassNotFoundException {
String fullName = packageName + "." + className;
// 编译器
JavaStringCompiler compiler = new JavaStringCompiler();
Map<String, byte[]> javaFile = compiler.compile(className + ".java", classSource);
// 加载内存中byte到Class<?>对象
Class<?> clazz = compiler.loadClass(fullName, javaFile);
return clazz;
}
/**
* 反射获取类实例
*
* @param clazz 类
* @return java.lang.Object
* @author dingdangdog
* @date 2021/8/26 10:06
*/
public static Object newInstance(Class clazz) throws InstantiationException, IllegalAccessException {
// 类实例化
Object object = clazz.newInstance();
return object;
}
/**
* 通过反射,获取想要的方法
*
* @param clazz 方法持有类
* @param methodName 方法名
* @param paramTypes ... 方法参数类(可以传入多个参数类)
* @return java.lang.reflect.Method
* @author dingdangdog
* @date 2021/8/26 10:05
*/
public static Method getMethod(Class clazz, String methodName, Class... paramTypes) throws NoSuchMethodException {
Method method = clazz.getMethod(methodName, paramTypes);
return method;
}
/**
* 反射方法执行
*
* @param method 方法实例
* @param object 方法持有者实例
* @param param ... 方法参数(可以传入多个参数)
* @return java.lang.Object
* @author dingdangdog
* @date 2021/8/26 10:01
*/
public static Object invokeMethod(Method method, Object object, Object... param) throws IllegalAccessException, InvocationTargetException {
try {
return method.invoke(object, param);
} catch (IllegalAccessException | InvocationTargetException e) {
log.error("++++++++++++++++++++{}方法执行出错++++++++++++++++++++", method.getName());
e.printStackTrace();
}
return null;
}
public static void main(String[] args) throws Exception {
// 传入String类型的代码
String source = "package oldmoon.api.compiler;" +
"import java.util.Arrays;" +
"public class Main {" +
"public static String test(String[] args, String test) {" +
"System.out.println(Arrays.toString(args));" +
"System.out.println(test);" +
"return \"testReturn\";" +
"}" +
"}";
String[] param = new String[]{"1", "2", "3"};
String test = new String("test");
try {
// 编译字节码对象
Class mainClazz = CompilerUtilOm.compiler("Main", "oldmoon.api.compiler", source);
// 实例化对象
Object mainObject = CompilerUtilOm.newInstance(mainClazz);
// 反射获取方法
Method mainMethod = CompilerUtilOm.getMethod(mainClazz, "test", param.getClass(), test.getClass());
// 执行方法,获取返回值
Object result = CompilerUtilOm.invokeMethod(mainMethod, mainObject, param, test);
// 输出返回值
System.out.println(result);
} catch (IOException | ClassNotFoundException e) {
log.error("++++++++++++++++++++动态编译出错++++++++++++++++++++");
e.printStackTrace();
} catch (InstantiationException e) {
log.error("++++++++++++++++++++实例化出错++++++++++++++++++++");
e.printStackTrace();
} catch (NoSuchMethodException e) {
log.error("++++++++++++++++++++反射获取方法出错++++++++++++++++++++");
e.printStackTrace();
} catch (IllegalAccessException e) {
log.error("++++++++++++++++++++反射实例化出错 || 反射执行方法出错++++++++++++++++++++");
e.printStackTrace();
} catch (InvocationTargetException e) {
log.error("++++++++++++++++++++反射执行方法出错++++++++++++++++++++");
e.printStackTrace();
} catch (Exception e) {
log.error("++++++++++++++++++++未知错误++++++++++++++++++++");
e.printStackTrace();
}
}
}
java// 排除api中不引数据库导致的报错包
@ComponentScan(excludeFilters =
{
@ComponentScan.Filter(type = FilterType.REGEX,pattern = "top.oldmoon.aop.log.service.*")
})
通过该注解配置,可以实现剔除某个包,让Spring不自动扫描该包下的内容。
适用于依赖api或者其他包时,一些不必要或不支持的对象被扫描到,引发的报错或内存占用等问题。通过该配置可以去掉这些不必要的扫描。