自己怎么做企业网站烟台主流网站

news/2025/9/29 17:27:41/文章来源:
自己怎么做企业网站,烟台主流网站,上海市企业服务云登录,项目交流平台前言最近看了某客时间的《Java业务开发常见错误100例》#xff0c;再结合平时踩的一些代码坑#xff0c;写写总结#xff0c;希望对大家有帮助#xff0c;感谢阅读~1. 六类典型空指针问题包装类型的空指针问题级联调用的空指针问题Equals方法左边的空指针问题ConcurrentHas… 前言最近看了某客时间的《Java业务开发常见错误100例》再结合平时踩的一些代码坑写写总结希望对大家有帮助感谢阅读~1. 六类典型空指针问题包装类型的空指针问题级联调用的空指针问题Equals方法左边的空指针问题ConcurrentHashMap 这样的容器不支持 Key 和 Value 为 null。集合数组直接获取元素对象直接获取属性1.1包装类型的空指针问题public class NullPointTest {public static void main(String[] args) throws InterruptedException {System.out.println(testInteger(null));}private static Integer testInteger(Integer i) {return i  1;  //包装类型传参可能为null直接计算则会导致空指针问题} } 1.2 级联调用的空指针问题public class NullPointTest {public static void main(String[] args) {//fruitService.getAppleService() 可能为空会导致空指针问题fruitService.getAppleService().getWeight().equals(OK);} } 1.3 Equals方法左边的空指针问题public class NullPointTest {public static void main(String[] args) {String s  null;if (s.equals(666)) { //s可能为空会导致空指针问题System.out.println(公众号捡田螺的小男孩666);}} } 1.4 ConcurrentHashMap 这样的容器不支持 KeyValue 为 null。public class NullPointTest {public static void main(String[] args) {Map map  new ConcurrentHashMap();String key  null;String value  null;map.put(key, value);} } 1.5  集合数组直接获取元素public class NullPointTest {public static void main(String[] args) {int [] arraynull;List list  null;System.out.println(array[0]); //空指针异常System.out.println(list.get(0)); //空指针一场} } 1.6 对象直接获取属性public class NullPointTest {public static void main(String[] args) {User usernull;System.out.println(user.getAge()); //空指针异常} } 2. 日期YYYY格式设置的坑日常开发经常需要对日期格式化但是呢年份设置为YYYY大写的时候是有坑的哦。反例Calendar calendar  Calendar.getInstance(); calendar.set(2019, Calendar.DECEMBER, 31);Date testDate  calendar.getTime();SimpleDateFormat dtf  new SimpleDateFormat(YYYY-MM-dd); System.out.println(2019-12-31 转 YYYY-MM-dd 格式后   dtf.format(testDate));运行结果2019-12-31 转 YYYY-MM-dd 格式后 2020-12-31 「解析」为什么明明是2019年12月31号就转了一下格式就变成了2020年12月31号了因为YYYY是基于周来计算年的它指向当天所在周属于的年份一周从周日开始算起周六结束只要本周跨年那么这一周就算下一年的了。正确姿势是使用yyyy格式。正例Calendar calendar  Calendar.getInstance(); calendar.set(2019, Calendar.DECEMBER, 31);Date testDate  calendar.getTime();SimpleDateFormat dtf  new SimpleDateFormat(yyyy-MM-dd); System.out.println(2019-12-31 转 yyyy-MM-dd 格式后   dtf.format(testDate));3.金额数值计算精度的坑看下这个浮点数计算的例子吧public class DoubleTest {public static void main(String[] args) {System.out.println(0.10.2);System.out.println(1.0-0.8);System.out.println(4.015*100);System.out.println(123.3/100);double amount1  3.15;double amount2  2.10;if (amount1 - amount2  1.05){System.out.println(OK);}} } 运行结果0.30000000000000004 0.19999999999999996 401.49999999999994 1.2329999999999999 可以发现结算结果跟我们预期不一致其实是因为计算机是以二进制存储数值的对于浮点数也是。对于计算机而言0.1无法精确表达这就是为什么浮点数会导致精确度缺失的。因此「金额计算一般都是用BigDecimal 类型」对于以上例子我们改为BigDecimal再看看运行效果System.out.println(new BigDecimal(0.1).add(new BigDecimal(0.2))); System.out.println(new BigDecimal(1.0).subtract(new BigDecimal(0.8))); System.out.println(new BigDecimal(4.015).multiply(new BigDecimal(100))); System.out.println(new BigDecimal(123.3).divide(new BigDecimal(100))); 运行结果0.3000000000000000166533453693773481063544750213623046875 0.1999999999999999555910790149937383830547332763671875 401.49999999999996802557689079549163579940795898437500 1.232999999999999971578290569595992565155029296875 发现结果还是不对「其实」使用 BigDecimal 表示和计算浮点数必须使用「字符串的构造方法」来初始化 BigDecimal正例如下public class DoubleTest {public static void main(String[] args) {System.out.println(new BigDecimal(0.1).add(new BigDecimal(0.2)));System.out.println(new BigDecimal(1.0).subtract(new BigDecimal(0.8)));System.out.println(new BigDecimal(4.015).multiply(new BigDecimal(100)));System.out.println(new BigDecimal(123.3).divide(new BigDecimal(100)));} } 在进行金额计算使用BigDecimal的时候我们还需要「注意BigDecimal的几位小数点还有它的八种舍入模式哈」。4. FileReader默认编码导致乱码问题看下这个例子public class FileReaderTest {public static void main(String[] args) throws IOException {Files.deleteIfExists(Paths.get(jay.txt));Files.write(Paths.get(jay.txt), 你好,捡田螺的小男孩.getBytes(Charset.forName(GBK)));System.out.println(系统默认编码Charset.defaultCharset());char[] chars  new char[10];String content  ;try (FileReader fileReader  new FileReader(jay.txt)) {int count;while ((count  fileReader.read(chars)) ! -1) {content  new String(chars, 0, count);}}System.out.println(content);} } 运行结果系统默认编码UTF-8 ,ݵСк 从运行结果可以知道系统默认编码是utf8demo中读取出来出现乱码了。为什么呢❝FileReader 是以当「前机器的默认字符集」来读取文件的如果希望指定字符集的话需要直接使用 InputStreamReader 和 FileInputStream。❞正例如下public class FileReaderTest {public static void main(String[] args) throws IOException {Files.deleteIfExists(Paths.get(jay.txt));Files.write(Paths.get(jay.txt), 你好,捡田螺的小男孩.getBytes(Charset.forName(GBK)));System.out.println(系统默认编码Charset.defaultCharset());char[] chars  new char[10];String content  ;try (FileInputStream fileInputStream  new FileInputStream(jay.txt);InputStreamReader inputStreamReader  new InputStreamReader(fileInputStream, Charset.forName(GBK))) {int count;while ((count  inputStreamReader.read(chars)) ! -1) {content  new String(chars, 0, count);}}System.out.println(content);} } 5. Integer缓存的坑public class IntegerTest {public static void main(String[] args) {Integer a  127;Integer b  127;System.out.println(ab: (a  b));Integer c  128;Integer d  128;System.out.println(cd: (c  d));} } 运行结果ab:true cd:false 为什么Integer值如果是128就不相等了呢「编译器会把 Integer a 127 转换为 Integer.valueOf(127)。」 我们看下源码。public static Integer valueOf(int i) {if (i  IntegerCache.low  i  IntegerCache.high)return IntegerCache.cache[i  (-IntegerCache.low)];return new Integer(i);} 可以发现i在一定范围内是会返回缓存的。❝默认情况下呢这个缓存区间就是[-128, 127]所以我们业务日常开发中如果涉及Integer值的比较需要注意这个坑哈。还有呢设置 JVM 参数加上 -XX:AutoBoxCacheMax1000是可以调整这个区间参数的大家可以自己试一下哈❞6. static静态变量依赖spring实例化变量可能导致初始化出错之前看到过类似的代码。静态变量依赖于spring容器的bean。 private static SmsService smsService  SpringContextUtils.getBean(SmsService.class); 这个静态的smsService有可能获取不到的因为类加载顺序不是确定的正确的写法可以这样如下 private static SmsService  smsService null;//使用到的时候采取获取public static SmsService getSmsService(){if(smsServicenull){smsService  SpringContextUtils.getBean(SmsService.class);}return smsService;} 7. 使用ThreadLocal线程重用导致信息错乱的坑使用ThreadLocal缓存信息有可能出现信息错乱的情况。看下下面这个例子吧。private static final ThreadLocalInteger currentUser  ThreadLocal.withInitial(() - null);GetMapping(wrong) public Map wrong(RequestParam(userId) Integer userId) {//设置用户信息之前先查询一次ThreadLocal中的用户信息String before   Thread.currentThread().getName()  :  currentUser.get();//设置用户信息到ThreadLocalcurrentUser.set(userId);//设置用户信息之后再查询一次ThreadLocal中的用户信息String after   Thread.currentThread().getName()  :  currentUser.get();//汇总输出两次查询结果Map result  new HashMap();result.put(before, before);result.put(after, after);return result; } 按理说每次获取的before应该都是null但是呢程序运行在 Tomcat 中执行程序的线程是 Tomcat 的工作线程而 Tomcat 的工作线程是基于线程池的。❝线程池会重用固定的几个线程一旦线程重用那么很可能首次从 ThreadLocal 获取的值是之前其他用户的请求遗留的值。这时ThreadLocal 中的用户信息就是其他用户的信息。❞把tomcat的工作线程设置为1server.tomcat.max-threads1 用户1请求过来会有以下结果符合预期用户2请求过来会有以下结果「不符合预期」因此使用类似 ThreadLocal 工具来存放一些数据时需要特别注意在代码运行完后显式地去清空设置的数据正例如下GetMapping(right) public Map right(RequestParam(userId) Integer userId) {String before   Thread.currentThread().getName()  :  currentUser.get();currentUser.set(userId);try {String after  Thread.currentThread().getName()  :  currentUser.get();Map result  new HashMap();result.put(before, before);result.put(after, after);return result;} finally {//在finally代码块中删除ThreadLocal中的数据确保数据不串currentUser.remove();} } 8. 疏忽switch的return和break这一点严格来说应该不算坑但是呢大家写代码的时候有些朋友容易疏忽了。直接看例子吧/** 关注公众号* 捡田螺的小男孩*/ public class SwitchTest {public static void main(String[] args) throws InterruptedException {System.out.println(testSwitch结果是testSwitch(1));}private static String testSwitch(String key) {switch (key) {case 1:System.out.println(1);case 2:System.out.println(2);return 2;case 3:System.out.println(3);default:System.out.println(返回默认值);return 4;}} } 输出结果测试switch 1 2 testSwitch结果是2 switch 是会「沿着case一直往下匹配的知道遇到return或者break。」 所以在写代码的时候留意一下是不是你要的结果。9. Arrays.asList的几个坑9.1 基本类型不能作为 Arrays.asList方法的参数否则会被当做一个参数。public class ArrayAsListTest {public static void main(String[] args) {int[] array  {1, 2, 3};List list  Arrays.asList(array);System.out.println(list.size());} } 运行结果1 Arrays.asList源码如下public static T ListT asList(T... a) {return new ArrayList(a); } 9.2 Arrays.asList 返回的 List 不支持增删操作。public class ArrayAsListTest {public static void main(String[] args) {String[] array  {1, 2, 3};List list  Arrays.asList(array);list.add(5);System.out.println(list.size());} } 运行结果Exception in thread main java.lang.UnsupportedOperationExceptionat java.util.AbstractList.add(AbstractList.java:148)at java.util.AbstractList.add(AbstractList.java:108)at object.ArrayAsListTest.main(ArrayAsListTest.java:11) Arrays.asList 返回的 List 并不是我们期望的 java.util.ArrayList而是 Arrays 的内部类 ArrayList。内部类的ArrayList没有实现add方法而是父类的add方法的实现是会抛出异常的呢。9.3 使用Arrays.asLis的时候对原始数组的修改会影响到我们获得的那个Listpublic class ArrayAsListTest {public static void main(String[] args) {String[] arr  {1, 2, 3};List list  Arrays.asList(arr);arr[1]  4;System.out.println(原始数组Arrays.toString(arr));System.out.println(list数组  list);} } 运行结果原始数组[1, 4, 3] list数组[1, 4, 3] 从运行结果可以看到原数组改变Arrays.asList转化来的list也跟着改变啦大家使用的时候要注意一下哦可以用new ArrayList(Arrays.asList(arr))包一下的。10. ArrayList.toArray() 强转的坑public class ArrayListTest {public static void main(String[] args) {ListString list  new ArrayListString(1);list.add(公众号捡田螺的小男孩);String[] array21  (String[])list.toArray();//类型转换异常} } 因为返回的是Object类型Object类型数组强转String数组会发生ClassCastException。解决方案是使用toArray()重载方法toArray(T[] a)String[] array1  list.toArray(new String[0]);//可以正常运行 11. 异常使用的几个坑11.1 不要弄丢了你的堆栈异常信息public void wrong1(){try {readFile();} catch (IOException e) {//没有把异常e取出来原始异常信息丢失  throw new RuntimeException(系统忙请稍后再试);} }public void wrong2(){try {readFile();} catch (IOException e) {//只保留了异常消息栈没有记录啦log.error(文件读取错误, {}, e.getMessage());throw new RuntimeException(系统忙请稍后再试);} } 正确的打印方式应该酱紫public void right(){try {readFile();} catch (IOException e) {//把整个IO异常都记录下来而不是只打印消息log.error(文件读取错误, e);throw new RuntimeException(系统忙请稍后再试);} } 11.2 不要把异常定义为静态变量public void testStaticExeceptionOne{try {exceptionOne();} catch (Exception ex) {log.error(exception one error, ex);}try {exceptionTwo();} catch (Exception ex) {log.error(exception two error, ex);} }private void exceptionOne() {//这里有问题throw Exceptions.ONEORTWO; }private void exceptionTwo() {//这里有问题throw Exceptions.ONEORTWO; } exceptionTwo抛出的异常很可能是 exceptionOne的异常哦。正确使用方法应该是new 一个出来。private void exceptionTwo() {throw new BusinessException(业务异常, 0001); } 11.3 生产环境不要使用e.printStackTrace();public void wrong(){try {readFile();} catch (IOException e) {//生产环境别用它e.printStackTrace();} } 因为它占用太多内存造成锁死并且日志交错混合也不易读。正确使用如下log.error(异常日志正常打印方式,e); 11.4 线程池提交过程中出现异常怎么办public class ThreadExceptionTest {public static void main(String[] args) {ExecutorService executorService  Executors.newFixedThreadPool(10);IntStream.rangeClosed(1, 10).forEach(i - executorService.submit(()- {if (i  5) {System.out.println(发生异常啦);throw new RuntimeException(error);}System.out.println(当前执行第几:  Thread.currentThread().getName() );}));executorService.shutdown();} } 运行结果当前执行第几:pool-1-thread-1 当前执行第几:pool-1-thread-2 当前执行第几:pool-1-thread-3 当前执行第几:pool-1-thread-4 发生异常啦 当前执行第几:pool-1-thread-6 当前执行第几:pool-1-thread-7 当前执行第几:pool-1-thread-8 当前执行第几:pool-1-thread-9 当前执行第几:pool-1-thread-10 可以发现如果是使用submit方法提交到线程池的异步任务异常会被吞掉的所以在日常发现中如果会有可预见的异常可以采取这几种方案处理1.在任务代码try/catch捕获异常2.通过Future对象的get方法接收抛出的异常再处理3.为工作者线程设置UncaughtExceptionHandler在uncaughtException方法中处理异常4.重写ThreadPoolExecutor的afterExecute方法处理传递的异常引用11.5 finally重新抛出的异常也要注意啦public void wrong() {try {log.info(try);//异常丢失throw new RuntimeException(try);} finally {log.info(finally);throw new RuntimeException(finally);} } 一个方法是不会出现两个异常的呢所以finally的异常会把try的「异常覆盖」。正确的使用方式应该是finally 代码块「负责自己的异常捕获和处理」。public void right() {try {log.info(try);throw new RuntimeException(try);} finally {log.info(finally);try {throw new RuntimeException(finally);} catch (Exception ex) {log.error(finally, ex);}} } 12.JSON序列化,Long类型被转成Integer类型public class JSONTest {public static void main(String[] args) {Long idValue  3000L;MapString, Object data  new HashMap(2);data.put(id, idValue);data.put(name, 捡田螺的小男孩);Assert.assertEquals(idValue, (Long) data.get(id));String jsonString  JSON.toJSONString(data);// 反序列化时Long被转为了IntegerMap map  JSON.parseObject(jsonString, Map.class);Object idObj  map.get(id);System.out.println(反序列化的类型是否为Integer(idObj instanceof Integer));Assert.assertEquals(idValue, (Long) idObj);} } 「运行结果」Exception in thread main 反序列化的类型是否为Integertrue java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.Longat object.JSONTest.main(JSONTest.java:24) ❝「注意啦」序列化为Json串后Josn串是没有Long类型呢。而且反序列化回来如果也是Object接收数字小于Interger最大值的话给转成Integer啦❞13. 使用Executors声明线程池newFixedThreadPool的OOM问题ExecutorService executor  Executors.newFixedThreadPool(10);for (int i  0; i  Integer.MAX_VALUE; i) {executor.execute(() - {try {Thread.sleep(10000);} catch (InterruptedException e) {//do nothing}});} 「IDE指定JVM参数-Xmx8m -Xms8m :」运行结果我们看下源码其实newFixedThreadPool使用的是无界队列public static ExecutorService newFixedThreadPool(int nThreads) {return new ThreadPoolExecutor(nThreads, nThreads,0L, TimeUnit.MILLISECONDS,new LinkedBlockingQueueRunnable()); }public class LinkedBlockingQueueE extends AbstractQueueEimplements BlockingQueueE, java.io.Serializable {.../*** Creates a {code LinkedBlockingQueue} with a capacity of* {link Integer#MAX_VALUE}.*/public LinkedBlockingQueue() {this(Integer.MAX_VALUE);} ... } ❝newFixedThreadPool线程池的核心线程数是固定的它使用了近乎于无界的LinkedBlockingQueue阻塞队列。当核心线程用完后任务会入队到阻塞队列如果任务执行的时间比较长没有释放会导致越来越多的任务堆积到阻塞队列最后导致机器的内存使用不停的飙升造成JVM OOM。❞14. 直接大文件或者一次性从数据库读取太多数据到内存可能导致OOM问题如果一次性把大文件或者数据库太多数据达到内存是会导致OOM的。所以为什么查询DB数据库一般都建议分批。读取文件的话一般问文件不会太大才使用Files.readAllLines()。为什么呢因为它是直接把文件都读到内存的预估下不会OOM才使用这个吧可以看下它的源码public static ListString readAllLines(Path path, Charset cs) throws IOException {try (BufferedReader reader  newBufferedReader(path, cs)) {ListString result  new ArrayList();for (;;) {String line  reader.readLine();if (line  null)break;result.add(line);}return result;} } 如果是太大的文件可以使用Files.line()按需读取当时读取文件这些一般是使用完需要「关闭资源流」的哈15. 先查询再更新/删除的并发一致性问题再日常开发中这种代码实现经常可见先查询是否有剩余可用的票再去更新票余量。if(selectIsAvailable(ticketId){ 1、deleteTicketById(ticketId) 2、给现金增加操作  }else{ return “没有可用现金券”  } 如果是并发执行很可能有问题的应该利用数据库的更新/删除的原子性正解如下if(deleteAvailableTicketById(ticketId)  1){ 1、给现金增加操作  }else{ return “没有可用现金券”  } 16. 数据库使用utf-8存储 插入表情异常的坑低版本的MySQL支持的utf8编码最大字符长度为 3 字节但是呢存储表情需要4个字节因此如果用utf8存储表情的话会报SQLException: Incorrect string value: \xF0\x9F\x98\x84 for column所以一般用utf8mb4编码去存储表情。17. 事务未生效的坑日常业务开发中我们经常跟事务打交道「事务失效」主要有以下几个场景底层数据库引擎不支持事务在非public修饰的方法使用rollbackFor属性设置错误本类方法直接调用异常被try...catch吃了导致事务失效。其中最容易踩的坑就是后面两个「注解的事务方法给本类方法直接调用」伪代码如下public class TransactionTest{public void A(){//插入一条数据//调用方法B (本地的类调用事务失效了)B();}Transactionalpublic void B(){//插入数据} } 如果异常被catch住「那事务也是会失效呢」~伪代码如下Transactional public void method(){try{//插入一条数据insertA();//更改一条数据updateB();}catch(Exception e){logger.error(异常被捕获了那你的事务就失效咯,e);} } 18. 当反射遇到方法重载的坑/***  反射demo*  author 捡田螺的小男孩*/ public class ReflectionTest {private void score(int score) {System.out.println(int grade   score);}private void score(Integer score) {System.out.println(Integer grade   score);}public static void main(String[] args) throws Exception {ReflectionTest reflectionTest  new ReflectionTest();reflectionTest.score(100);reflectionTest.score(Integer.valueOf(100));reflectionTest.getClass().getDeclaredMethod(score, Integer.TYPE).invoke(reflectionTest, Integer.valueOf(60));reflectionTest.getClass().getDeclaredMethod(score, Integer.class).invoke(reflectionTest, Integer.valueOf(60));} } 运行结果int grade 100 Integer grade 100 int grade 60 Integer grade 60 如果「不通过反射」传入Integer.valueOf(100)走的是Integer重载。但是呢反射不是根据入参类型确定方法重载的而是「以反射获取方法时传入的方法名称和参数类型来确定」的getClass().getDeclaredMethod(score, Integer.class) getClass().getDeclaredMethod(score, Integer.TYPE) 19. mysql 时间 timestamp的坑有更新语句的时候timestamp可能会自动更新为当前时间看个demoCREATE TABLE t (a int(11) DEFAULT NULL,b timestamp  NOT NULL,c timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP ) ENGINEInnoDB DEFAULT CHARSETutf8 我们可以发现 「c列」 是有CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP所以c列会随着记录更新而「更新为当前时间」。但是b列也会随着有记录更新为而「更新为当前时间」。可以使用datetime代替它,需要更新为当前时间就把now()赋值进来或者修改mysql的这个参数explicit_defaults_for_timestamp。20. mysql8数据库的时区坑之前我们对mysql数据库进行升级新版本为8.0.12。但是升级完之后发现now()函数获取到的时间比北京时间晚8小时原来是因为mysql8默认为美国那边的时间需要指定下时区jdbc:mysql://localhost:3306/test?useUnicodetruecharacterEncodingUTF-8 serverTimezoneAsia/Shanghai 参考与感谢[1]Java业务开发常见错误100例: https://time.geekbang.org/column/article/209108 往期推荐 Spring Boot集成Redis这个坑把我害惨了线程池的7种创建方式强烈推荐你用它...定时任务的实现原理看完就能手撸一个关注我每天陪你进步一点点

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/922052.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网站内页上海机械网站建设

