程序员常用的几种算法

程序员常用的几种算法

  • 一、程序员算法汇总
  • 二、程序员常用的几种算法
    • 1.选择排序算法
      • 1.1 选择排序算法解析:
      • 1.2 示例代码:
    • 2.插入排序算法
      • 2.1 插入排序算法解析:
      • 2.2 示例代码:
    • 3.冒泡排序算法
      • 3.1 冒泡排序算法解析:
      • 3.2 示例代码:
      • 3.3 优化冒泡排序算法
    • 4.希尔排序算法
      • 4.1 希尔排序算法解析:
      • 4.2 示例代码:
    • 5.归并排序算法
      • 5.1 归并排序算法解析:
      • 5.2 示例代码:
    • 6.快速排序算法
      • 6.1 快速排序算法解析:
      • 6.2 示例代码:
    • 7.堆排序算法
      • 7.1 堆排序算法解析:
      • 7.2 示例代码:
    • 8.计数排序算法
      • 8.1 计数排序算法解析:
      • 8.2 示例代码:
      • 8.3 优化计数排序代码
    • 9.桶排序算法
      • 9.1 桶排序算法解析:
      • 9.2 示例代码:
    • 10.基数排序算法
      • 10.1 基数排序算法解析:
      • 10.2 示例代码:
    • 总结

一、程序员算法汇总


  1. 线性搜索算法:通过逐个比较来查找给定值。
  2. 二分搜索算法:通过将搜索区间减半来快速查找有序数组中的元素。
  3. 插入排序算法:通过逐个地插入元素来对数组进行排序。
  4. 选择排序算法:通过选择最小(或最大)的元素来对数组进行排序。
  5. 冒泡排序算法:通过相邻元素的比较和交换来对数组进行排序。
  6. 归并排序算法:通过将数组分成较小的块并逐步合并它们来对数组进行排序。
  7. 快速排序算法:通过选择一个基准元素并将数组分成两个子数组来对数组进行排序。
  8. 堆排序算法:通过构建最大(或最小)堆来对数组进行排序。
  9. 计数排序算法:通过计算元素的出现次数来对数组进行排序。
  10. 桶排序算法:通过将元素分配到不同的桶中来对数组进行排序。
  11. 基数排序算法:通过将元素按照位数进行排序来对数组进行排序。
  12. 字符串匹配算法:通过查找模式在给定文本中的出现位置来进行字符串匹配。
  13. 广度优先搜索算法:通过遍历节点的邻居来搜索图的最短路径。
  14. 深度优先搜索算法:通过递归地遍历节点的邻居来搜索图的最短路径。
  15. Dijkstra算法:通过计算节点之间的最短路径来搜索加权图。
  16. Floyd-Warshall算法:通过计算所有节点之间的最短路径来搜索加权图。
  17. 贝尔曼-福特算法:通过计算从源节点到所有其他节点的最短路径来搜索加权图。
  18. A*算法:通过启发式函数来搜索图的最短路径。
  19. 拓扑排序算法:通过确定图中节点之间的依赖关系来排序图的节点。
  20. Kruskal算法:通过选择边来构建最小生成树。
  21. Prim算法:通过选择节点来构建最小生成树。
  22. 最大流算法:通过在网络中查找最大流量路径来解决最大流问题。
  23. 最小割算法:通过在网络中查找最小割来解决最小割问题。
  24. 背包问题算法:通过动态规划来解决背包问题。
  25. 最长公共子序列算法:通过动态规划来查找两个序列的最长公共子序列。
  26. 最短公共超序列算法:通过动态规划来查找两个序列的最短公共超序列。
  27. 最长递增子序列算法:通过动态规划来查找给定序列的最长递增子序列。
  28. 最大子数组和算法:通过动态规划来查找给定数组的最大子数组和。
  29. 最优二叉搜索树算法:通过动态规划来构建最优二叉搜索树。
  30. 多重背包问题算法:通过动态规划来解决多重背包问题。
  31. 最大公约数算法:通过欧几里得算法来查找两个数的最大公约数。
  32. 最小公倍数算法:通过最大公约数算法来计算两个数的最小公倍数。
  33. 斐波那契数列算法:通过递归或动态规划来生成斐波那契数列。
  34. 快速幂算法:通过递归或迭代来计算幂。
  35. 回溯算法:通过尝试所有可能的解决方案来解决组合优化问题。



