Boost程序库完全开发指南:1.2-C++基础知识点梳理

news2024/12/27 2:02:27

  主要整理了N多年前(2010年)学习C++的时候开始总结的知识点,好长时间不写C++代码了,现在LLM量化和推理需要重新学习C++编程,看来出来混迟早要还的。

1.const_cast <new_type> (expression)[1]
解析:const_cast转换符用来移除变量的const或volatile限定符。如下所示:
(1)常量指针被转化成非常量指针,并且仍然指向原来的对象。比如,const A *pca1 = new A; A *pa2 = const_cast<A*>(pca1);
(2)常量引用被转换成非常量引用,并且仍然指向原来的对象。比如,const A &a1 = a0; A a2 = const_cast<A&>(a1);
(3)常量对象被转换成非常量对象(错误)。 比如,const A ca; A a = const_cast<A>(ca);(错误)
(4)添加const属性。比如,const int *k = const_cast<const int*>(j);和const int *m = j;
  说明:使用const_cast去掉const属性,其实并不是真的改变原类类型(或基本类型)的const属性,它只是又提供了一个接口(指针或引用),可以通过这个接口来改变类型的值。使用const_case添加const属性,也是提供了一个接口,来不让修改其值。

2.VS 2013和Boost 1.6.2[2]
解析:
(1)附加包含目录:D:\boost_1_62_0
(2)附加库目录:D:\boost_1_62_0\stage\lib
在VS 2013工程中,添加C/C++工程中外部头文件及库的基本步骤,如下所示:[4]
(1)添加工程的头文件目录:工程 --> 属性 --> 配置属性 --> C/C++ --> 常规 --> 附加包含目录:加上头文件存放目录。
(2)添加文件引用的lib静态库路径:工程 --> 属性 --> 配置属性 --> 链接器 --> 常规 --> 附加库目录:加上lib文件存放目录。
(3)添加工程引用的lib文件名:工程 --> 属性 --> 配置属性 --> 链接器 --> 输入 --> 附加依赖项:加上lib文件名。
(4)添加工程引用的dll动态库:把引用的dll放到工程的可执行文件所在的目录下。
说明:b2.exe、bjam.exe这两个exe的作用是一样的,只不过bjam.exe是老版本,b2是bjam的升级版本。

3.VS 2013和Boost.Python [3][5]
解析:Boost::Python库是Python和C++相互交互的框架,它是对Python/C API的包装,可以在Python中调用C++的类和方法,也可以让C++调用Python的类和方法。Python是一个动态类型的语言,C++是一个静态类型的语言,对于Python中的变量类型,Boost.Python都有相应的类对应。
(1)编译Boost.Python
执行命令bjam --with-python link=shared runtime-link=shared address-model=64,在目录D:\boost_1_62_0\stage\lib下面生成boost_python-vc120-mt-1_62.dll,boost_python-vc120-mt-1_62.lib,boost_python-vc120-mt-gd-1_62.dll,boost_python-vc120-mt-gd-1_62.lib四个文件。如果报错fatal error C1001:编译器中发生内部错误,那么将VS 2013升级到VS 2013 Update 5。[7]
(2)使用VS 2013生成dll文件
使用VS 2013新建一个Win32 DLL项目,然后设置项目属性:包含目录D:\boost_1_62_0,D:\boost_1_62_0\libs,D:\Program Files\Anaconda2\include,库目录D:\boost_1_62_0\stage\lib,D:\Program Files\Anaconda2\libs,并且不启用最小重新生成,不使用预编译头。
(3)Python调用C++
将生成的dll文件改为pyd文件,并将boost_python-vc120-mt-gd-1_62.dll和pyd文件复制到Python项目的根目录。[8][9]
  说明:通过Boost.Python模块(也是对Python/C API的封装),C++可为Python编写扩展模块。通过Python/C API,Python可为C++提供脚本接口。[10]

4.chrono、ratio和ctime等头文件 [6]
解析:
(1)#include :日期和时间。
(2)#include :日期和时间。
(3)#include :比例关系。
(4)#include :运行时类型信息(RTTI)。

5.两种遍历host_vector方式
解析:
(1)常规方式

for (int i = 0; i < h_vec.size(); i++) {
	cout << h_vec[i] << endl;
}