完整课程请点击以下链接 Go 语言项目开发实战_Go_实战_项目开发_孔令飞_Commit 规范_最佳实践_企业应用代码-极客时间 Go语言中没有传统意义上的类和继承的概念,但可以通过嵌入类型(embedded types)来实现类似的功能。嵌入类型允许一个结构…

程序员用什么软件亚马逊seo什么意思

1. 什么是HTTP协议 HTTP是应用层的协议。Java最主要的应用场景是做网站,而网站由 后端(HTTP服务器) 和 前端(浏览器)组成,HTTP协议就是负责这里后端和前端的数据交互。 HTTP3.0 之前在传输层是通过 TCP传…

opencv学习记录6

图像金字塔图像金字塔 高斯金字塔 向下取样----pyrDown (1)对图像进行高斯卷积核 (2)删除所有偶数行和列其中,高斯核卷积运算(高斯滤波)就是对整幅图像进行加权平均的过程,每一个像素点的值,都由其本身和邻域内的…

努力的轨迹,通往成长的旅程——赵欣彤的自我介绍

老师、助教和各位同学们您好,我是赵欣彤。这篇博客是想和您做一个简单的自我介绍。虽然还不够成熟和优秀,但我很愿意学习、改进,也希望在课程中积极参与团队合作和项目实践。期待能在您的指导下和同学们一起成长。�…