二、程序员常用的几种算法

1.选择排序算法


1.1 选择排序算法解析:


先找到数组中最小的那个元素,之后将它和数组的第一个元素交换位置(如果第一个元素就是最小元素那么它就和自己交换)。在之后在剩下的元素中找到最小的元素,将它与数组的第二个元素交换位置。如此往复,直到将整个数组排序。这种方法我们称之为选择排序。
程序员常用的几种算法




1.2 示例代码:


public class SelectSort {public static int[] selectSort(int[] a) {int n = a.length;for (int i = 0; i < n - 1; i++) {int min = i;for (int j = i + 1; j < n; j++) {if(a[min] > a[j]) min = j;}//交换int temp = a[i];a[i] = a[min];a[min] = temp;}return a;}
}



2.插入排序算法


2.1 插入排序算法解析:


我们在玩打牌的时候,你是怎么整理那些牌的呢?一种简单的方法就是一张一张的来,将每一张牌插入到其他已经有序的牌中的适当位置。当我们给无序数组做排序的时候,为了要插入元素,我们需要腾出空间,将其余所有元素在插入之前都向右移动一位,这种算法我们称之为插入排序。

过程简单描述:
1、从数组第2个元素开始抽取元素。
2、把它与左边第一个元素比较,如果左边第一个元素比它大,则继续与左边第二个元素比较下去,直到遇到不比它大的元素,然后插到这个元素的右边。
3、继续选取第3,4,….n个元素,重复步骤 2 ,选择适当的位置插入。
程序员常用的几种算法





2.2 示例代码:


public class InsertSort {public static int[] insertSort(int[] arr) {if(arr == null || arr.length < 2)return arr;int n = arr.length;for (int i = 1; i < n; i++) {int temp = arr[i];int k = i - 1;while(k >= 0 && arr[k] > temp)k--;//腾出位置插进去,要插的位置是 k + 1;for(int j = i ; j > k + 1; j--)arr[j] = arr[j-1];//插进去arr[k+1] = temp;}return arr;}
}



3.冒泡排序算法


3.1 冒泡排序算法解析:


把第一个元素与第二个元素比较,如果第一个比第二个大,则交换他们的位置。接着继续比较第二个与第三个元素,如果第二个比第三个大,则交换他们的位置….
我们对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对,这样一趟比较交换下来之后,排在最右的元素就会是最大的数。除去最右的元素,我们对剩余的元素做同样的工作,如此重复下去,直到排序完成。
程序员常用的几种算法





3.2 示例代码:


public class BubbleSort {public static int[] bubbleSort(int[] arr) {if (arr == null || arr.length < 2) {return arr;}int n = arr.length;for (int i = 0; i < n; i++) {for (int j = 0; j < n -i - 1; j++) {if (arr[j + 1] < arr[j]) {int t = arr[j];arr[j] = arr[j+1];arr[j+1] = t;}}}return arr;}
)

3.3 优化冒泡排序算法


假如从开始的第一对到结尾的最后一对,相邻的元素之间都没有发生交换的操作,这意味着右边的元素总是大于等于左边的元素,此时的数组已经是有序的了,我们无需再对剩余的元素重复比较下去了。

public class BubbleSort {public static int[] bubbleSort(int[] arr) {if (arr == null || arr.length < 2) {return arr;}int n = arr.length;for (int i = 0; i < n; i++) {boolean flag = true;for (int j = 0; j < n -i - 1; j++) {if (arr[j + 1] < arr[j]) {flag = false;int t = arr[j];arr[j] = arr[j+1];arr[j+1] = t;}}//一趟下来是否发生位置交换if(false)break;}return arr;}
}



4.希尔排序算法


4.1 希尔排序算法解析:


希尔排序可以说是插入排序的一种变种。无论是插入排序还是冒泡排序,如果数组的最大值刚好是在第一位,要将它挪到正确的位置就需要 n - 1 次移动。也就是说,原数组的一个元素如果距离它正确的位置很远的话,则需要与相邻元素交换很多次才能到达正确的位置,这样是相对比较花时间了。

希尔排序就是为了加快速度简单地改进了插入排序,交换不相邻的元素以对数组的局部进行排序。

希尔排序的思想是采用插入排序的方法,先让数组中任意间隔为 h 的元素有序,刚开始 h 的大小可以是 h = n / 2,接着让 h = n / 4,让 h 一直缩小,当 h = 1 时,也就是此时数组中任意间隔为1的元素有序,此时的数组就是有序的了。
程序员常用的几种算法





4.2 示例代码:


public class ShellSort {public static int[] shellSort(int arr[]) {if (arr == null || arr.length < 2) return arr;int n = arr.length;// 对每组间隔为 h的分组进行排序,刚开始 h = n / 2;for (int h = n / 2; h > 0; h /= 2) {//对各个局部分组进行插入排序for (int i = h; i < n; i++) {// 将arr[i] 插入到所在分组的正确位置上insertI(arr, h, i);}}return arr;}/*** 将arr[i]插入到所在分组的正确位置上* arr[i]] 所在的分组为 ... arr[i-2*h],arr[i-h], arr[i+h] ...*/private static void insertI(int[] arr, int h, int i) {int temp = arr[i];int k;for (k = i - h; k > 0 && temp < arr[k]; k -= h) {arr[k + h] = arr[k];}arr[k + h] = temp;}
}

需要注意的是,对各个分组进行插入的时候并不是先对一个组排序完了再来对另一个组排序,而是轮流对每个组进行排序。




5.归并排序算法


5.1 归并排序算法解析:


将一个大的无序数组有序,我们可以把大的数组分成两个,然后对这两个数组分别进行排序,之后在把这两个数组合并成一个有序的数组。由于两个小的数组都是有序的,所以在合并的时候是很快的。

通过递归的方式将大的数组一直分割,直到数组的大小为 1,此时只有一个元素,那么该数组就是有序的了,之后再把两个数组大小为1的合并成一个大小为2的,再把两个大小为2的合并成4的 …… 直到全部小的数组合并起来。
程序员常用的几种算法





5.2 示例代码:


public class MergeSort {// 归并排序public static int[] mergeSort(int[] arr, int left, int right) {// 如果 left == right,表示数组只有一个元素,则不用递归排序if (left < right) {// 把大的数组分隔成两个数组int mid = (left + right) / 2;// 对左半部分进行排序arr = mergeSort(arr, left, mid);// 对右半部分进行排序arr = mergeSort(arr, mid + 1, right);//进行合并merge(arr, left, mid, right);}return arr;}// 合并函数,把两个有序的数组合并起来// arr[left..mif]表示一个数组,arr[mid+1 .. right]表示一个数组private static void merge(int[] arr, int left, int mid, int right) {//先用一个临时数组把他们合并汇总起来int[] a = new int[right - left + 1];int i = left;int j = mid + 1;int k = 0;while (i <= mid && j <= right) {if (arr[i] < arr[j]) {a[k++] = arr[i++];} else {a[k++] = arr[j++];}}while(i <= mid) a[k++] = arr[i++];while(j <= right) a[k++] = arr[j++];// 把临时数组复制到原数组for (i = 0; i < k; i++) {arr[left++] = a[i];}}
}

然而面试官要你写个非递归式的归并排序怎么办?
别怕,我这还撸了个非递归式的归并排序,代码如下:

public class MergeSort {// 非递归式的归并排序public static int[] mergeSort(int[] arr) {int n = arr.length;// 子数组的大小分别为1,2,4,8...// 刚开始合并的数组大小是1,接着是2,接着4....for (int i = 1; i < n; i += i) {//进行数组进行划分int left = 0;int mid = left + i - 1;int right = mid + i;//进行合并,对数组大小为 i 的数组进行两两合并while (right < n) {// 合并函数和递归式的合并函数一样merge(arr, left, mid, right);left = right + 1;mid = left + i - 1;right = mid + i;}// 还有一些被遗漏的数组没合并,千万别忘了// 因为不可能每个字数组的大小都刚好为 iif (left < n && mid < n) {merge(arr, left, mid, n - 1);}}return arr;}
}



6.快速排序算法


6.1 快速排序算法解析:


我们从数组中选择一个元素,我们把这个元素称之为中轴元素吧,然后把数组中所有小于中轴元素的元素放在其左边,所有大于或等于中轴元素的元素放在其右边,显然,此时中轴元素所处的位置的是有序的。也就是说,我们无需再移动中轴元素的位置。
从中轴元素那里开始把大的数组切割成两个小的数组(两个数组都不包含中轴元素),接着我们通过递归的方式,让中轴元素左边的数组和右边的数组也重复同样的操作,直到数组的大小为1,此时每个元素都处于有序的位置。
程序员常用的几种算法





6.2 示例代码:


public class QuickSort {public static int[] quickSort(int[] arr, int left, int right) {if (left < right) {//获取中轴元素所处的位置int mid = partition(arr, left, right);//进行分割arr = quickSort(arr, left, mid - 1);arr = quickSort(arr, mid + 1, right);}return arr;}private static int partition(int[] arr, int left, int right) {//选取中轴元素int pivot = arr[left];int i = left + 1;int j = right;while (true) {// 向右找到第一个小于等于 pivot 的元素位置while (i <= j && arr[i] <= pivot) i++;// 向左找到第一个大于等于 pivot 的元素位置while(i <= j && arr[j] >= pivot ) j--;if(i >= j)break;//交换两个元素的位置,使得左边的元素不大于pivot,右边的不小于pivotint temp = arr[i];arr[i] = arr[j];arr[j] = temp;}arr[left] = arr[j];// 使中轴元素处于有序的位置arr[j] = pivot;return j;}
}



7.堆排序算法


7.1 堆排序算法解析:


堆的特点就是堆顶的元素是一个最值,大顶堆的堆顶是最大值,小顶堆则是最小值。
堆排序就是把堆顶的元素与最后一个元素交换,交换之后破坏了堆的特性,我们再把堆中剩余的元素再次构成一个大顶堆,然后再把堆顶元素与最后第二个元素交换….如此往复下去,等到剩余的元素只有一个的时候,此时的数组就是有序的了。
程序员常用的几种算法





7.2 示例代码:


