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

C++核心编程--类篇

C++核心编程

1.内存分区模型

C++程序在执行时,将内存大方向分为4个区域

意义:不同区域存放数据,赋予不同的生命周期,更能灵活编程

  • 代码区:存放函数体的二进制代码,由操作系统进行管理的
  • 全局区:存放全局变量和静态变量以及常量
  • 栈区:由编译器自动分配释放,存放函数的参数值,局部变量等
  • 堆区:由程序员分配和释放,若程序员不释放,程序结束时由操作系统回收

1.1、程序运行前

代码区

  1. 存放CPU执行的机器指令
  2. 代码区是共享的,共享的目的是为了频繁被执行的程序
  3. 代码区是只读的,防止程序以外地修改它的指令

全局区

  1. 全局变量静态变量存放在此
  2. 全局区包含了常量区
  3. 该区域数据在程序结束后操作系统自动释放

1.2、程序运行后

栈区

  1. 不要返回局部变量地址,栈区开辟的数据会被编译器自动释放

#include<iostream>
using namespace std;int* func() {int a = 10; //局部变量return &a; //返回局部变量的值
}int main() {int* p = func();cout << *p << endl; //编译器会自动保存一次正确的值cout << *p << endl;cout << *p << endl;system("pause");return 0;
}

image-20230830074906875

堆区:

  1. 由我们自己开辟内存,我们不结束程序,不会释放
#include<iostream>
using namespace std;int* fun() {//new关键字,可以将数据开辟到堆区int * a = new int(10);return a;
}int main() {int * p = fun();cout << *p << endl;cout << *p << endl;cout << *p << endl;system("pause");return 0;
}

image-20230830081237728

1.3、new关键字

在堆区中开辟数据,可以使用new关键字

利用new创建的数据,会返回该数据对应的类型的指针

语法: new 数据类型

  • 开辟数据后可以手动释放,利用delete

#include<iostream>
using namespace std;int* fun() {//new关键字,可以将数据开辟到堆区int * a = new int(10);return a;
}int main() {int * p = fun();cout << *p << endl;cout << *p << endl;//释放数据delete p;cout << *p << endl;system("pause");return 0;
}

image-20230830093101931

这里只会输出打印俩个P数据

image-20230830093204647

  1. 数组同理

语法 int * arr = new int[10];

delete [] arr

void fun() {//new关键字,可以将数据开辟到堆区//int * a = new int(10);//return a;int* arr = new int[10];for (int i = 0; i < 10; i++){arr[i] = i + 100;}for (int i = 0; i < 10; i++){cout << arr[i] << endl;}//删除数组delete [] arr;
}

2、引用

作用:给变量起别名

语法:数据类型 &别名 = 原名

注意:一旦初始化,不可以更改,不能再次修改别名指向另一个

本质:引用的本质在C++内部实现是个指针常量


#include<iostream>
using namespace std;
int main() {int a = 10;//给a取个别名bint &b = a;cout <<  b << endl;//利用别名修改a的值b = 100;cout << b << endl;system("pause");return 0;
}

image-20230830180236430

2.1、引用做函数参数

作用:函数传参时,可以利用引用的技术让形参修饰实参

优秀:可以简化指针修改实参

//交换
void swap01(int& a, int& b) {int temp = a;a = b;b = temp;
}#include<iostream>
using namespace std;
int main() {int a = 10;int b = 20;swap01(a, b);cout << "交换后A:" << a << endl;cout << "交换后B:" << b << endl;system("pause");return 0;
}

image-20230830182257758

2.2、引用做函数返回值

作用:作为返回值存在

注意:不要返回局部变量引用

用法:函数调用作为左值(左边的值)

  1. 返回局部变量情况(错误)
int& test02() {int a = 10;return a;
}
int main() {int& b = test02();cout << b << endl;//编译器会做一次预存,后面就会出错cout << b << endl;cout << b << endl;system("pause");return 0;
}

image-20230830183250939

  1. 正确做法

    int & test02() {static int a = 10; //静态变量,存放在全局区return a;
    }
    

image-20230830183513266

2.2、常量引用

用来修饰形参,防止误操作

//用来修饰形参
void printA(const int  & a) {//a = 100; 这里就不能修改acout << "值为:" << a << endl;
}

