当前位置: 首页 > news >正文

第十九章程序清单合集——Java语言程序设计进阶篇(黑皮书)

目录

程序清单19_1GenericStack

程序清单19_2GenericMethodDemo 

程序清单19_3BoundedTypeDemo 

程序清单19_4GenericSort

程序清单19_5Max

 程序清单19_6MaxUsingGenericType

程序清单19_7wildCardNeedDemo

程序清单19_8AnyWildCardDemo

程序清单19_9SuperWildChardDemo

程序清单19_10GenericMatrix

 程序清单19_11IntegerMatrix

 程序清单19_12RationalMatrix

程序清单13_13Rational(在19_12代码中有引用

程序清单19_13TestIntegerMatrix

程序清单19_14TestRationalMatrix


程序清单19_1GenericStack

package chapter_19;
import java.util.ArrayList;
public class 程序清单19_1GenericStack <E>{private ArrayList<E> list = new ArrayList<E>();//private java.util.ArrayList<E> list = new java.util.ArrayList<E>();public int getSize() {return list.size();}public E peek() {return list.get(getSize()-1);}public void push(E o) {list.add(o);}public E pop() {E o = list.get(getSize()-1);list.remove(getSize() - 1);return o;}public boolean isEmpty() {return list.isEmpty();}@Overridepublic String toString() {return "stack: " + list.toString();}}

程序清单19_2GenericMethodDemo 

package chapter_19;public class 程序清单19_2GenericMethodDemo {public static void main(String[] args) {Integer[] integers = {1, 2, 3, 4,5};String[] strings = {"Lodon","Paris", "New york", "Austin"};程序清单19_2GenericMethodDemo.<Integer>print(integers);程序清单19_2GenericMethodDemo.<String>print(strings);/*print(integers);print(strings);*/}public static <E> void print(E[] list) {for(int i = 0;i < list.length;i++)System.out.println(list[i] + " ");System.out.println();}}

输出结果

1 2 3 4 5 
Lodon Paris New york Austin 

程序清单19_3BoundedTypeDemo 

package chapter_19;public class 程序清单19_3BoundedTypeDemo {public static void main(String[] args) {Rectangle rectangle = new Rectangle();Circle circle = new Circle(2);System.out.println("Same area? ");}public static <E extends GeometriObject> boolean equalArea(E object1,E object2) {return object1.getArea() == object2.getArea();}
}

见程序清单13-4

程序清单19_4GenericSort

package chapter_19;public class 程序清单19_4GenericSort {public static void main(String[] args) {Integer[] intArray = {new Integer(2), new Integer(4),new Integer(3)};Double[] doubleArray = {new Double(3.4),new Double(1.3),new Double(-22.1)};Character[] charArray = {new Character('a'),new Character('J'),new Character('r')};String[] stringArray = {"Tom","Susan","kim"};sort(intArray);sort(doubleArray);sort(charArray);sort(stringArray);System.out.print("Sorted Integer objects: ");printList(intArray);System.out.print("Sorted Double objects: ");printList(doubleArray);System.out.print("Sorted Character objects: ");printList(charArray);System.out.print("Sorted String objects: ");printList(stringArray);}public static <E extends Comparable<E>> void sort(E[] list) {E currentMin;int currentMinIndex;for(int i = 0;i < list.length - 1;i++) {currentMin = list[i];currentMinIndex = i;for(int j = i+1;j< list.length;j++) {if(currentMin.compareTo(list[j])>0){currentMin = list[j];currentMinIndex = j;}}if(currentMinIndex != i) {list[currentMinIndex] = list[i];list[i] = currentMin;}}}public static void printList(Object[] list) {for(int i = 0;i<list.length;i++)System.out.print(list[i] + " ");System.out.println();}}

程序清单19_5Max

package chapter_19;public class 程序清单19_5Max {public static Comparable max(Comparable o1,Comparable o2) {if(o1.compareTo(o2) > 0)return o1;elsereturn o2;}
}

 程序清单19_6MaxUsingGenericType

package chapter_19;public class 程序清单19_6MaxUsingGenericType {public static <E extends Comparable<E>> E max(E o1,E o2) {if(o1.compareTo(o2)> 0)return o1;else return o2;}}

程序清单19_7wildCardNeedDemo

package chapter_19;public class 程序清单19_7wildCardNeedDemo {public static void main(String[] args) {程序清单19_1GenericStack<Integer> intStack = new 程序清单19_1GenericStack<Integer>();intStack.push(1);intStack.push(2);intStack.push(-2);System.out.println("The max number is "+max(intStack));}//public static double max(程序清单19_1GenericStack<Number>stack) {intStack不是GenericStack<Number>的实例,所以这行代码会出错public static double max(程序清单19_1GenericStack<Integer>stack) {double max = stack.pop().doubleValue();while(!stack.isEmpty()) {double value = stack.pop().doubleValue();if(value > max)max = value;}return max;}}

 输出结果

The max number is 2.0

程序清单19_8AnyWildCardDemo

package chapter_19;public class 程序清单19_8AnyWildCardDemo {public static void main(String[] args) {程序清单19_1GenericStack<Integer> intStack = new 程序清单19_1GenericStack<>();intStack.push(1);intStack.push(2);intStack.push(-2);print(intStack);}public static void print(程序清单19_1GenericStack<?> stack) {while(!stack.isEmpty()) {System.out.print(stack.pop() + " ");}}}

程序清单19_9SuperWildChardDemo

package chapter_19;public class 程序清单19_9SuperWildChardDemo {public static void main(String[] args) {程序清单19_1GenericStack<String> stack1 = new 程序清单19_1GenericStack<>();程序清单19_1GenericStack<Object> stack2 = new 程序清单19_1GenericStack<>();stack2.push("Java");stack2.push(2);;stack1.push("Sun");add(stack1, stack2);程序清单19_8AnyWildCardDemo.print(stack2);}public static <T> void add(程序清单19_1GenericStack<T> stack1,程序清单19_1GenericStack<? super T> stack2) {while (!stack1.isEmpty()) stack2.push(stack1.pop());}}

 输出结果

Sun 2 Java 

程序清单19_10GenericMatrix

package chapter_19;public abstract class 程序清单19_10GenericMatrix <E extends Number>{protected abstract E add(E o1,E o2);protected abstract E multiply(E o1,E o2);protected abstract E zero();public E[][] addMatrix(E[][] matrix1,E[][] matrix2){if((matrix1.length != matrix2.length)||(matrix1[0].length != matrix2[0].length)) {throw new RuntimeException("The matrices do not have the same size");}E[][] result = (E[][])new Number[matrix1.length][matrix1[0].length];for(int i = 0;i < result[i].length;i++) {for(int j = 0;j < result[i].length;j++) {result[i][j] = add(matrix1[i][j],matrix2[i][j]);}}return result;}public E[][] multiplyMatrix(E[][] matrix1,E[][] matrix2){if(matrix1[0].length != matrix2.length) {throw new RuntimeException("The matrices do no have compatible size");}E[][] result = (E[][])new Number[matrix1.length][matrix2[0].length];for(int i = 0;i < result.length;i++) {for(int j = 0;j < result[0].length;j++) {result[i][j] = zero();for(int k = 0;k < matrix1[0].length;k++) {result[i][j] = add(result[i][j], multiply(matrix1[i][k], matrix2[k][j]));}}}return result;}public static void printResult(Number[][] m1,Number[][] m2,Number[][] m3,char op) {for(int i = 0;i < m1.length;i++) {for(int j = 0;j < m1[0].length;j++)System.out.print(" " + m1[i][j]);if(i == m1.length/2)System.out.print(" " + op + " ");else System.out.print("    ");for(int j = 0;j < m2.length;j++)System.out.print(" " + m2[i][j]);if(i == m1.length / 2)System.out.print(" = ");elseSystem.out.print("    ");for(int j = 0;j < m3.length;j++)System.out.print(m3[i][j] + " ");System.out.println();}}
}

 程序清单19_11IntegerMatrix

package chapter_19;public class 程序清单19_11IntegerMatrix extends 程序清单19_10GenericMatrix<Integer>{@Overrideprotected Integer add(Integer o1,Integer o2) {return o1 + o2;}@Overrideprotected Integer multiply(Integer o1, Integer o2) {return o1 * o2;}@Overrideprotected Integer zero() {return 0;}}

 程序清单19_12RationalMatrix

package chapter_19;public class 程序清单19_12RationalMatrix extends 程序清单19_10GenericMatrix<程序清单13_13Rational>{@Overrideprotected 程序清单13_13Rational add(程序清单13_13Rational r1,程序清单13_13Rational r2) {return r1.add(r2);}@Override protected 程序清单13_13Rational multiply(程序清单13_13Rational r1,程序清单13_13Rational r2) {return r1.multiply(r2);}@Overrideprotected 程序清单13_13Rational zero() {return new 程序清单13_13Rational(0,1);}
}

程序清单13_13Rational(在19_12代码中有引用

package chapter_19;public class 程序清单13_13Rational extends Number implements Comparable<程序清单13_13Rational>{private long numerator = 0;private long denominator = 1;public 程序清单13_13Rational() {this(0,1);}public 程序清单13_13Rational(long numerator,long denominator) {long gcd = gcd(numerator,denominator);this.numerator = ((denominator > 0)?1:-1)*numerator / gcd;this.denominator = Math.abs(denominator) / gcd;}private static long gcd(long n,long d) {long n1 =Math.abs(n);long n2 = Math.abs(d);int gcd = 1;for(int k = 1;k <= n1&&k <= n2;k++) {if(n1 %k == 0&&n2 % k == 0)gcd = k;}return gcd;}public long getNumerator() {return numerator;}public long getDenominator() {return denominator;}public 程序清单13_13Rational add(程序清单13_13Rational secondRational) {long n = numerator * secondRational.getDenominator()+denominator*secondRational.getNumerator();long d = denominator * secondRational.getDenominator();return new 程序清单13_13Rational(n,d);}public 程序清单13_13Rational subtract(程序清单13_13Rational secondRational) {long n = numerator * secondRational.getDenominator()- denominator * secondRational.getNumerator();long d = denominator * secondRational.getDenominator();return new 程序清单13_13Rational(n,d);}public 程序清单13_13Rational multiply(程序清单13_13Rational secondRational) {long n = numerator * secondRational.getNumerator();long d = denominator * secondRational.getDenominator();return new 程序清单13_13Rational(n,d);}public 程序清单13_13Rational divide(程序清单13_13Rational secondRational) {long n = numerator * secondRational.getDenominator();long d = denominator * secondRational.numerator;return new 程序清单13_13Rational(n,d);}@Overridepublic String toString() {if(denominator == 1)return numerator +"";elsereturn numerator + "/" + denominator;}@Overridepublic boolean equals(Object other) {if((this.subtract((程序清单13_13Rational)(other))).getNumerator() == 0)return true;elsereturn false;}@Overridepublic int intValue() {return (int)doubleValue();}@Overridepublic float floatValue() {return (float)doubleValue();}@Overridepublic double doubleValue() {return numerator * 1.0/denominator;}@Overridepublic long longValue() {return (long)doubleValue();}@Overridepublic int compareTo(程序清单13_13Rational o) {if(this.subtract(o).getNumerator() > 0)return 1;else if(this.subtract(o).getNumerator() < 0)return -1;else return 0;}
}

程序清单19_13TestIntegerMatrix

 package chapter_19;public class 程序清单19_13TestIntegerMatrix {public static void main(String[] args) {Integer[][] m1 = new Integer[][] {{1, 2, 3},{4, 5, 6},{1, 1, 1}};Integer[][] m2 = new Integer[][] {{1, 1, 1},{2, 2, 2},{0, 0, 0}};程序清单19_11IntegerMatrix integerMatrix = new 程序清单19_11IntegerMatrix();System.out.println("\nm1 + m2 is ");程序清单19_10GenericMatrix.printResult(m1, m2, integerMatrix.addMatrix(m1, m2), '+');System.out.println("\nm1 * m2 is ");程序清单19_10GenericMatrix.printResult(m1, m2, integerMatrix.multiplyMatrix(m1, m2), '*');}
}

输出结果

m1 + m2 is 1 2 3     1 1 1    2 3 4 4 5 6 +  2 2 2 = 6 7 8 1 1 1     0 0 0    1 1 1 m1 * m2 is 1 2 3     1 1 1    5 5 5 4 5 6 *  2 2 2 = 14 14 14 1 1 1     0 0 0    3 3 3 

程序清单19_14TestRationalMatrix

package chapter_19;public class 程序清单19_14TestRationalMatrix {public static void main(String[] args) {程序清单13_13Rational[][] m1 = new 程序清单13_13Rational[3][3];程序清单13_13Rational[][] m2 = new 程序清单13_13Rational[3][3];for(int i = 0;i < m1.length;i++) {for(int j = 0;j < m1[0].length;j++) {m1[i][j] = new 程序清单13_13Rational(i+1,j+5);m2[i][j] = new 程序清单13_13Rational(i+1,j+6);}}程序清单19_12RationalMatrix rationalMatrix = new 程序清单19_12RationalMatrix();System.out.println("\nm1 + m2 + is ");程序清单19_10GenericMatrix.printResult(m1, m2,rationalMatrix.addMatrix(m1, m2), '+');System.out.println("\nm1 * m2 is ");程序清单19_10GenericMatrix.printResult(m1, m2,rationalMatrix.multiplyMatrix(m1, m2), '*');}
}

 输出结果

m1 + m2 + is 1/5 1/6 1/7     1/6 1/7 1/8    11/30 13/42 15/56 2/5 1/3 2/7 +  1/3 2/7 1/4 = 11/15 13/21 15/28 3/5 1/2 3/7     1/2 3/7 3/8    11/10 13/14 45/56 m1 * m2 is 1/5 1/6 1/7     1/6 1/7 1/8    101/630 101/735 101/840 2/5 1/3 2/7 *  1/3 2/7 1/4 = 101/315 202/735 101/420 3/5 1/2 3/7     1/2 3/7 3/8    101/210 101/245 101/280 

相关文章:

第十九章程序清单合集——Java语言程序设计进阶篇(黑皮书)

目录 程序清单19_1GenericStack 程序清单19_2GenericMethodDemo 程序清单19_3BoundedTypeDemo 程序清单19_4GenericSort 程序清单19_5Max 程序清单19_6MaxUsingGenericType 程序清单19_7wildCardNeedDemo 程序清单19_8AnyWildCardDemo 程序清单19_9SuperWildChardDem…...

el-table组件树形数据修改展开箭头

<style lang"scss" scoped> ::v-deep .el-table__expand-icon .el-icon-arrow-right:before {content: ">"; // 箭头样式font-size: 16px; }::v-deep .el-table__expand-icon{ // 没有展开的状态background-color: rgba(241, 242, 245, 1);color:…...

LabVIEW前面板无法显示的常见原因

当 LabVIEW 前面板显示为白色或黑色时&#xff0c;可能由于控件可视性设置、显卡驱动问题、程序错误或 LabVIEW 设置不当引起。通过检查面板设置、更新驱动、重启程序等方式可有效解决此问题。 遇到前面板无法显示或显示为白色/黑色的情况&#xff0c;可能有以下几种原因。可以…...

PyQt事件机制练习

一、思维导图 二、代码 import sysfrom PyQt6.QtTextToSpeech import QTextToSpeech from PyQt6.QtWidgets import QApplication, QWidget, QLabel, QPushButton, QLineEdit from PyQt6 import uic from PyQt6.QtCore import Qt, QTimerEvent, QTimeclass MyWidget(QWidget):d…...

Android 中,Activity Fragment:如何进行界面跳转、数据传递等

学习笔记 1. Activity 之间的界面跳转和数据传递 在 Android 中&#xff0c;Activity 之间的跳转通常通过 Intent 来完成。Intent 可以携带数据&#xff0c;并传递给目标 Activity&#xff0c;也可以从目标 Activity 返回数据。 从一个 Activity 跳转到另一个 Activity // 在…...

【ubuntu18.04】安装easycwmp出现/usr/bin/ld: cannot find -lubus问题解决方案

错误日志 rootw1804-virtual-machine:/opt/dev/easycwmp# make Making all in bin make[1]: Entering directory /opt/dev/easycwmp/bin gcc -DPACKAGE_NAME\"easycwmpd\" -DPACKAGE_TARNAME\"easycwmpd\" -DPACKAGE_VERSION\"1.8.6\" -DPACKAG…...

可视化建模以及UML期末复习----做题篇

一、单项选择题。&#xff08;20小题&#xff0c;每小题2分,共40分&#xff09; 1、UML图不包括&#xff08; &#xff09; A、用例图 B、状态机图 C、流程图 D、类图 E、通信图 答案&#xff1a;C、流程图 UML中不包括传统意义上的流程图&#xff0c;流程图通常是指B…...

【2024年浙江工商大学程序设计竞赛新生赛(同步赛)部分题解】

比赛链接 C. 交换 题目大意 给定一个长度为 n n n 的数组 a a a。一开始你有一个总和 s 0 s 0 s0。 现在你需要做 n n n 次操作&#xff0c;第 i i i 次操作的流程如下&#xff08; 1 ⩽ i ⩽ n 1 \leqslant i \leqslant n 1⩽i⩽n)&#xff1a; 选择一个下标 p ∈…...

[SAP ABAP] DEBUG ABAP程序中的循环语句

在ABAP程序开发中可能会遇到要DEBUG循环语句的情况&#xff0c;这个循环语句可能会执行上万次&#xff0c;但我们希望程序执行循环到100次就停下来&#xff0c;也就是希望DEBUG断点设置在循环语句的第100次停下来观察执行的结果&#xff0c;这时我们可以在DEBUG程序时通过设置一…...

解决阿里云轻量级服务器 Ubuntu 24.04.1 LTS 没网也 ping 不通 8.8.8.8 以及 route -n 没有输出任何转发信息

事情发生在两天前&#xff0c;位于公网的阿里云轻量级服务器&#xff08;Ubuntu 24.04.1 LTS&#xff09;忽然没网。主要是上次上服务器进行配置已经是一个多月前&#xff0c;最近也没有做什么事情&#xff0c;就忽然没网了&#xff0c;让人纳闷。更主要的是&#xff0c;上次备…...

AUTOSAR:SOME/IP 概念

文章目录 1. 用例与需求1.1 典型用例1.2 对中间件的要求 2. 协议栈示例3. SOME/IP 概念3.1 中间件整体功能与架构3.2 服务组成元素详细解释 4. 服务发现机制深入剖析5. 总结 1. 用例与需求 1.1 典型用例 信息娱乐系统&#xff1a; 后座娱乐系统连接&#xff1a;允许后排乘客连…...

STM32--中断

中断 中断向量表 定义一段固定的内存&#xff0c;以4字节对齐&#xff0c;存放各个中断服务函数程序的首地址。定义在启动文件中。 中断相关寄存器 内核中断不经过中断使能、除能寄存器。 中断优先级 1、抢占优先级&#xff1a;高高抢占优先级可以打断正在执行的低抢占优先…...

海思3559a开发

目录 固件烧录配置网络nfs挂载虚拟机文件使用telnet连接开发板 固件烧录 1、配置好HiTool烧录工具 需要注意长度必须不小于对应文件大小 2、开始烧录 先点击擦除全器件&#xff0c;重新给开发板上电&#xff0c;擦除成功后如下图所示。 点击烧写&#xff0c;重新给开发板上电…...

优选算法——位运算

1. 常见位运算总结 2. 判定字符是否唯一 题目链接&#xff1a;面试题 01.01. 判定字符是否唯一 - 力扣&#xff08;LeetCode&#xff09; 题目展示&#xff1a; 题目分析&#xff1a;本题有很多种做法&#xff0c;这里我们使用位图来解决&#xff0c;这种做法是一种效率很高…...

【JAVA】旅游行业中大数据的使用

一、应用场景 数据采集与整合&#xff1a;全面收集旅游数据&#xff0c;如客流量、游客满意度等&#xff0c;整合形成统一数据集&#xff0c;为后续分析提供便利。 舆情监测与分析&#xff1a;实时监测旅游目的地的舆情信息&#xff0c;运用NLP算法进行智能处理&#xff0c;及…...

使用html和JavaScript实现一个简易的物业管理系统

码实现了一个简易的物业管理系统&#xff0c;主要使用了以下技术和功能&#xff1a; 1.主要技术 使用的技术&#xff1a; HTML: 用于构建网页的基本结构。包括表单、表格、按钮等元素。 CSS: 用于美化网页的外观和布局。设置字体、颜色、边距、对齐方式等样式。 JavaScript…...

浅谈Kubernetes(K8s)之RC控制器与RS控制器

1.RC控制器 1.1RC概述 Replication Controller 控制器会持续监控正在运行的Pod列表&#xff0c;并保证相应类型的Pod的数量与期望相符合&#xff0c;如果Pod数量过少&#xff0c;它会根据Pod模板创建新的副本&#xff0c;反之则会删除多余副本。通过RC可实现了应用服务的高可用…...

如何在 openAI Sora 上生成视频内容

近期OpenAI 推出了我们期待已久的视频生成模型 Sora。能够生成包含多个角色、特定类型的动作以及主体和背景的精确细节的复杂场景。该模型不仅了解用户在提示中要求的内容&#xff0c;还了解这些内容在物理世界中的存在方式。 如何在 openAI Sora 上生成视频内容 使用Sora 视频…...

【Oracle11g SQL详解】日期和时间函数:SYSDATE、TO_DATE、TO_CHAR 等

日期和时间函数&#xff1a;SYSDATE、TO_DATE、TO_CHAR 等 在 Oracle 数据库中&#xff0c;日期和时间函数用于处理日期和时间数据。它们在记录创建时间、分析时间间隔、格式化输出等场景中非常重要。本文将详细讲解常用的日期和时间函数及其应用。 一、SYSDATE&#xff1a;获…...

STM32 串口收发文本数据包

单片机学习&#xff01; 目录 前言 一、文本数据包格式 二、串口收发文本数据包代码 三、代码解析 3.1 标志位清除 3.2 数据包接收 四、代码问题改进 总结 前言 本文介绍了串口收发文本数据包程序设计的思路并详解代码作用。 一、文本数据包格式 文本数据包的格式的定义…...

铭记一次项目重大事故

在程序的世界里&#xff0c;bug 就像隐藏在暗处的小怪兽&#xff0c;时不时跳出来捣乱。而职业生涯中&#xff0c;总有那么一个或几个 bug 让我们刻骨铭心。它或许让项目差点夭折&#xff0c;或许让你熬了无数个通宵&#xff0c;或许有着离奇的出现方式和曲折的解决过程。无论是…...

AUTOSAR 汽车开放系统架构

AUTOSAR 官网 AUTOMOTIVE OPEN SYSTEM ARCHITECTURE AUTOSAR (AUTomotive Open System ARchitecture) is a global partnership of leading companies in the automotive and software industry to develop and establish the standardized software framework and open E/E …...

从零用java实现 小红书 springboot vue uniapp (2)主页优化

前言 移动端演示 http://8.146.211.120:8081/#/ 前面的文章我们基本完成了主页的布局 今天我们具体的去进行实现 并且分享我开发时遇到的问题 首先先看效果 java仿小红书主页 实现效果为 1.顶端全屏切换 2.上划加载更多 3.下拉当前页整体刷新 顶端全屏切换我们选择 gui-switch…...

打电话玩手机识别-支持YOLO,COCO,VOC格式的标记,超高识别率可检测到手持打电话, 非接触式打电话,玩手机自拍等

打电话玩手机识别-支持YOLO&#xff0c;COCO&#xff0c;VOC格式的标记&#xff0c;超高识别率可检测到手持打电话&#xff0c; 非接触式打电话&#xff0c;玩手机自拍等1275个图片。 手持打电话&#xff1a; 非接触打电话 玩手机 数据集下载 yolov11:https://download.csdn…...

黑马程序员Java项目实战《苍穹外卖》Day12

苍穹外卖-day12 课程内容 工作台Apache POI导出运营数据Excel报表 功能实现&#xff1a;工作台、数据导出 工作台效果图&#xff1a; 数据导出效果图&#xff1a; 在数据统计页面点击数据导出&#xff1a;生成Excel报表 1. 工作台 1.1 需求分析和设计 1.1.1 产品原…...

实现SpringBoot项目嵌入其他项目

很多时候我们需要在项目里面嵌入其他项目或者被其他项目嵌入&#xff0c;如我们开发一个开源项目b&#xff0c;用户需要在自己的项目a嵌入b项目&#xff0c;使用b项目的功能&#xff0c;而且要实现a项目工作最小化&#xff0c;最好实现引入即用。 1.定义b项目的自定义配置 …...

海康威视摄像头RTSP使用nginx推流到服务器直播教程

思路&#xff1a; 之前2020年在本科的时候&#xff0c;由于项目的需求需要将海康威视的摄像头使用推流服务器到网页进行直播。这里将自己半个月琢磨出来的步骤给大家发一些。切勿转载&#xff01;&#xff01;&#xff01;&#xff01; 使用网络摄像头中的rtsp协议---------通…...

【自动化】requirements.txt

1.是什么&#xff1f; 用于列出项目依赖的所有Python包及其版本。这使得其他开发者可以轻松地安装与你的项目兼容的环境&#xff0c;或者在不同的机器上复制相同的开发环境。 2.如何编写requirements.txt 手动创建 格式&#xff1a; 包名版本号 在终端home命令自动生成 创建r…...

C++ 中多态性在实际项目中的应用场景

背景与需求 在一个图形绘制软件中&#xff0c;需要绘制多种不同的图形&#xff0c;如圆形、矩形、三角形等。每个图形都有自己的绘制方法&#xff0c;但是它们都可以被看作是一个抽象的 “图形” 概念&#xff0c;并且都有一个共同的操作&#xff0c;比如绘制&#xff08;draw&…...

手机租赁系统开发指南一站式服务流程解析

内容概要 手机租赁系统的开发是一个复杂但有趣的过程&#xff0c;像搭建乐高一样&#xff0c;只要找到合适的模块&#xff0c;就能打造出一个宾至如归的租赁平台。在这部分&#xff0c;我们将对开发流程的整体结构进行简要概述&#xff0c;并指出每个环节的重要性。 首先&…...

基于Couchbase的数据构建方案:数仓分层

初步方案是将公共层和报表层分别放在不同的bucket中&#xff0c;这种设计从存储和访问优化的角度是合理的&#xff0c;但仍有以下细节需要考虑&#xff1a; 1. 数仓公共层设计&#xff08;origin bucket&#xff09; 合理性分析&#xff1a; 将ODS、DWD、DWS层的数据放在一个b…...

Linux中的线程

目录 线程的概念 进程与线程的关系 线程创建 线程终止 线程等待 线程分离 原生线程库 线程局部存储 自己实现线程封装 线程的优缺点 多线程共享与独占资源 线程互斥 互斥锁 自己实现锁的封装 加锁实现互斥的原理 死锁 线程同步 线程的概念 回顾进程相关概念 …...

【保姆级】Mac如何安装+切换Java环境

本文从如何下载不同版本的JDK,到如何丝滑的切换JDK,以及常见坑坑的处理方法,应有尽有,各位看官走过路过不要错过~~~ 下载⏬ 首先上官网: https://www.oracle.com/ 打不开的话可以使用下面👇这个中文的 https://www.oracle.com/cn/java/technologies/downloads/a…...

leetcode 31 Next Permutation

题意 找到下一个permutation是什么&#xff0c;对于一个数组[1&#xff0c;2&#xff0c;3]&#xff0c;下一个排列就是[1, 3, 2] 链接 https://leetcode.com/problems/next-permutation/ 思考 首先任何一个permutation满足一个性质&#xff0c;从某个位置往后一定是降序。…...

从RocketMQ到Dubbo:自研中间件技术的崛起

目录 一. 宝兰德 BES 中间件&#xff08;BES - Business Enterprise Server&#xff09; 二. TongWeb 中间件 三. 阿里巴巴 RocketMQ 四. 京东 JStorm 五. 华为 GaussDB 六. 华为 FusionInsight 七. 百度 Tinker 八. 中科曙光 Kylin 九. 滴滴 Druid 一. 宝兰德 BES 中间…...

计算机键盘简史 | 键盘按键功能和指法

注&#xff1a;本篇为 “计算机键盘简史 | 键盘按键功能和指法” 相关文章合辑。 英文部分机翻未校。 The Evolution of Keyboards: From Typewriters to Tech Marvels 键盘的演变&#xff1a;从打字机到技术奇迹 Introduction 介绍 The keyboard has journeyed from a humb…...

考研两三题

283. 移动零 - 力扣&#xff08;LeetCode&#xff09; 本题解法&#xff1a;使用双指针 解法一&#xff1a; 如上图&#xff0c;在一开始slow指向-1&#xff0c;fast指向数组起始位&#xff0c;进入while循环&#xff0c;保证fast不越界&#xff0c;因为代码中fast会自增&#…...

CentOS8或docker镜像centos8更换镜像源

因为 CentOS 8 已经结束生命周期&#xff0c;原来的镜像源不可用了。我们需要将镜像源改为 CentOS 8 的替代源。 在容器中运行以下命令&#xff1a; 首先备份原有的源 cd /etc/yum.repos.d/ mkdir backup mv *.repo backup/ 创建新的源文件 cat > /etc/yum.repos.d/Cent…...

集成方案 | Docusign + 泛微,实现全流程电子化签署!

本文将详细介绍 Docusign 与泛微的集成步骤及其效果&#xff0c;并通过实际应用场景来展示 Docusign 的强大集成能力&#xff0c;以证明 Docusign 集成功能的高效性和实用性。 在现代企业运营中&#xff0c;效率和合规性是至关重要的。泛微作为企业级办公自动化和流程管理的解决…...

知乎数据分析面试题及参考答案

请阐述大数定理和中心极限定理的内容及其在数据分析中的应用。 大数定理是指在随机试验中,每次出现的结果不同,但是大量重复试验出现的结果的平均值却几乎总是接近于某个确定的值。简单来说,当样本量足够大的时候,样本均值会趋近于总体均值。例如,抛硬币试验,当抛硬币的次…...

8.Vue------如何重新加载子组件key属性----vue知识积累

在子组件中使用key属性是一种强制重新渲染子组件的有效方法。‌通过改变key属性的值&#xff0c;Vue会 销毁旧组件并创建新组件&#xff0c;从而实现组件的重新加载。这种方法适用于需要完全重新渲染子组件&#xff0c; 包括其内部状态和生命周期钩子的场景&#xff0c;特别是…...

C语言动态内存管理

1.为什么要有动态内存分配 内存开辟方式: int val 20;//在栈空间上开辟四个字节 char arr[10] {0};//在栈空间上开辟10个字节的连续空间开辟空间的方式特点 空间开辟大小是固定德的数组在申明的时候&#xff0c;必须指明数组的长度&#xff0c;数组空间一旦确定了大小不能…...

【蓝桥杯备战】Day 1

1.基础题目 LCR 018.验证回文串 给定一个字符串 s &#xff0c;验证 s 是否是 回文串 &#xff0c;只考虑字母和数字字符&#xff0c;可以忽略字母的大小写。 本题中&#xff0c;将空字符串定义为有效的 回文串 。 示例 1: 输入: s "A man, a plan, a canal: Panama…...

电子应用设计方案-51:智能镜子系统方案设计

智能镜子系统方案设计 一、引言 智能镜子作为一种新兴的智能家居设备&#xff0c;将传统镜子与现代科技相结合&#xff0c;为用户提供了丰富的功能和便捷的体验。本方案旨在设计一款功能强大、用户友好、外观美观的智能镜子系统。 二、系统概述 1. 系统目标 - 提供清晰的镜面…...

[2015~2024]SmartMediaKit音视频直播技术演进之路

技术背景 2015年&#xff0c;因应急指挥项目需求&#xff0c;我们实现了RTMP推送音视频采集推送&#xff08;采集摄像头和麦克风数据&#xff09;模块&#xff0c;在我们做好了RTMP推送模块后&#xff0c;苦于没有一个满足我们毫秒级延迟诉求的RTMP播放器&#xff0c;于是第一…...

图片添加水印的实验原理,实验代码,实验现象

一、图片添加水印的实验原理 1. 选择水印类型 可见水印&#xff1a;这些水印可以直接被肉眼看到&#xff0c;通常用于防止未经授权的使用。它们可以是文字、标志或图案等形式&#xff0c;并且放置在图像的显著位置。不可见水印&#xff1a;这类水印不容易被察觉&#xff0c;但…...

Python Web 开发案例解析

一、Flask 基础应用案例 &#xff08;一&#xff09;项目搭建与初始化 环境准备 安装 Python 解释器&#xff0c;确保版本符合 Flask 要求&#xff0c;如 Python 3.6 及以上。使用pip安装 Flask 库&#xff0c;命令为pip install flask。可以创建虚拟环境&#xff0c;如python…...

JPG 转 PDF:免费好用的在线图片转 PDF 工具

JPG 转 PDF&#xff1a;免费好用的在线图片转 PDF 工具 在日常工作和生活中&#xff0c;我们经常需要将图片转换为 PDF 格式。无论是制作电子文档、准备演示材料&#xff0c;还是整理照片集&#xff0c;将图片转换为 PDF 都是一个常见的需求。今天为大家介绍一款完全免费、无需…...

代码随想录44天

1143.最长公共子序列 class Solution:def longestCommonSubsequence(self, s: str, t: str) -> int:n, m len(s), len(t)cache # 缓存装饰器&#xff0c;避免重复计算 dfs 的结果&#xff08;记忆化&#xff09;def dfs(i: int, j: int) -> int:if i < 0 or j <…...

C语言-详细解答-重组字符串并16进制转10进制

1.题目要求 2.代码实现 #include <stdio.h> #include <ctype.h> #include <string.h>int hexToDec(char hex[]) {int len strlen(hex);int base 1;int dec 0;for (int i len - 1; i > 0; i--) {if (isdigit(hex[i])) {dec (hex[i] - 0) * base;} e…...