(2)迭代器方式

for (host_vector<int>::iterator i = h_vec.begin(); i != h_vec.end(); i++)
{
	cout << *i << endl;
}

6.volatile关键字
解析:volatile关键字确保本条指令不会因编译器的优化而省略,而且要求每次直接读值。

7.extern “C”
解析:extern "C"的主要作用是为了能够正确实现C++代码调用其它C语言代码。加上extern "C"后,会指示编译器这部分代码按C语言的进行编译,而不是C++的。由于C++支持函数重载,因此编译器编译函数的过程中会将函数的参数类型也加到编译后的代码中,而不仅仅是函数名;而C语言并不支持函数重载,因此编译C语言代码的函数时不会带上函数的参数类型,一般只包括函数名。

8.C++ 11中auto功能[11]
解析:自动类型推断;返回值占位。

9.assert宏
解析:assert()是宏,而不是函数。在C的#include<assert.h>头文件中,其作用是如果它的条件返回错误,则终止程序执行。如下所示:

#include <stdio.h>      
#include <assert.h>     
 
void print_number(int* myInt) {
	assert(myInt != NULL);
	printf("%d\n", *myInt);
}
 
int main()
{
	int a = 10;
	int * b = NULL;
	int * c = NULL;
 
	b = &a;
 
	print_number(b);
	print_number(c);
 
	return 0;
}

10.inline关键字
解析:关键字inline必须与函数定义体放在一起才能使函数成为内联函数,仅将inline放在函数声明前面不起任何作用。不宜使用内联函数,如下所示:
(1)如果函数体内的代码比较长,使用内联将导致内存消耗代价较高。
(2)如果函数体内出现循环,那么执行函数体内代码的时间要比函数调用的开销大。

11.exit()函数
解析:exit(1)是异常退出,exit(0)是正常退出。

12.C++三法则
解析:如果类定义下列其中一个函数,那么也需要其它两个函数,如下所示:
(1)析构函数(Destructor)
(2)复制构造函数(copy constructor)
(3)复制赋值运算符(copy assignment operator)

13.POD类型
解析:POD是Plain Old Data的缩写,它是一个struct或者类,且不包含构造函数、析构函数以及虚函数。

14.虚函数,纯虚函数,虚基类与虚继承
解析:
(1)虚函数:定义一个函数为虚函数,不代表函数为不被实现的函数。定义它为虚函数是为了允许用基类的指针来调用子类的这个函数。
(2)纯虚函数:定义一个函数为纯虚函数,才代表函数没有被实现。定义纯虚函数是为了实现一个接口,起到一个规范的作用,规范继承这个类的程序员必须实现这个函数。

15.std::shared_ptr
解析:std::shared_ptr定义于头文件 中,template< class T > class shared_ptr; std::shared_ptr是通过指针保持某个对象的共享拥有权的智能指针。若干个shared_ptr对象可以拥有同一个对象;最后一个指向该对象的shared_ptr被销毁或重置时,该对象被销毁。销毁该对象时使用的是delete表达式或者是在构造shared_ptr时传入的自定义删除器(deleter)。shared_ptr也可以不拥有对象,称作空(empty)。shared_ptr满足CopyConstructible和CopyAssignable的要求。

16.explicit specifier
解析:在大部分情况中,隐式转换却容易导致错误(不是语法错误,编译器不会报错)。通过将构造函数声明为explicit(显式)的方式可以抑制隐式转换,也就是explicit构造函数必须显式调用。如下所示:

struct A {
    A ( int ) {}
    operator int() const { return 0; }
};
 
struct B {
    explicit B(int) {}
    explicit operator int() const { return 0; }
};
 
int main() {
    // A is has no explicit ctor / conversion, everything is fine
    A a1 = 1;
    A a2 ( 2 );
    A a3 { 3 };
    int na1 = a1;
    int na2 = static_cast<int>( a1 );
 
    B b1 = 1; // Error: implicit conversion from int to B
    B b2 ( 2 ); // OK: explicit constructor call
    B b3 { 3 }; // OK: explicit constructor call
    int nb1 = b2; // Error: implicit conversion from B to int
    int nb2 = static_cast<int>( b2 ); // OK: explicit cast
}

说明:explicit class_name ( params );explicit operator type () (C++11起)。