第2章 day02 requests基础

爬虫初始 爬虫相关介绍什么是爬虫?爬虫程序是需要充当B/S或者C/S架构中的客户端。 爬虫程序需要模拟客户端进行请求发送,然后获取服务器端对应的相关数据。 在B/S架构中爬虫程序模拟的就是浏览器。提问:如果日后你的…

WebAPI开发步骤

WebAPI开发步骤1.在VS2022中选择新建项目,选择 ASP.Net Core Web API.2.我们先用CodeFirst,即先建数据表模型,再用EF Core写入数据库定义User类,在新建文件夹Models下,里面可以建多个对应数据库中的表实体 在NuGet…

台州公司网站外包晋州建设规划局网站

一 insert 语句 强调: 本文介绍的内容很基础,仅做记录用,参考价值较少 ① 总述 目的: 增加rows记录1、完整格式insert [into] 表名[字段名1[, 字段名2]] value[s](值1, 值2);备注:指定部分字段添加,没有被指定的字段要么会自动增长,要…

线性代数_工程实践-计算实现numpy

点云和坐标变换数学概念 1.矩阵乘法01.两个矩阵A和B相乘,需要满足A的列数等于B的行数02.单位矩阵 如果A是nn矩阵,I是单位矩阵,则AI= A, IA = A03.逆矩阵 矩阵A的逆矩阵 A^-1, A A^-1=A^-1A= I,I是单位矩阵 当…