3、函数高级

3.1、函数的默认参数

语法: 返回值类型 函数名 (形参 = 默认值){}

//设置了俩个默认参数
int func(int a, int b = 10, int c = 30) {return a + b + c;
}int main() {int a = func(10);cout << a << endl;system("pause");return 0;
}

注意

  1. 设置默认参数从这个位置往后的每个参数都必须有默认参数,否则报错 这里的C也必须有默认参数

image-20230831171310436

  1. 如果函数声明有默认参数,函数实现就不可能有默认参数

声明和实现只能有一个有参数

//定义一个函数
//声明
int func2(int a = 10, int b = 10);
//实现
int func2(int a = 10, int b = 10) {return a + b;
}int main() cout << func2(10, 20) << endl;system("pause");return 0;
}

image-20230831171756539

3.2、函数占位参数

语法:返回值类型 函数名 (数据类型){}

void func(int a, int) {cout << "1111" << endl;
}
  1. 占位参数可以有默认值
void func(int a, int = 10) {cout << "1111" << endl;
}

3.3、函数重载概述

作用:函数名可以相同,提高复用性

函数重载的满足条件

  1. 同一作用域下
  2. 函数名称相同
  3. 函数参数类型不同 或者 个数不同 或者 顺序不同

注意:函数的返回值不可以作为函数重载的条件

#include<iostream>
using namespace std;//函数重载
//可以让函数名相同,提高复用性
//以下俩个均在全局作用域下
void func() {cout << "第一个方法" << endl;
}
//函数参数`类型不同`
void func(int a) {cout << "第二个方法" << endl;
}int main() {func();system("pause");return 0;
}

image-20230902092708718

根据传入的参数不同,可以调用不同的参数的相同名的方法

注意:函数的返回值不可以作为函数重载的条件

image-20230902093029689

3.3.1、函数重载的注意事项

  1. 引用作为重载条件

  2. 函数重载碰到函数默认参数

  • 引用作为重载条件
//引用做重载的条件
void func(int& a) {cout << "引用调用" << endl;
}void func(const int& a) {cout << "常量引用调用" << endl;
}int main() {int a = 10;func(a);//这里的直接插入10会生成一个临时变量赋给const int// int temp = 10;// const int  = temp;func(10);system("pause");return 0;
}

image-20230902100731340

  • 函数重载碰到函数默认参数
//函数重载碰到函数默认参数
void func2(int a, int b = 10) {cout << "方法1" << endl;
}
void func2(int a) {cout << "方法2" << endl;
}int main() {//这里会报错func2(10);system("pause");return 0;
}

image-20230902101024896

4、类和对象

c++面向对象的三大特征:封装、继承、多态

4.1、封装

意义:

  1. 将属性和行为作为一个整体,表现生活中的事务
  2. 将属性和行为加以权限控制
  3. 在设计类的时候,属性和行为写在一起,表现事务

语法: class 类名{ 访问权限: 属性 / 行为}

#include<iostream>
using namespace std;
//eg:设计一个圆的类 求圆的周长//定义常量
const double PI = 3.14;class  Cricle
{//访问权限 公共的
public://定义一个半径int m_r;//获取周长double CricleZC() {return 2 * PI * m_r;}
};int main() {//实例化 一个对象Cricle cr;//给对象属性赋值cr.m_r = 10;/cout << "周长为:" << cr.CricleZC() << endl;system("pause");return 0;
}
  • 可利用方法去间接修改属性的值
class Student {//访问权限
public:string name;int St_num;void pr_inf() {cout << "姓名:" << name << '\n' << "学号:" << St_num << endl;}//给姓名赋值void setName(string nm) {name = nm;}void setSt_num(int num) {St_num = num;}};

4.1.1、封装的访问权限

访问权限分为三种:

  1. public 公共权限
  2. protected 保护权限
  3. private 私有权限
  • public 公共权限--------类内可以访问 类外可以访问

  • protected 保护权限--------类内可以访问 类外不可以被访问 (子类可以访问父类的保护内容)

