2024-05-25
老狗随想
00

作家吴晓波把难以被机器替代的能力,称为“柔软的能力”。目前看上去,有三种能力,机器不大可能实现。

人性化和人格魅力

机器提供的服务是没有人性的,也不会有人格魅力,更不会感动人心。这注定了,有些感受是机器无法提供的。最简单的一个例子,老奶奶在街上突然摔倒了,你会感到心痛和惊慌,要是一台机器突然故障了,你大概不会对机器产生同情心。所以,一个富有人格魅力和人性的人,在计算机主导的时代,是有优势的;相反的,一个没有个性、人云亦云、千面一律、会消失在流水线上的人,则天然具有竞争劣势。

创意

计算机只能根据算法,做出下一步行为,没法超出算法的范围。这意味着,只要掌握了算法,就掌握了计算机的一举一动。人类则是难以预测的,常常会有天马行空的创意。机器最难以与人类竞争的,就是创造力。目前,还没有一种软件,能够写出一部人类爱看的小说,估计将来也难有。另外,科学家曾经有过争论,计算机会不会“顿悟”?目前看上去,大概也是不会的。

决策和领导力(即企业家能力)

美国经济学家熊彼得曾经说过,生产力增加的主要原因,除了资本和劳动力,就是企业家能力。一个优秀的领导者,可以团结所有资源,创造出超额利润,最典型的就是乔布斯那样的人物。计算机没有办法团结领导一群人,齐心协力完成一个使命。

作为个人来说,人生规划的时候,应该尽量发展这些能力,才能避免与机器“抢工作”。

2024-05-25
编程与技术
00

首先在报错的仓库本地打开命令行(CMD),然后:

  1. 执行  git pull origin master --allow-unrelated-histories
  2. 重新 addcommit相应文件
  3. 执行  git push origin master

此时就能够上传成功了

2024-05-25
编程与技术
00

问题始末

学习Nacos配置启动,用的Windows,部署集群刚开始用的8846-8847-8848三个端口,结果8847一直报端口占用,cmd查看端口并没有被占用。把88468848都停掉后,就没占用了,但是如果先启动884788468848都起不来了。。。。刚开始以为不能用同一台机器部署集群,但是百度很多都是用同一个电脑测试的集群,把8847端口改成8850就可以了,越想越奇怪,我又增加了个8847,结果还是不行,把8847改成8844又可以了。。。。。

不知道这是不是个官方Bug,记录一下吧。有懂的大佬欢迎指点解答~~

PS:后来知道是官方的设定导致的。。文末有答案。。

  • 说明:所有节点使用的是同一套文件,只进行了配置文件(application.propertiescluster.conf)的修改!Nacos版本2.0.3
2024-05-25
编程与技术
00

直接上源码(注释很清晰)

代码内含有测试main方法,可直接复制运行。

java
package 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(); } } }
2024-05-25
编程与技术
00

springboot启动类剔除扫描某个包

java
// 排除api中不引数据库导致的报错包 @ComponentScan(excludeFilters = { @ComponentScan.Filter(type = FilterType.REGEX,pattern = "top.oldmoon.aop.log.service.*") })

通过该注解配置,可以实现剔除某个包,让Spring不自动扫描该包下的内容。

适用于依赖api或者其他包时,一些不必要或不支持的对象被扫描到,引发的报错或内存占用等问题。通过该配置可以去掉这些不必要的扫描。