 public class Head {// 堆排序public static int[] headSort(int[] arr) {int n = arr.length;//构建大顶堆for (int i = (n - 2) / 2; i >= 0; i--) {downAdjust(arr, i, n - 1);}//进行堆排序for (int i = n - 1; i >= 1; i--) {// 把堆顶元素与最后一个元素交换int temp = arr[i];arr[i] = arr[0];arr[0] = temp;// 把打乱的堆进行调整,恢复堆的特性downAdjust(arr, 0, i - 1);}return arr;}//下沉操作public static void downAdjust(int[] arr, int parent, int n) {//临时保存要下沉的元素int temp = arr[parent];//定位左孩子节点的位置int child = 2 * parent + 1;//开始下沉while (child <= n) {// 如果右孩子节点比左孩子大,则定位到右孩子if(child + 1 <= n && arr[child] < arr[child + 1])child++;// 如果孩子节点小于或等于父节点,则下沉结束if (arr[child] <= temp ) break;// 父节点进行下沉arr[parent] = arr[child];parent = child;child = 2 * parent + 1;}arr[parent] = temp;}
}



8.计数排序算法


8.1 计数排序算法解析:


计数排序是一种适合于最大值和最小值的差值不是不是很大的排序。
基本思想:就是把数组元素作为数组的下标,然后用一个临时数组统计该元素出现的次数,例如 temp[i] = m, 表示元素 i 一共出现了 m 次。最后再把临时数组统计的数据从小到大汇总起来,此时汇总起来是数据是有序的。
程序员常用的几种算法





8.2 示例代码:


public class Counting {public static int[] countSort(int[] arr) {if(arr == null || arr.length < 2) return arr;int n = arr.length;int max = arr[0];// 寻找数组的最大值for (int i = 1; i < n; i++) {if(max < arr[i])max = arr[i];}//创建大小为max的临时数组int[] temp = new int[max + 1];//统计元素i出现的次数for (int i = 0; i < n; i++) {temp[arr[i]]++;}int k = 0;//把临时数组统计好的数据汇总到原数组for (int i = 0; i <= max; i++) {for (int j = temp[i]; j > 0; j--) {arr[k++] = i;}}return arr;}
}

8.3 优化计数排序代码

上面的代码中,我们是根据 max 的大小来创建对应大小的数组,假如原数组只有10个元素,并且最小值为 min = 10000,最大值为 max = 10005,那我们创建 10005 + 1 大小的数组不是很吃亏,最大值与最小值的差值为 5,所以我们创建大小为6的临时数组就可以了。
也就是说,我们创建的临时数组大小 (max - min + 1)就可以了,然后在把 min作为偏移量。优化之后的代码如下所示:

public class Counting {public static int[] sort(int[] arr) {if(arr == null || arr.length < 2) return arr;int n = arr.length;int min = arr[0];int max = arr[0];// 寻找数组的最大值与最小值for (int i = 1; i < n; i++) {if(max < arr[i])max = arr[i];if(min > arr[i])min = arr[i];}int d = max - min + 1;//创建大小为max的临时数组int[] temp = new int[d];//统计元素i出现的次数for (int i = 0; i < n; i++) {temp[arr[i] - min]++;}int k = 0;//把临时数组统计好的数据汇总到原数组for (int i = 0; i < d; i++) {for (int j = temp[i]; j > 0; j--) {arr[k++] = i + min;}}return arr;}
}



9.桶排序算法


9.1 桶排序算法解析:


桶排序就是把最大值和最小值之间的数进行瓜分,例如分成 10 个区间,10个区间对应10个桶,我们把各元素放到对应区间的桶中去,再对每个桶中的数进行排序,可以采用归并排序,也可以采用快速排序之类的,之后每个桶里面的数据就是有序的了,我们在进行合并汇总。




9.2 示例代码:


public class BucketSort {public static int[] BucketSort(int[] arr) {if(arr == null || arr.length < 2) return arr;int n = arr.length;int max = arr[0];int min = arr[0];// 寻找数组的最大值与最小值for (int i = 1; i < n; i++) {if(min > arr[i])min = arr[i];if(max < arr[i])max = arr[i];}//和优化版本的计数排序一样,弄一个大小为 min 的偏移值int d = max - min;//创建 d / 5 + 1 个桶,第 i 桶存放  5*i ~ 5*i+5-1范围的数int bucketNum = d / 5 + 1;ArrayList<LinkedList<Integer>> bucketList = new ArrayList<>(bucketNum);//初始化桶for (int i = 0; i < bucketNum; i++) {bucketList.add(new LinkedList<Integer>());}//遍历原数组,将每个元素放入桶中for (int i = 0; i < n; i++) {bucketList.get((arr[i]-min)/d).add(arr[i] - min);}//对桶内的元素进行排序,我这里采用系统自带的排序工具for (int i = 0; i < bucketNum; i++) {Collections.sort(bucketList.get(i));}//把每个桶排序好的数据进行合并汇总放回原数组int k = 0;for (int i = 0; i < bucketNum; i++) {for (Integer t : bucketList.get(i)) {arr[k++] = t + min;}}return arr;}
}



10.基数排序算法


10.1 基数排序算法解析:


基数排序的排序思路是这样的:先以个位数的大小来对数据进行排序,接着以十位数的大小来多数进行排序,接着以百位数的大小……排到最后,就是一组有序的元素了。不过,他在以某位数进行排序的时候,是用“桶”来排序的。由于某位数(个位/十位….,不是一整个数)的大小范围为0-9,所以我们需要10个桶,然后把具有相同数值的数放进同一个桶里,之后再把桶里的数按照0号桶到9号桶的顺序取出来,这样一趟下来,按照某位数的排序就完成了
程序员常用的几种算法




10.2 示例代码:


public class RadioSort {public static int[] radioSort(int[] arr) {if(arr == null || arr.length < 2) return arr;int n = arr.length;int max = arr[0];// 找出最大值for (int i = 1; i < n; i++) {if(max < arr[i]) max = arr[i];}// 计算最大值是几位数int num = 1;while (max / 10 > 0) {num++;max = max / 10;}// 创建10个桶ArrayList<LinkedList<Integer>> bucketList = new ArrayList<>(10);//初始化桶for (int i = 0; i < 10; i++) {bucketList.add(new LinkedList<Integer>());}// 进行每一趟的排序,从个位数开始排for (int i = 1; i <= num; i++) {for (int j = 0; j < n; j++) {// 获取每个数最后第 i 位是数组int radio = (arr[j] / (int)Math.pow(10,i-1)) % 10;//放进对应的桶里bucketList.get(radio).add(arr[j]);}//合并放回原数组int k = 0;for (int j = 0; j < 10; j++) {for (Integer t : bucketList.get(j)) {arr[k++] = t;}//取出来合并了之后把桶清光数据bucketList.get(j).clear();}}return arr;}
}



程序员常用的几种算法

总结


编程算法是编程世界的核心,它们可以解决各种问题。从搜索和排序到图算法和动态规划,每种算法都有其独特的应用场景。通过掌握这些算法,您将能够更好地理解编程世界的奥秘,并且能够更高效地解决问题。无论您是新手还是有经验的程序员,学习和掌握这些算法都是必不可少的。希望本文对您有所帮助,并能够激发您在编程领域的创造力和热情。


如若本文能帮您, 希望您能关注Python老吕的CSDN博客 ;
您可以在本文进行评论,老吕将努力快速回复,和您近距离交流各种问题;
博主ID:Python老吕,希望大家点赞、评论、收藏。


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

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

相关文章

【PyTorch】进阶学习:探索BCEWithLogitsLoss的正确使用---二元分类问题中的logits与标签形状问题

【PyTorch】进阶学习&#xff1a;探索BCEWithLogitsLoss的正确使用—二元分类问题中的logits与标签形状问题 &#x1f308; 个人主页&#xff1a;高斯小哥 &#x1f525; 高质量专栏&#xff1a;Matplotlib之旅&#xff1a;零基础精通数据可视化、Python基础【高质量合集】、Py…

微服务架构 | 多级缓存

INDEX 通用设计概述2 优势3 最佳实践 通用设计概述 通用设计思路如下图 内容分发网络&#xff08;CDN&#xff09; 可以理解为一些服务器的副本&#xff0c;这些副本服务器可以广泛的部署在服务器提供服务的区域内&#xff0c;并存有服务器中的一些数据。 用户访问原始服务器…

(未解决)macOS matplotlib 中文是方框

reference&#xff1a; Mac OS系统下实现python matplotlib包绘图显示中文(亲测有效)_mac plt 中文值-CSDN博客 module ‘matplotlib.font_manager‘ has no attribute ‘_rebuild‘解决方法_font_manager未解析-CSDN博客 # 问题描述&#xff08;笑死 显而易见 # solve 找到…

【Linux】 yum —— Linux 的软件包管理器

Linux 的软件包管理器 yum yum 是什么什么是软件包查看软件包 yum 命令行工具yum 配置文件yum 凭什么可以支持下载呢&#xff1f;yum 生态yum 社区yum 的故障排除和资源支持yum 的持续集成和持续交付 yum 是什么 Yum&#xff08;Yellowdog Updater Modified&#xff09;是一个…

【PCIe】TLP结构与配置空间

&#x1f525;博客主页&#xff1a;PannLZ 文章目录 PCIe TLP结构PCIe配置空间和地址空间 PCIe TLP结构 TLP 主要由3个部分组成&#xff1a; Header 、 数据(可选&#xff0c;取决于具体的TLP 类 型 ) 和 ECRC (End to End CRC, 可选)。TLP 都始于发送端的事务层&#xff0c;终…

物联网,智慧城市的数字化转型引擎

随着科技的飞速发展&#xff0c;物联网&#xff08;IoT&#xff09;已成为推动智慧城市建设的关键力量。物联网技术通过连接各种设备和系统&#xff0c;实现数据的实时采集、传输和处理&#xff0c;为城市的智能化管理提供了强大的支持。在数字化转型的浪潮中&#xff0c;物联网…

【操作系统概念】 第8章:内存管理

文章目录 0.前言8.1 背景8.1.1 基本硬件8.1.2 地址绑定8.1.3 逻辑地址空间和物理地址空间8.1.4 动态加载&#xff08;dynamic loading&#xff09;8.1.5 动态链接&#xff08;dynamically linking&#xff09;与共享库 8.3 连续内存分配&#xff08;contiguous memory allocati…

【linuxC语言】dup、dup2函数

文章目录 前言一、dup函数二、dup2函数三、将标准输出重定向到文件总结 前言 在Linux环境下&#xff0c;dup、dup2以及原子操作都是用于文件描述符管理和处理的重要工具。这些功能提供了对文件描述符进行复制和原子操作的能力&#xff0c;使得在多线程或多进程环境中更加安全和…

10大主流压力/负载/性能测试工具推荐

在移动应用和Web服务正式发布之前&#xff0c;除了进行必要的功能测试和安全测试&#xff0c;为了保证互联网产品的服务交付质量&#xff0c;往往还需要做压力/负载/性能测试。然而很多传统企业在试水互联网的过程中&#xff0c;往往由于资源或产品迭代速度等原因忽视了这一块工…

整屋案例丨福州府108m²3室2厅2卫轻奢有度,高级耐看。福州中宅装饰,福州装修

空间之间的空间 比空间本身更具有意味&#xff0c; 但也容易被忽略&#xff0c; 正是由于“之间”的多元性和复杂性 以及它的不确定性&#xff0c; 空间之间变得无限可能。 平面设计图 项目信息 项目名称 | 福州府 设计地址 | 福建福州 项目面积 | 108㎡ 项目户型 | …

【JavaEE初阶】 JVM类加载简介

文章目录 &#x1f343;前言&#x1f332;类加载过程&#x1f6a9;加载&#x1f6a9;验证&#x1f6a9;准备&#x1f6a9;解析&#x1f6a9;初始化 &#x1f384;双亲委派模型&#x1f6a9;什么是双亲委派模型&#xff1f;&#x1f6a9;双亲委派模型的优点 ⭕总结 &#x1f343…

程序运行的基本流程

操作系统&#xff08;应用程序&#xff09;&#xff1a; 装系统就是将操作系统安装到硬盘1中 计算机启动的基本过程&#xff1a; 总结&#xff1a; 程序一般保存在硬盘中&#xff0c;软件安装的过程就是将程序写入硬盘的过程程序在运行时会加载进入内存&#xff0c;然后由CPU…

Alveo U200 和 U250 数据中心加速器卡硬件原理图

U200原理图中的一些重要组件和接口如下&#xff1a; QSFP (Quad Small Form-factor Pluggable)&#xff1a;QSFP 是一种高速网络连接器&#xff0c;可支持 40GbE/100GbE 等数据传输速率。在 U200 中&#xff0c;QSFP 用于与外部设备进行高速网络通信。 闪存&#xff1a;闪存是…

【Python】6. 基础语法(4) -- 列表+元组+字典篇

列表和元组 列表是什么, 元组是什么 编程中, 经常需要使用变量, 来保存/表示数据. 如果代码中需要表示的数据个数比较少, 我们直接创建多个变量即可. num1 10 num2 20 num3 30 ......但是有的时候, 代码中需要表示的数据特别多, 甚至也不知道要表示多少个数据. 这个时候,…

重磅发布|AutoMQ 1.0.0 GA 版本官宣:已验证生产环境可用性

AutoMQ 是基于云构建的无服务、极速弹性、极具成本效益的下一代 Kafka。100%兼容Apache Kafka&#xff0c;无分区数据复制。在无副作用的前提下解决了 Kafka 弹性、运维上的诸多痛点并且带来了数量级的成本降低。 AutoMQ 1.0.0 GA 版本现已在 Github 仓库 (https://github.com…

tcp服务器客户端通信(socket编程)

目录 1.编程流程 2.代码演示 2.1 服务器代码 2.2 客户端代码 3.注意 3.1 ping命令 3.2 netstat命令 3.3 为什么memset? 3.4 哪个会阻塞? 3.5 显示连接信息 1.编程流程 2.代码演示 2.1 服务器代码 #include <stdio.h> #include <stdlib.h> #include <…

Logseq电脑端+安卓端同步gitee或github

文章目录 0.初衷1.电脑端1.1 新建仓库1.2 克隆项目&#xff0c;生成秘钥1.3 添加图谱&#xff0c;选择文件目录&#xff0c;我是原本就有笔记&#xff0c;所以会如下所示。1.4 下载脚本文件1.5赋权限 &#xff08;windows可跳过&#xff09;1.6 修改脚本命令1.7 logseq设置同步…

Docker-完整项目的部署(保姆级教学)

目录 1 手动部署(白雪版) 1.1 创建网络 1.2 MySQL的部署 1.2.1 准备 1.2.2 部署 1.3 Java项目的部署 1.3.1 准备 1.3.1.1 将Java项目打成jar包 1.3.1.2 编写Dockerfile文件 1.3.2 部署 1.3.2.1 将jar包、Dockerfile文件放在linux同一个文件夹下 1.3.2.2 构建镜像 …

C# 用Trace.WriteLine输出调试信息无法查看

写程序就会遇见BUG&#xff0c;这时候在代码不同部位输出一些标记的信息对查找错误非常有必要&#xff0c;一般情况下我们都是使用Console.WriteLine()方法来打印信息到控制台窗口&#xff0c;但有时候使用Console.WriteLine()方法会存在不方便的情况&#xff0c;比如鄙人遇到的…

tomcat优化与部署(三)------nignx优化与nginx +tomcat 部署

在目前流行的互联网架构中&#xff0c;Tomcat在目前的网络编程中是举足轻重的&#xff0c;由于Tomcat的运行依赖于JVM&#xff0c;从虚拟机的角度把Tomcat的调整分为外部环境调优 JVM 和 Tomcat 自身调优两部分 Tomcat 是一个流行的开源 Java 服务器&#xff0c;用于托管 Java …