  • private 私有权限--------类内可以访问 类外不可以被访问 (子类不可以访问父类的私有内容)

class Person 
{
public://公共权限string m_Name;protected://保护权限string m_car;private://私有权限int m_id;
};int main() {Person p1;p1.m_Name = "zy";//类内可以访问 类外不可以被访问//p1.m_car = "zzz";//p1.m_id = 123445;system("pause");return 0;
}

image-20230907161711380

image-20230907161724052

4.1.2、struct和class区别

struct和class的唯一区别:默认访问的权限不同

  • struct 默认权限为公有
  • class 默认权限为私有
class C1 {int c1_age;
};struct C2
{int c2_age;
};int main() {C1 c1;//报错//c1.c1_age = 100;C2 c2;c2.c2_age = 100;system("pause");return 0;
}

image-20230907162608184

4.1.3、成员属性设置为私有

  1. 将所有成员属性设置为私有,可以自己控制读写
  2. 对于写权限,我们可以检测数据的有效性
#include<iostream>
#include<string>
using namespace std;class Person
{
public://定义获取设置名字方法,方便类外部使用string getName(){return p_name;}void setName(string name){p_name = name;}//可以根据传入值检测数据的有效性void setAge(int age) {//检测输入的值if (age<0||age>=150){//输入错误设置默认值,并使该方法失效p_age = 0;cout << "输入的值为错误值" << endl;return;}//如果上面检测不通过,不会执行该条语句p_age = age;}int getAge() {return p_age;}private:string p_name;int p_age;
};int main() {Person p1;p1.setName("zyy");p1.setAge(170);string name = p1.getName();int age = p1.getAge();cout << "姓名:" << name <<'\n' << "年龄:" << age << endl;system("pause");return 0;
}

image-20230907165744439

4.1.4、类练习题

  1. 设计立方体类
    • 求出立方体的面积和体积
    • 分别用全局函数和成员函数判断俩个立方体是否相等

image-20230907175049565

#include<iostream>
using namespace std;class Cuboid
{
public://获取面积int getCuboid_are(){//(长×宽+宽×高+长×高)×2 面积公式return ((m_H * m_L) + (m_H * m_W) + (m_L * m_W) * 2);}//获取体积int getCuboid_vol() {return m_H * m_L * m_W;}//设置长方体长宽高void setCuboid_H(int H){m_H = H;}void setCuboid_L(int L){m_L = L;}void setCuboid_W(int W){m_W = W;}//获取长方体的长宽高int getCuboid_H() {return m_H;}int getCuboid_L() {return m_L;}int getCuboid_W() {return m_W;}//利用成员函数判断是否相等//这里只传c2 因为类已经存了一个立方体的数下,再更另一个作对比//谁调用这个函数就传另一个  c1.isEq2(c2);bool isEq2(Cuboid& c2) {if (m_H == c2.getCuboid_H() && m_L == c2.getCuboid_L() && m_W == c2.getCuboid_W()){return 1;}return 0;}private://定义长方体的长宽高int m_H;int m_L;int m_W;
};//全局判断是否相等 传入地址节约内存
bool isEq(Cuboid &c1,Cuboid &c2) {if (c1.getCuboid_H() == c2.getCuboid_H()&&c1.getCuboid_L()==c2.getCuboid_L()&&c1.getCuboid_W() == c2.getCuboid_W()){return 1;}return 0;
}int main() {Cuboid c1,c2;c1.setCuboid_H(10);c1.setCuboid_L(10);c1.setCuboid_W(10);	c2.setCuboid_H(10);c2.setCuboid_L(10);c2.setCuboid_W(10);int area = c1.getCuboid_are();int vol = c1.getCuboid_vol();cout << "area:" << area << '\n' << "vol:" << vol << endl;//利用全局函数判断是否相等bool flag =  isEq(c1, c2);cout << flag << endl;//利用c1的属性去对比c2bool flag2 = c1.isEq2(c2);cout << flag2 << endl;system("pause");return 0;
}
  1. 点和圆的关系
    • 设计一个圆形类(Circle),和一个点类(Point),计算点和圆的关系

image-20230908092919384

#include<iostream>
using namespace std;class Point {
public://设置X坐标和Y坐标void setPoint_X(int x) {p_X = x;}void setPoint_Y(int y) {p_Y = y;}//获取X坐标和Y坐标int getPoint_X() {return p_X;}int getPoint_Y() {return p_Y;}private://定义X坐标和Y坐标int p_X;int p_Y;
};class Circle {
public://设置圆心和半径void setCircle_R(int R) {c_R = R;}void setCircle_XY(int X,int Y) {c_P.setPoint_X(X);c_P.setPoint_Y(Y);}//获取圆心和半径int getCircle_R() {return c_R;}int getCircle_X() {return c_P.getPoint_X();}int getCircle_Y() {return c_P.getPoint_Y();}//判断点和圆的关系int  isEq(Point p) {//获取点到圆心的距离int distance =(c_P.getPoint_X() - p.getPoint_X()) * (c_P.getPoint_X() - p.getPoint_X()) +(c_P.getPoint_Y() - p.getPoint_Y()) * (c_P.getPoint_Y() - p.getPoint_Y());int rDistance = c_R * c_R;// 1点在圆上,2点在圆外,3点在内if (distance == rDistance){cout << "圆上" << endl;return 1;}else if (distance > rDistance) {cout << "圆外" << endl;return 2;}else{cout << "圆内" << endl;return 3;}}private://定义半径和圆心int c_R;//在内中可以让另一个类作为本类中的成员Point c_P;
};int main() {Circle c1;//设置半径和圆心c1.setCircle_R(10);c1.setCircle_XY(10, 0);//创建点Point p;p.setPoint_X(10);p.setPoint_Y(10);int a = c1.isEq(p);cout << a << endl;system("pause");return 0;
}

4.1.5、类的拆分

基于上面练习题做一个拆分