广州网站定制开发定制美瞳网站建设

之前为了做控规,从湘源8中扒了一套国空用地用海的绘图参数给湘源7使用。 【预告】在湘源控规7中使用 国空用地用海分类标准 但是部里在2023年11月又发布了一套新的用地用海分类。 本想去湘源8里面再扒一下,结果发现湘源8自己还没有更新呢,…

在HAL库使用printf打印串口信息

以STM32F103为例,在hal库中选择usart1,设置按下图配置并在usart.c文件内新增以下函数:点击查看代码 #if 1 #pragma import(__use_no_semihosting) //标准库需要的支持函数 struct __…

第3章 day03 xpath+反爬虫

上次直播作业下厨房的菜谱搜索(多个请求参数)通过抓包工具的分析发现,搜索菜谱的数据包有两个请求参数:keyword:搜索的关键字 cat:1001固定形式import requests#请求头 headers = {User-Agent:Mozilla/5.0 (Macint…

装修公司营销网站模板查询注册公司

正整数 A 的“D​A​​(为 1 位整数)部分”定义为由 A 中所有 D​A​​ 组成的新整数 P​A​​。例如:给定 A3862767,D​A​​6,则 A 的“6 部分”P​A​​ 是 66,因为 A 中有 2 个 6。 现给定 A、D​A​​…