17.boost::mutex
解析:Boost线程库提供了6种互斥体类型:boost::mutex;boost::try_mutex;boost::timed_mutex;boost::recursive_mutex;boost::recursive_try_mutex;boost::recursive_timed_mutex。boost库中提供了mutex类与lock类,通过组合可以轻易的构建读写锁与互斥锁。如下所示:
(1)mutex对象类:mutex类主要有两种:boost::mutex,boost::shared_mutex,其中mutex有lock和unlock方法,shared_mutex除了提供lock和unlock方法外,还有shared_lock和shared_unlock方法。因此,boost::mutex为独占互斥类,boost::shared_mutex为共享互斥类。
(2)lock模板类:boost::unique_lock,boost::shared_lock,其中unique_lock为独占锁,shared_lock为共享锁。unique_lock中的T可为mutex类中的任意一种,如果为shared_mutex,那么boost::unique_lock类的对象构造函数构造时,会自动调用shared_mutex的shared_lock方法,析构函数里会自动调用shared_mutex的shared_unlock方法。如果boost:: unique_lock,则分别自动调用lock和unlock方法。boost::shared_lock中的T只能是shared_mutex类。

18.NMake Makefiles与MinGW Makefiles区别
解析:-G “MinGW Makefiles"这个参数的意思是生成MinGW的Makefile,最终生成的编译目标(Makefile)是针对MinGW编译器的。如果编译器是VS,那么使用"NMake Makefiles”。

19.Boost并发编程[12]
解析:
(1)Interprocess (IPC)库:用于实现共享内存、内存映射的 I/O 和消息队列;
(2)Thread库:用于实现可移植的多线程;
(3)Message Passing Interface (MPI):库用于分布式计算中的消息传递;
(4)Asio库:用于使用套接字和其它低层功能实现可移植的连网功能。

20.CMake常用命令
解析:
(1)set(Foo a b c):设置变量Foo。
(2)add_exectuable:告诉工程生成一个可执行文件。
(3)add_library:告诉工程生成一个库文件。
(4)include_directories:头文件路径。
(5)link_directories:库文件路径。
(6)find_package(XXX):调用FindXXX.cmake模块。
(7)add_definitions:添加编译参数。
(8)target_link_libraries:添加链接库。
(9)CMAKE_BUILD_TYPE:SET(CMAKE_BUILD_TYPE Debug|Release)。
(10)编译器参数:CMAKE_C_FLAGS;CMAKE_CXX_FLAGS。
(11)_FOUND:如果找到了name,被设置为1,否则不设置。
(12)_INCLUDE_DIRS:被设置成name安装头文件和依赖头文件的目录。
(13)_LIBRARIES:被设置成所建立和安装的name库的文件名。
(14)_LIBRARY_DIRS:被设置成name库的第三方依赖文件所在的目录。
(15)_VERSION:所找到的name的版本。
(16)_COMPONENTS:列出所有可用组件。
(17)_DEFINITIONS:列出所需要的预处理器定义和编译器标志。
(18)获得一个目录下所有源文件(不包含头文件):aux_source_directory(<dir> <variable>)。
(19)设定依赖的cmake版本:cmake_minimum_required(VERSION 2.6)。
(20)${projectname_SOURCE_DIR}:表示根源文件目录。
(21)${projectname _BINARY_DIR}:表示根二进制文件目录。
(22)打印make输出:make VERBOSE=1。
(23)add_compile_options:添加的编译选项是针对所有编译器的。
(24)executable_output_path:指定可执行文件存放的路径。
(25)library_output_path:指定库文件存放的路径。
(26)cmake_current_source_dir:指的是当前处理的CMakeLists.txt所在的路径。
(27)cmake_current_binary_dir:如果是out-of-source编译,指的是target编译目录。
(28)cmake_current_list_file:输出调用这个变量的CMakeLists.txt完整路径。
(29)cmake_current_list_line:输出这个变量所在的行。
(30)cmake_module_path:定义cmake模块所在的路径。
(31)cmake调用环境变量:使用$ENV{NAME}指令调用系统环境变量。
(32)UNIX:在所有的类UNIX平台为TRUE,包括OS X和cygwin。
(33)WIN32:在所有的win32平台为TRUE,包括cygwin。
(34)build_shared_libs:控制默认的库编译方式。