  1. 在头文件中创建一个.h后缀的头文件

image-20230908093526535

  1. 在源文件中创建一个.cpp后缀的源文件

image-20230908094439218

  1. point.h中只需要成员函数的声明和成员变量的声明。

image-20230908094603435

//防止头文件重复包含,避免名称冲突
#pragma once
#include<iostream>
using namespace std;class Point {
public://设置X坐标和Y坐标void setPoint_X(int x);void setPoint_Y(int y);//获取X坐标和Y坐标int getPoint_X();int getPoint_Y();
private://定义X坐标和Y坐标int p_X;int p_Y;
};
  1. point.cpp源文件中只需要留住所有函数的实现就可以

注意这里如果直接写会报错需要告诉编译器是哪个作用域下面的函数

image-20230908095215386

#include "point.h"//设置X坐标和Y坐标//Point::告诉编译器是Point作用域下面的函数void Point::setPoint_X(int x) {p_X = x;}void Point::setPoint_Y(int y) {p_Y = y;}//获取X坐标和Y坐标int Point::getPoint_X() {return p_X;}int Point::getPoint_Y() {return p_Y;}
  1. 同理实现Circle的拆分

这里如果涉及到引用其他类需要include引用一下

image-20230908095716045

  • Circle.h
#pragma once
#include <iostream>
#include "point.h"
using namespace std;class Circle {
public://设置圆心和半径void setCircle_R(int R);void setCircle_XY(int X, int Y);//获取圆心和半径int getCircle_R();int getCircle_X();int getCircle_Y();//判断点和圆的关系int  isEq(Point p);private://定义半径和圆心int c_R;//在内中可以让另一个类作为本类中的成员Point c_P;
};
  • Circle.cpp
#include "Circle.h"//设置圆心和半径void Circle::setCircle_R(int R) {c_R = R;}void Circle::setCircle_XY(int X, int Y) {c_P.setPoint_X(X);c_P.setPoint_Y(Y);}//获取圆心和半径int Circle::getCircle_R() {return c_R;}int Circle::getCircle_X() {return c_P.getPoint_X();}int Circle::getCircle_Y() {return c_P.getPoint_Y();}//判断点和圆的关系int  Circle::isEq(Point p) {int distance =(c_P.getPoint_X() - p.getPoint_X()) * (c_P.getPoint_X() - p.getPoint_X()) +(c_P.getPoint_Y() - p.getPoint_Y()) * (c_P.getPoint_Y() - p.getPoint_Y());int rDistance = c_R * c_R;// 1点在圆上,2点在圆外,3点在内if (distance == rDistance){cout << "圆上" << endl;return 1;}else if (distance > rDistance) {cout << "圆外" << endl;return 2;}else{cout << "圆内" << endl;return 3;}}
  1. 在想要用这个源文件中直接引用就可以使用了
#include<iostream>
using namespace std;
#include "point.h"
#include "Circle.h"int main() {Circle c1;//设置半径和圆心c1.setCircle_R(10);c1.setCircle_XY(10, 0);//创建点Point p;p.setPoint_X(10);p.setPoint_Y(10);int a = c1.isEq(p);cout << a << endl;system("pause");return 0;
}