ttkefu2026迎来永久免费的客服系统分享

ttkefu2026迎来永久免费的客服系统分享在数字化浪潮席卷全球的当下,客户服务已成为企业核心竞争力的重要组成部分。然而,传统客服系统高昂的部署成本、复杂的功能配置以及多渠道整合的痛点,始终制约着中小企业服务效…

002- 学习环境搭建

学习环境搭建1、开发工具下载 Visualstudio 2022  https://visualstugio.microsoft.com/zh-hans/vs/ 【产品链接,失效自己找和谐版本】  https://docs.microsoft.com/zh-cn/visualstudio/releases/2022/system…

网页建站点seo实战密码在线阅读

最近看到一道面试题:内部类可以引用它的包含类的成员吗?有没有什么限制? 答案大部分都是这样子的: 完全可以。如果不是静态内部类,那没有什么限制! 一个内部类对象可以访问创建它的外部类对象的成员包括私有…

第10章 day10 DrissionPage详细教程

DrissionPage详细教程 1. 基本概述 DrissionPage 是一个基于 python 的网页自动化工具。它既能控制浏览器,也能像requests一样收发数据包,更重要的是还能把两者合二为一。因此,简单来说DrissionPage可兼顾浏览器自动…

求局部最小值

求局部最小值局部最小值 题目:给定一个数组,每两个相邻的数组不等,找到该数组上任意一个局部最小值。 定义:nums[1] > nums[0] nums[len(nums) - 2] > nums[len(nums) - 1] nums[n-1] > nums[n] &&am…

Element-UI的transfer穿梭框组件数据量大解决方案

一、面临问题 数据量大,渲染慢,搜索、勾选、关闭、右移卡顿 二、解决方案 1. 总体思路 改写 Element-UI 的 transfer 穿梭框组件,形成自己的自定义组件 2. 具体步骤 2.1 复制 Element-UI 的 transfer 穿梭框组件出来…

第9章 day09 hook插件

二. hook插件 1.概念 在JavaScript中,hook是一种能够拦截和修改函数或方法行为的技术。通过使用hook,开发者可以在现有的函数执行前、执行后或者替换函数的实现逻辑。hook目的是找到函数入口以及一些参数变化,便于分…

nginx 一致性hash和流量检查模块

nginx-module-vts:这是一个Nginx的监控模块,能够收集Nginx自身详细的虚拟主机流量状态信息,如请求次数、响应字节、响应时间等,并以JSON、HTML或Prometheus格式输出。nginx-vts-exporter依赖于这个模块。nginx-vts…