21.#include
解析:io代表输入输出,manip是manipulator[操纵器]的缩写。它是I/O流控制头文件,就像C里面的格式化输出一样。

22.#define WIN32_LEAN_AND_MEAN
解析:包含<windows.h>时去除一些头文件的包含,加快编译速度。

23.#define NOMINMAX
解析:为了禁用Visual C++中的min/max宏定义,可以在包含<windows.h>头文件之前加上#define NOMINMAX。

24.标准库bitset对象上的操作
解析:
[1]b.any():b中是否存在置为1的二进制位。
[2]b.none():b中不存在置为1的二进制位。
[3]b.count():b中置为1的二进制位的个数。
[4]b.size():b中二进制位的个数。
[5]b[pos]:访问b中在pos处的二进制位。
[6]b.test(pos):b中在pos处的二进制位是否为1。
[7]b.set():把b中所有二进制位都置为1。
[8]b.set(pos):把b中在pos处的二进制位置为1。
[9]b.reset():把b中所有二进制位都置为0。
[10]b.reset(pos):把b中在pos处的二进制位置为0。
[11]b.flip():把b中所有二进制位逐位取反。
[12]b.flip(pos):把b中在pos处的二进制位取反。
[13]b.to_ulong:把b中同样的二进制位返回一个unsigned long值。
[14]os << b:把b中的位集输出到os流。

25.GCC参数
解析:

[1]static:编译静态库。 
[2]shared:编译动态库。  
[3]w:不生成任何警告信息。       
[4]Wall:生成所有警告信息。   
[5]-l [小写l]指定要链接的库。  
[6]-I [大写i]指定头文件目录。  
[7]-L [大写l]指定库目录。  

26.Binutils
解析:GNU Binutils [Binary Utilities],即GNU二进制工具集。