相关文章:

C++核心编程--类篇

C核心编程 1.内存分区模型 C程序在执行时&#xff0c;将内存大方向分为4个区域 意义&#xff1a;不同区域存放数据&#xff0c;赋予不同的生命周期&#xff0c;更能灵活编程 代码区&#xff1a;存放函数体的二进制代码&#xff0c;由操作系统进行管理的全局区&#xff1a;存放…...

java中用feign远程调用注解FeignClient的时候不重写Encoder和Decoder怎么格式不对呢?

如果在使用 Feign 进行远程调用时&#xff0c;没有重写 Encoder 和 Decoder&#xff0c;但仍然遇到格式不对的问题&#xff0c;可能是由于以下原因之一&#xff1a; 服务端返回的数据格式与客户端期望的格式不匹配&#xff1a;Feign 默认使用基于 Jackson 的 Encoder 和 Decode…...

记录使用Docker Compose 部署《XAPI项目》遇道的问题及解决方案

《XAPI项目》&#xff1a;GitHub仓库&#xff08;勿打&#x1f6ab;小破站一个&#xff09; 这篇文档&#xff0c;主要内容是记录使用Docker Compose 部署《XAPI项目》遇道的问题及解决方案 目录 &#x1f4da; 本地MySQL数据如何导入到容器内的MySQL中❎ 解决报错&#xff1a;…...

腾讯云OCR实践 - 降低客服财务运营成本

一、 前言&#xff1a; 随着图片时代的飞速发展&#xff0c;大量的文字内容为了优化排版和表现效果&#xff0c;都采用了图片的形式发布和存储&#xff0c;这为内容的传播和安全性带来了很大的便利&#xff0c;需要做重复性劳动。 OCR文字扫描工具也逐渐的应运而生&#xff0c;…...

springboot+vue上传图片

这里是一个简单的示例&#xff0c;演示了如何在Spring Boot中从Vue.js上传图像&#xff1a; 1.前端Vue.js代码&#xff1a; <template><div><input type"file" change"handleFileUpload"><button click"uploadImage">…...

高压电缆护层接地环流及温度在线监测系统

高压电缆的金属护层是电缆的重要组成部分&#xff0c;当缆芯通过电流时&#xff0c;会在金属护层上产生环流&#xff0c;外护套的绝缘状态差、接地不良、金属护层接地方式不正确等等都会引起护套环流异常现象&#xff0c;严重威胁电缆运行安全。 当电缆金属护层环流出现异常时…...

无涯教程-JavaScript - IPMT函数

描述 IPMT函数根据定期,固定的还款额和固定的利率返回给定投资期限内的利息支付。 语法 IPMT (rate, per, nper, pv, [fv], [type])争论 Argument描述Required/OptionalRateThe interest rate per period.RequiredPerThe period for which you want to find the interest a…...

【EI会议征稿】第三届机械自动化与电子信息工程国际学术会议(MAEIE 2023)

第三届机械自动化与电子信息工程国际学术会议&#xff08;MAEIE 2023&#xff09; 第三届机械自动化与电子信息工程国际学术会议&#xff08;MAEIE 2023&#xff09;将于2023年12月15-17日在江苏南京举行。本会议通过与业内众多平台、社会各团体协力&#xff0c;聚集机械自动…...

手写实现LRN局部响应归一化算子

1、重写算子的需求 芯片推理过程中遇到很多算子计算结果不对的情况&#xff0c;原因是封装的算子会在某些特殊情况下计算超限&#xff0c;比如输入shape特别大或者数值特别大时&#xff0c;LRN算子计算会出现NAN值&#xff0c;所以需要重写算子。先对输入数据做一个预处理&…...

朗思科技数字员工通过统信桌面操作系统兼容性互认认证

近日&#xff0c;朗思科技数字员工与统信桌面操作系统V20进行了兼容互认&#xff0c;针对上述产品的功能、兼容性方面&#xff0c;通过共同严格测试表明——朗思科技数字员工在统信桌面操作系统 V20上整体运行稳定&#xff0c;满足功能及兼容性测试要求。 北京朗思智能科技有限…...

十六、Webpack常见的插件和模式

一、认识插件Plugin Webpack的另一个核心是Plugin&#xff0c;官方有这样一段对Plugin的描述&#xff1a; While loaders are used to transform certain types of modules, plugins can be leveraged to perform a wider range of tasks like bundle optimization, asset m…...

ChatGPT新增超强插件:文本直接生成视频、海报,支持自定义修改!

全球著名在线设计平台Canva&#xff0c;在ChatGPT Plus&#xff08;GPT-4&#xff09;上推出了插件功能&#xff0c;用户通过文本提示&#xff0c;几秒钟就能生成演示文稿、PPT插图、电子书封面、宴会邀请函等各种精美设计海报&#xff0c;同时支持生成视频。 该插件最强大的功…...

亚像素边缘提取的例子

求帮忙下载&#xff1a; 1.http://download.csdn.net/detail/pkma75/925394 pkma75 资源积分&#xff1a;1分 备注&#xff1a;pdf格式&#xff0c;用曲线拟合的方法计算亚像素&#xff0c;编程易实现&#xff0c;具有较强的实用价值 2.http://download.csdn.net/detail/kua…...

Wayland:推动Linux桌面进入下一代图形显示时代

文章首发地址 Wayland是Linux系统下的一种图形显示协议&#xff0c;旨在替代X Window System&#xff08;X11&#xff09;作为Linux桌面环境的图形显示服务。下面是对Wayland的详细解释&#xff1a; 背景&#xff1a; 传统的Linux桌面环境使用X Window System&#xff08;X11&…...

mysql外键(foreign key)

简介 MySQL的外键约束用来在两个表数据之间建立链接&#xff0c;其中一张表的一个字段被另一张表中对应的字段约束。也就是说&#xff0c;设置外键约束至少要有两种表&#xff0c;被约束的表叫做从表&#xff08;子表&#xff09;&#xff0c;另一张叫做主表&#xff08;父表&…...

内网穿透——Windows搭建服务器

文章目录 1.前言2. Emby网站搭建2.1. Emby下载和安装2.2 Emby网页测试 3. 本地网页发布3.1 注册并安装cpolar内网穿透3.2 Cpolar云端设置3.3 Cpolar内网穿透本地设置 4.公网访问测试5.结语 1.前言 在现代五花八门的网络应用场景中&#xff0c;观看视频绝对是主力应用场景之一&…...

UE5.1 + Android 环境搭建

官方文档&#xff1a;一定一定一定要参照官方文档&#xff0c;因UE不同版本对应的环境搭建并不完全一致。 准备工作 通过EpicGameLaunch下载Android目标平台。 必须安装jdk1.8并配置环境变量&#xff0c;UE5.1不要使用最新的jdk20&#xff1b;下载地址 安装 Android Studio …...

华为python面试题目

华为Python常见的面试问题包括: Python是如何被解释的?什么是PEP8?Python是怎样管理内存的?什么是Python装饰器?Python提供哪些内置类型?Python中的异常处理是怎样的?什么是Python的上下文管理器?Python中的列表推导式是什么?Python中的生成器是什么?什么是Python的装…...

IP代理安全吗?如何防止IP被限制访问?

你是否遇到过可以正常上网&#xff0c;但访问某个网站却被禁止&#xff1f;注册某个网站账号&#xff0c;却被封号&#xff1f;那都是因为IP出现问题&#xff01;您的IP地址透露很多关于您的信息&#xff0c;包括您的位置和互联网活动。 在本文中&#xff0c;我们将一起了解IP地…...

使用 gst-template 创建自己的 gstreamer 插件

系列文章目录 创建 gstreamer 插件的几种方式 使用 gst-template 创建自己的 gstreamer 插件 使用 gst-plugins-bad 里面的 gst-element-maker 工具创建gstreamer 插件 文章目录 系列文章目录前言一、如何获取 gst-template 仓库代码二、gst-template 相关的软件依赖1. 根据自…...

Product Hunt 每日热榜 | 2026-04-09