27.itoa函数[#include <stdlib.h>]
解析:函数原型char *itoa( int value, char *string, int radix);(把一个整数转换为字符串),如下所示:
[1]value:欲转换的数据。
[2]string:目标字符串的地址。
[3]radix:转换后的进制数,比如16进制等。
  相关函数,如下所示:
[1]char *ultoa(unsigned long value, char *string, int radix) :将无符号整型数value转换成字符串并返回该字符串。
[2]char *ltoa(long value, char *string, int radix) :将长整型数value转换成字符串并返回该字符串。
[3]char *itoa(int value, char *string, int radix):将整数value转换成字串存入string,radix为转换时所用基数。
[4]double atof(char *nptr) :将字符串nptr转换成双精度数,并返回这个数,错误返回0。  
[5]int atoi(char *nptr) :将字符串nptr转换成整型数,并返回这个数,错误返回0。
[6]long atol(char *nptr) :将字符串nptr转换成长整型数,并返回这个数,错误返回0。  
[7]double strtod(char *str, char **endptr) :将字符串str转换成双精度数,并返回这个数。
[8]long strtol(char *str, char **endptr, int base) :将字符串str转换成长整型数,并返回这个数。

28.Tcl/Tk脚本语言
解析:Tcl是"工具控制语言[Tool Control Language]"的缩写。Tk是Tcl"图形工具箱"的扩展,它提供各种标准的GUI接口项,以利于迅速进行高级应用程序开发。

29.LLVM
解析:LLVM是构架编译器[compiler]的框架系统,以C++编写而成,用于优化以任意程序语言编写的程序的编译时间[compile-time]、链接时间[link-time]、运行时间[run-time]以及空闲时间[idle-time],对开发者保持开放,并兼容已有脚本。

30.CC编译器
解析:在Linux下,cc通常是一个符号连接,指向gcc。

31.CMake安装
解析:
[1]sudo apt-get install cmake
[2]sudo apt-get install cmake-qt-gui
[3]使用命令cmake-gui在终端打开界面

32.静态成员函数
解析:静态成员函数没有this指针,只能访问静态成员数据、其它静态成员函数和类外部的其它函数。

33.C++继承类型
解析:
[1]公有继承[public]:当一个类派生自公有基类时,基类的公有成员也是派生类的公有成员,基类的保护成员也是派生类的保护成员,基类的私有成员不能直接被派生类访问,但是可以通过调用基类的公有和保护成员来访问。
[2]保护继承[protected]: 当一个类派生自保护基类时,基类的公有和保护成员将成为派生类的保护成员。
[3]私有继承[private]:当一个类派生自私有基类时,基类的公有和保护成员将成为派生类的私有成员。

34.可重载运算符
解析:
[1]双目算术运算符:+ (加),-(减),(乘),/(除),% (取模)
[2]关系运算符:==(等于),!= (不等于),< (小于),> (大于>,<=(小于等于),>=(大于等于)
[3]逻辑运算符:||(逻辑或),&&(逻辑与),!(逻辑非)
[4]单目运算符:+ (正),-(负),
(指针),&(取地址)
[5]自增自减运算符:++(自增),–(自减)
[6]位运算符:| (按位或),& (按位与),~(按位取反),^(按位异或),,<< (左移),>>(右移)
[7]赋值运算符:=, +=, -=, *=, /= , % = , &=, |=, ^=, <<=, >>=
[8]空间申请与释放:new, delete, new[] , delete[]
[9]其它运算符:()(函数调用),->(成员访问),,(逗号),

35.不可重载运算符
解析:
[1].:成员访问运算符
[2].和->:成员指针访问运算符
[3]:::域运算符
[4]sizeof:长度运算符
[5]?::条件运算符
[6]#:预处理符号
说明:运算重载符不可以改变语法结构,不可以改变操作数的个数,不可以改变优先级,不可以改变结合性。

36.虚函数
解析:虚函数是在基类中使用关键字virtual声明的函数。在派生类中重新定义基类中定义的虚函数时,会告诉编译器不要静态链接到该函数。在程序中任意点可以根据所调用的对象类型来选择调用的函数,这种操作被称为动态链接,或后期绑定。

37.纯虚函数
解析:virtual int area() = 0;其中,=0告诉编译器,函数没有主体,上面的虚函数是纯虚函数。

38.使用CLion进行Boost编程
解析:
[1]./booststrap.sh
[2]sudo ./b2 install
说明:编译好的头文件位于/usr/local/include/boost,库路径位于/usr/local/lib。

39.ADD_EXECUTABLE(CRNode ${SRC_LIST})
解析:定义了这个工程会生成一个文件名为CRNode的可执行文件,相关的源文件是SRC_LIST中定义的源文件列表。需要注意的是,这里的CRNode和之前的项目名称没有任何关系,可以任意定义。

40.TARGET_LINK_LIBRARIES(CRNode log4cpp thrift)
解析:在指定链接目标文件的时候需要链接的外部库,其效果类似gcc的编译参数-l,可以解决外部库的依赖问题。

41.C类库
解析:

[1]<cassert> (assert.h):C Diagnostics Library (header)
[2]<cctype> (ctype.h):Character handling functions (header)
[3]<cerrno> (errno.h):C Errors (header)
[4]<cfenv> (fenv.h):Floating-point environment (header)
[5]<cfloat> (float.h):Characteristics of floating-point types (header)
[6]<cinttypes> (inttypes.h):C integer types (header)
[7]<ciso646> (iso646.h):ISO 646 Alternative operator spellings (header)
[8]<climits> (limits.h):Sizes of integral types (header)
[9]<clocale> (locale.h):C localization library (header)
[10]<cmath> (math.h):C numerics library (header)
[11]<csetjmp> (setjmp.h):Non local jumps (header)
[12]<csignal> (signal.h):C library to handle signals (header)
[13]<cstdarg> (stdarg.h):Variable arguments handling (header)
[14]<cstdbool> (stdbool.h):Boolean type (header)
[15]<cstddef> (stddef.h):C Standard definitions (header)
[16]<cstdint> (stdint.h):Integer types (header)
[17]<cstdio> (stdio.h):C library to perform Input/Output operations (header)
[18]<cstdlib> (stdlib.h):C Standard General Utilities Library (header)
[19]<cstring> (string.h):C Strings (header)
[20]<ctgmath> (tgmath.h):Type-generic math (header)
[21]<ctime> (time.h):C Time Library (header)
[22]<cuchar> (uchar.h):Unicode characters (header)
[23]<cwchar> (wchar.h):Wide characters (header)
[24]<cwctype> (wctype.h):Wide character type (header)

42.C++容器类库
解析:

[1]<array>:Array header (header)
[2]<bitset>:Bitset header (header)
[3]<deque>:Deque header (header)
[4]<forward_list>:Forward list (header)
[5]<list>:List header (header)
[6]<map>:Map header (header)
[7]<queue>:Queue header (header)
[8]<set>:Set header (header)
[9]<stack>:Stack header (header)
[10]<unordered_map>:Unordered map header (header)
[11]<unordered_set>:Unordered set header (header)
[12]<vector>:Vector header (header)

43.C++输入/输出流类库
解析:

44.Atomics and threading library
解析:

[1]<atomic>:Atomic (header)
[2]<condition_variable>:Condition variable (header)
[3]<future>:Future (header)
[4]<mutex>:Mutex (header)
[5]<thread>:Thread (header)

45.Miscellaneous headers
解析:

[1]<algorithm>:Standard Template Library: Algorithms (library )
[2]<chrono>:Time library (header)
[3]<codecvt>:Unicode conversion facets (header)
[4]<complex>:Complex numbers library (header)
[5]<exception>:Standard exceptions (header)
[6]<functional>:Function objects (header)
[7]<initializer_list>:Initializer list (header)
[8]<iterator>:Iterator definitions (header)
[9]<limits>:Numeric limits (header)
[10]<locale>:Localization library (header)
[11]<memory>:Memory elements (header)
[12]<new>:Dynamic memory (header)
[13]<numeric>:Generalized numeric operations (header)
[14]<random>:Random (header)
[15]<ratio>:Ratio header (header)
[16]<regex>:Regular Expressions (header)
[17]<stdexcept>:Exception classes (header)
[18]<string>:Strings (header)
[19]<system_error>:System errors (header)
[20]<tuple>:Tuple library (header)
[21]<typeindex>:Type index (header)
[22]<typeinfo>:Type information (header)
[23]<type_traits>:type_traits (header)
[24]<utility>:Utility components (header)
[25]<valarray>:Library for arrays of numeric values (header)

46.malloc,free,calloc,realloc用法
解析:
[1]void* malloc(size_t size);:该函数与类型无关,向内存申请一块连续可用的空间,并返回指向这块空间的指针。
[2]void free (void *ptr);:指针指向申请出来的起始地址。
[3]void *calloc (size_t num,size_t size);:用来动态分配内存。
[4]void realloc(void ptr,size_t size );:对动态开辟内存大小的调整。

47.chrono库
解析:chrono库主要包含了三种类型:时间间隔Duration、时钟Clocks和时间点Timepoint。

48.C++ auto原理
解析:auto的原理就是根据后面的值,来自己推测前面的类型是什么。

49.MinGW
解析:MinGW是让Windows用户可以用上GNU工具。

50.Cygwin
解析:Cygwin提供完整的类Unix环境。

参考文献:
[1]C++类型转换详解const_cast:http://blog.csdn.net/lwbeyond/article/details/6213382
[2]在VS2013中安装配置boost_1_58_0库:http://blog.csdn.net/a249900679/article/details/50961852
[3]Boost.Python初级教程:http://blog.csdn.net/lainegates/article/details/8008414
[4]VC包含目录、附加依赖项、库目录及具体设置:http://www.cnblogs.com/MuyouSome/p/3380134.html
[5]Boost.Python:http://www.boost.org/doc/libs/1_62_0/libs/python/doc/html/index.html
[6]C++的chrono、ratio和ctime等头文件:http://lib.csdn.net/article/operatingsystem/19036
[7]Boost安装出错,遇到“编译器中发生内部错误”的解决方法:http://blog.csdn.net/alpine_climbing/article/details/52621528
[8]VS2013 + Python + Boost.Python实现Python调用C++方法:http://evanstone.blog.51cto.com/9615170/1583366
[9]基于VS2015 X64的Boost.Python环境搭建:http://m.blog.csdn.net/article/details?id=52014741
[10]Python/C API Reference Manual:https://docs.python.org/2.7/c-api/index.html
[11]C++11新特性auto的使用:http://blog.csdn.net/huang_xw/article/details/8760403
[12]使用Boost库进行并发编程:http://www.ibm.com/developerworks/cn/aix/library/au-concurrent_boost/
[13] #define NOMINMAX:http://blog.163.com/fleeting_ash/blog/static/663410862009310113424930/
[14] 编译器cc、gcc、g++、CC的区别:https://www.cnblogs.com/52php/p/5681725.html

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

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

相关文章

分布式架构篇

1、微服务 微服务架构风格&#xff0c;就像是把一个单独的应用程序开发为一套小服务&#xff0c;每个服务运行在自己的进程中&#xff0c;并使用轻量级机制通信&#xff0c;通常是 HTTP API。这些服务围绕业务能力来构建&#xff0c;并通过完全自动化部署机制来独立部署。这些…

一文拿捏Spring事务之、ACID、隔离级别、失效场景

1.&#x1f31f;Spring事务 1.编程式事务 事务管理代码嵌入嵌入到业务代码中&#xff0c;来控制事务的提交和回滚&#xff0c;例如TransactionManager 2.声明式事务 使用aop对方法前后进行拦截&#xff0c;然后在目标方法开始之前创建或者加入一个事务&#xff0c;执行完目…

AutoCAD2014第一章 快速入门

AutoCAD的基本功能 AutoCAD具有功能强大、易于掌握、使用方便和体系结构开放等特点&#xff0c;能够绘制平面图形与三维图形、标注图形尺寸、渲染图形以及打印输出图纸&#xff0c;深受广大工程技术人员的欢迎。 AutoCAD所包含的基本功能有图形的绘制与编辑功能、尺寸标注功能…

[架构之路-229]:计算机体硬件与系结构 - 计算机系统的矩阵知识体系结构

目录 一、纵向&#xff1a;目标系统的分层结构 1.1 目标系统的架构 1.2 网络协议栈 1.3 计算机程序语言分层 二、横向&#xff08;构建目标系统的时间、开发阶段&#xff09;&#xff1a;软件工程 三、二维矩阵知识体系结构 一、纵向&#xff1a;目标系统的分层结构 1.1…

mysql双主双从读写分离

架构图&#xff1a; 详细内容参考&#xff1a; 结果展示&#xff1a; 178.119.30.16&#xff08;从&#xff09;- master 178.119.30.17&#xff08;从&#xff09;- slave 由上述结果可以看出&#xff0c;产生了主备节点同时抢占VIP的问题&#xff08;即脑裂问题&#xff09…

Python无废话-办公自动化Excel格式美化

设置字体 在使用openpyxl 处理excel 设置格式&#xff0c;需要导入Font类&#xff0c;设置Font初始化参数&#xff0c;常见参数如下&#xff1a; 关键字参数 数据类型 描述 name 字符串 字体名称&#xff0c;如Calibri或Times New Roman size 整型 大小点数 bold …

Ae 效果:CC Page Turn

扭曲/CC Page Turn Distort/CC Page Turn CC Page Turn &#xff08;CC 翻页&#xff09;主要用于模拟书页翻动的效果。通过使用该效果&#xff0c;用户可以创建出像书页或杂志页面翻动的视觉效果&#xff0c;增强影片的交互性和视觉吸引力。 ◆ ◆ ◆ 效果属性说明 Contro…

3D孪生场景搭建:参数化模型

1、什么是参数化模型 参数化模型是指通过一组参数来定义其形状和特征的数学模型或几何模型。这些参数可以用于控制模型的大小、形状、比例、位置、旋转、曲率等属性&#xff0c;从而实现对模型进行灵活的调整和变形。 在计算机图形学和三维建模领域&#xff0c;常见的参数化模…

获取医疗器械板块的个股列表

获取医疗器械板块的个股列表&#xff0c;用python爬虫做到&#xff08;数据网址&#xff1a;板块 - 医疗器械概念 - 股票行情中心 - 搜狐证券&#xff09; import requests from bs4 import BeautifulSoup # 获取医疗器械概念个股列表url "https://q.stock.sohu.com/cn/…

​苹果应用高版本出现:“无法安装此app,因为无法验证其完整性”是怎么回事?竟然是错误的?

最近经常有同学私聊我问苹果应用签名后用落地页下载出现高版本是什么意思&#xff1f;我一脸懵&#xff01;还有这个操作&#xff1f;高版本是个啥玩意&#xff01;所以我就上了一下科技去搜索引擎搜索了下&#xff0c;哈哈哈&#xff0c;然后了解下来发现是这样的首先我们确定…

《Secure Analytics-Federated Learning and Secure Aggregation》论文阅读

背景 机器学习模型对数据的分析具有很大的优势&#xff0c;很多敏感数据分布在用户各自的终端。若大规模收集用户的敏感数据具有泄露的风险。 对于安全分析的一般背景就是认为有n方有敏感数据&#xff0c;并且不愿意分享他们的数据&#xff0c;但可以分享聚合计算后的结果。 联…

Go语言面经进阶10问

1.Golang可变参数 函数方法的参数&#xff0c;可以是任意多个&#xff0c;这种我们称之为可以变参数&#xff0c;比如我们常用的fmt.Println()这类函数&#xff0c;可以接收一个可变的参数。可以变参数&#xff0c;可以是任意多个。我们自己也可以定义可以变参数&#xff0c;可…

【Leetcode】二分查找合集

二分查找合集 二分模板leetcode 704.二分查找题目思路代码 Leetcode 34.在排序数组中查找元素的第⼀个和最后⼀个位置题目思路代码 35. 搜索插入位置题目思路代码 69.X的平方根题目思路代码 852. 山脉数组的峰顶索引题目代码 162.寻找峰值题目思路代码 153. 寻找旋转排序数组中…

CUDA C编程权威指南:1-基于CUDA的异构并行计算

什么是CUDA&#xff1f;CUDA&#xff08;Compute Unified Device Architecture,统一计算设备架构&#xff09;是NVIDIA&#xff08;英伟达&#xff09;提出的并行计算架构&#xff0c;结合了CPU和GPU的优点&#xff0c;主要用来处理密集型及并行计算。什么是异构计算&#xff1…

基于阶梯碳交易的含P2G-CCS耦合和燃气掺氢的虚拟电厂优化调度(matlab代码)

目录 1 主要内容 系统结构图 P2G-CCS 耦合模型 其他算例对比 2 部分代码 3 下载链接 1 主要内容 该程序复现《基于阶梯碳交易的含P2G-CCS耦合和燃气掺氢的虚拟电厂优化调度》模型&#xff0c;以碳交易和碳封存成本、燃煤机组启停和煤耗成本、弃风成本、购气成本之和为目标…

嵌入式系统中C++内存管理基本方法

引言 说到 C 的内存管理&#xff0c;我们可能会想到栈空间的本地变量、堆上通过 new 动态分配的变量以及全局命名空间的变量等&#xff0c;这些变量的分配位置都是由系统来控制管理的&#xff0c;而调用者只需要考虑变量的生命周期相关内容即可&#xff0c;而无需关心变量的具…

如何在 Windows 上安装 ONLYOFFICE 协作空间社区版

ONLYOFFICE 协作空间是一个在线协作平台&#xff0c;帮助您更好地与客户、业务合作伙伴、承包商及第三方进行文档协作。今天我们来介绍一下&#xff0c;如何在 Windows 上安装协作空间的自托管版。 ONLYOFFICE 协作空间主要功能 使用 ONLYOFFICE 协作空间&#xff0c;您可以&a…

【彩色图像处理GUI】各种颜色映射、重新调整大小和更改分辨率、伽玛校正,对比度,反转颜色(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

【洛谷 P1216】[USACO1.5] [IOI1994]数字三角形 Number Triangles 题解(动态规划)

[USACO1.5] [IOI1994]数字三角形 Number Triangles 题目描述 观察下面的数字金字塔。 写一个程序来查找从最高点到底部任意处结束的路径&#xff0c;使路径经过数字的和最大。每一步可以走到左下方的点也可以到达右下方的点。 在上面的样例中&#xff0c;从 7 → 3 → 8 →…

Linux系统编程系列之POSIX信号量

一、什么是POSIX信号量 POSIX信号量是一种用于线程之间同步和互斥的机制&#xff0c;它是由POSIX标准定义的一种IPC&#xff08;进程间通信&#xff09;机制&#xff0c;可以用于进程间或线程间的同步操作。POSIX信号量分成两种&#xff0c;POSIX匿名信号量和POSIX具体信号量。…