1. Velo 标语&#xff1a;将任何内容分享为视频消息。 介绍&#xff1a;Velo 利用人工智能将你的原始屏幕录制转化为值得一看的、随时可以分享的视频。 产品网站&#xff1a; 立即访问 Product Hunt&#xff1a; View on Product Hunt 关键词&#xff1a;Velo, 视频消息, A…...

FigmaCN实战指南:3步实现Figma界面全中文化,提升设计师工作效率70%

FigmaCN实战指南&#xff1a;3步实现Figma界面全中文化&#xff0c;提升设计师工作效率70% 【免费下载链接】figmaCN 中文 Figma 插件&#xff0c;设计师人工翻译校验 项目地址: https://gitcode.com/gh_mirrors/fi/figmaCN FigmaCN是一款专为中文设计师打造的开源浏览器…...

【OpenClaw】通过 Nanobot 源码学习架构---()总体堵

核心摘要&#xff1a;这篇文章能帮你 ?? 1. 彻底搞懂条件分支与循环的适用场景&#xff0c;告别选择困难。 ?? 2. 掌握遍历DOM集合修改属性的标准姿势与性能窍门。 ?? 3. 识别流程控制中的常见“坑”&#xff0c;并学会如何优雅地绕过去。 ?? 主要内容脉络 ?? 一、痛…...

Nginx 学习总结式

1. 引入 在现代 AI 工程中&#xff0c;Hugging Face 的 tokenizers 库已成为分词器的事实标准。不过 Hugging Face 的 tokenizers 是用 Rust 来实现的&#xff0c;官方只提供了 python 和 node 的绑定实现。要实现与 Hugging Face tokenizers 相同的行为&#xff0c;最好的办法…...

揭秘AI写教材技巧!利用AI教材写作实现低查重、高质量教材编写!

教材创作&#xff1a;AI工具助力原创与合规平衡 在教材编写过程中&#xff0c;如何做到原创与合规的平衡是一个重要的议题。很多时候&#xff0c;创作者会在借鉴优秀教材时担心查重率超标&#xff0c;而在自行撰写知识点时又可能面临逻辑不够严谨和内容不准确的问题。引用他人…...

化工园区智慧巡检平台

化工园区智慧巡检平台概述化工园区智慧巡检平台通过物联网、大数据、人工智能等技术&#xff0c;实现巡检流程数字化、智能化&#xff0c;提升安全性和效率。平台通常涵盖设备监控、隐患识别、数据分析、应急响应等功能&#xff0c;助力园区管理降本增效。核心功能模块实时监控…...

Java 25虚拟线程压测全对比:Spring WebFlux vs Virtual Threads vs Project Loom原生方案,谁才是百万QPS终极解?

第一章&#xff1a;Java 25虚拟线程压测全对比&#xff1a;Spring WebFlux vs Virtual Threads vs Project Loom原生方案&#xff0c;谁才是百万QPS终极解&#xff1f;Java 25正式将虚拟线程&#xff08;Virtual Threads&#xff09;从预览特性转为标准特性&#xff0c;标志着J…...

BilibiliDown音频提取指南:从技术侦探视角破解B站无损音质下载难题

BilibiliDown音频提取指南&#xff1a;从技术侦探视角破解B站无损音质下载难题 【免费下载链接】BilibiliDown (GUI-多平台支持) B站 哔哩哔哩 视频下载器。支持稍后再看、收藏夹、UP主视频批量下载|Bilibili Video Downloader &#x1f633; 项目地址: https://gitcode.com/…...

7步效率革命:设计批量处理驱动的智能工作流

7步效率革命&#xff1a;设计批量处理驱动的智能工作流 【免费下载链接】illustrator-scripts Adobe Illustrator scripts 项目地址: https://gitcode.com/gh_mirrors/il/illustrator-scripts 副标题&#xff1a;告别重复劳动的设计自动化方案 在现代设计工作流中&…...

OpenEMS终极指南:三步构建你的智能能源管理系统

OpenEMS终极指南&#xff1a;三步构建你的智能能源管理系统 【免费下载链接】openems OpenEMS - Open Source Energy Management System 项目地址: https://gitcode.com/gh_mirrors/op/openems 还在为高额电费账单发愁吗&#xff1f;是否羡慕别人家的太阳能系统能智能调…...