C语言面试

news2025/1/10 15:59:28

数据类型(基本内置类型)

char        //字符数据类型

short        //短整型

int        //整型

long        //长整型

long long        //更长的整型

float        //单精度浮点数

double        //双精度浮点数

类型的基本归类

 整形家族:

char:  unsigned char;  signed char

short: unsigned short [int] ;  signed short [int]

int: unsigned int;  signed int

long:  unsigned long [int];  signed long [int]

浮点数家族:

float   double

构造类型:

数组类型

结构类型:struct

枚举类型:enum

联合类型:union

指针类型:

int *pi;        char *pc;        float* pf;        void* pv;

空类型:

void表示空类型(无类型)

通常应用于函数的返回类型、函数的参数、指针类型

原码、反码、补码

原码

反码:将原码符号位不变,其他位依次按位取反就可以得到反码

补码:反码+1 就得到补码

对于整型来说:数据存放内存中其实存放的是补码(使用补码,可以将符号位和数值域统 一处理;同时,加法和减法也可以统一处理(CPU只有加法器)此外,补码与原码相互转换,其运算过程 是相同的,不需要额外的硬件电路。

大小端 

大端(存储)模式:数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中;

小端(存储)模式:数据的低位保存在内存的低地址中,而数据的高位,保存子啊内存的高地址中。

为什么有大小端模式之分?

为在计算机系统中,我们是以字节为单位的,每个地址单元 都对应着一个字节,一个字节为8 bit。但是在C语言中除了8 bit的char之外,还有16 bit的short 型,32 bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32 位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。因 此就导致了大端存储模式和小端存储模式

变量的命名

  • 只能由字母(包括大写和小写)、数字和下划线(_)组成
  • 不能以数字开头
  • 长度不能超过63个字符
  • 变量名中区分大小写的
  • 变量名不能使用关键字 

常量

  • 字面常量
  • const 修饰的常变量  

1、定义变量为常量,一旦赋值,就不能再修改它的值;

2、修饰函数的参数,可以确保在函数体内不能修改这个参数的值,从而提供了更安全的参数传递。

  • #define 定义的标识符常量
  • 枚举常量 

转义字符

\?        在书写连续多个问号时使用,防止他们被解析成三字母词

\‘           用于表示字符常量'

\“           用于表示一个字符串内部的双引号

\\           用于表示一个反斜杠,防止它被解释为一个转移序列符

\a          警告字符,蜂鸣

\b          退格符

\f           进制符

\n          换行

\r           回车

\t           水平制表符

\v          垂直制表符

\ddd       ddd表示1-3个八进制的数字。如:\130表示字符X

\xdd        dd表示2个十六进制数字。如:\x30表示字符0

常见关键字

 auto  break   case  char  const   continue  default  do   double else  enum   extern float  for   goto  if   int   long  register    return   short  signed sizeof   static struct  switch  typedef(类型重命名) union  unsigned   void  volatile  while

指针变量

我们可以通过&(取地址操作符)取出变量的内存起始地址,把地址可以存放到一个变量中,这个变量就是指针变量。

野指针:指针指向的位置是不可知的(随机的、不正确的、没有明确限制的)

野指针成因:1、指针未初始化 2、指针越界访问 3、指针指向的空间释放

如何规避野指针:指针初始化;小心指针越界;指针指向空间释放,即使置NULL;避免返回局部变量的地址;指针使用之前检查有效性

指针数组 

指针数组是指针还是数组?    是数组。存放指针的数组

&arr 表示的是数组的地址,而不是数组首元素的地址。

字符函数和字符串函数

求字符串长度        strlen

长度不受限制的字符串函数        strcpy  strcat  strcmp

长度受限制的字符串函数介绍        strncpy  strncat  strncmp

char * strncpy ( char * destination, const char * source, size_t num );

拷贝num个字符从源字符串到目标空间。 如果源字符串的长度小于num,则拷贝完源字符串之后,在目标的后边追加0,直到num个。

字符串查找        strstr  strtok

错误信息报告        strerror

字符操作        

内存操作函数        memcpy   memmove   memset   memcmp

P,P++是P是char类型的时候

移动了一个字节

字节对齐int char int占12个字节。如何缩减字节

通过将int设置为short、使用位图去保存、将字节小的类型放在一块。

逻辑操作有哪些?

与、或、异或

动态内存分配

malloc 和 free

malloc和free都声明在 stdlib.h 头文件中。

C语言提供了一个动态内存开辟的函数

void* malloc(size_t size);

  • 如果开辟成功,则返回一个指向开辟好空间的指针。
  • 如果开辟失败,则返回一个NULL指针,因此malloc的返回值一定要做检查。
  • 返回值的类型是 void* ,所以malloc函数并不知道开辟空间的类型,具体在使用的时候使用者自己来决定。
  • 如果参数 size 为0,malloc的行为是标准是未定义的,取决于编译器。

void free(void* ptr);

free函数用来释放动态开辟的内存。

  • 如果参数 ptr 指向的空间不是动态开辟的,那free函数的行为是未定义的。
  • 如果参数 ptr 是NULL指针,则函数什么事都不做。

void* calloc (size_t num, size_t size);

  • 函数的功能是为num个大小为size的元素开辟一块空间,并且把空间的每个字节初始化为0.
  • 与函数malloc区别只在于calloc会在返回地址之前把申请的空间的每个字节初始化为全0

void* realloc(void* ptr, size_t size);

  • ptr是要调整的内存地址
  • size调整之后新大小
  • 返回值为调整之后的内存起始位置
  • 这个函数调整原内存空间大小的基础上,还会将原来内存中的数据移动到新的空间

常见的动态内存错误

  1. 对NULL指针的解引用操作
  2. 对动态开辟空间的越界访问
  3. 对非动态开辟内存使用free释放
  4. 使用free释放一块动态开辟内存的一部分
  5. 对同一块动态内存多次释放
  6. 动态开辟内存忘记释放(内存泄露)

文件的打开和关闭

文件指针

FILE* pf; //文件指针变量

通过文件指针变量能找到与它关联的文件。

文件的打开和关闭

FILE * fopen(const char * filename, const char * mode);

int fclose(FILE * stream);

文件使用方式含义如果指定文件不存在
r(只读)为了输入数据,打开一个已存在的文本本文件出错
w(只写)为了输出数据,打开一个文本文件建立一个新的文件
a(追加)向文本文件尾添加数据建立一个新的文件
rb(只读)为了输入数据,打开一个二进制文件出错
wb(只写)为了输出数据,打开一个二进制文件建立一个新的文件
ab(追加)向一个二进制文件尾添加数据建立一个新的文件
r+(读写)为了读和写,打开一个文本文件出错
w+(读写)为了读和写,建议一个新的文件建立一个新的文件
a+(读写)打开一个文件,在文件尾进行读写建立一个新的文件
rb+(读写)为了读和写打开一个二进制文件出错
wb+(读写)为了读和写,新建一个新的二进制文件建立一个新的文件
ab+(读写)打开一个二进制文件,在文件尾进行读和写建立一个新的文件

文件缓存区 

 

const的作用

1、定义变量为常量,一旦赋值,就不能再修改它的值;

2、修饰函数的参数,可以确保在函数体内不能修改这个参数的值,从而提供了更安全的参数传递。

static的作用

Static修饰变量:按照作用范围的不同,变量分为局部变量全局变量。如果用static修饰变量,不论这个变量是全局的还是局部的都是存储在全局/静态数据区

  • 静态局部变量:使用static修饰符定义的局部变量,即使在声明时为赋初值,编译器也会把它初始化为0。
  • 全局变量:只对当前文件可见,其他文件不可见,其他文件可以定义与其同名的变量,两者互不影响。在定义不需要与其他文件共享的全局变量时,加上static关键字能够有效地降低程序模块之间的耦合,避免不同文件同名变量的冲突,且不会误使用。

static修饰函数:使用方式和全局变量类似,在函数的返回类型前加上static,就是静态函数,特性:

  • 静态函数只能在声明它的文件中可见,其他文件不能引用该函数
  • 不同的文件可以使用相同名字的静态函数,互不影响

#define

1、定义标识符

#define MAX 1000 #define reg register          //为 register这个关键字,创建一个简短的名字 #define do_forever for(;;)     //用更形象的符号来替换一种实现

#define CASE break;case        //在写case语句的时候自动把 break写上。

// 如果定义的 stuff过长,可以分成几行写,除了最后一行外,每行的后面都加一个反斜杠(续行符)。

2、定义宏 

#define 机制包括了一个规定,允许把参数替换到文本中,这种实现通常称为宏(macro)或定义 宏(define macro)。

#define name( parament-list ) stuff

其中的 parament-list 是一个由逗号隔开的符号表,它们可能出现在stuff中。

3、#define替换规则

1. 在调用宏时,首先对参数进行检查,看看是否包含任何由#define定义的符号。如果是,它们首先 被替换。

2. 替换文本随后被插入到程序中原来文本的位置。对于宏,参数名被他们的值所替换。

3. 最后,再次对结果文件进行扫描,看看它是否包含任何由#define定义的符号。如果是,就重复上 述处理过程。

#和##

 1、使用 # ,把一个宏参数变成对应的字符串。

int i = 10;
#define PRINT(FORMAT, VALUE)\
 printf("the value of " #VALUE "is "FORMAT "\n", VALUE);
...
PRINT("%d", i+3);//产生了什么效果?

2、## 的作用

##可以把位于它两边的符号合成一个符号。

它允许宏定义从分离的文本片段创建标识符。

宏和函数

属性#define定义宏函数
代码长度每次使用时,宏代码都会被插入到程序中。除了非常 小的宏之外,程序的长度会大幅度增长函数代码只出现于一个地方;每 次使用这个函数时,都调用那个 地方的同一份代码
执行速度更快存在函数的调用和返回的额外开 销,所以相对慢一些
操作符优先级宏参数的求值是在所有周围表达式的上下文环境里, 除非加上括号,否则邻近操作符的优先级可能会产生 不可预料的后果,所以建议宏在书写的时候多些括 号。函数参数只在函数调用的时候求 值一次,它的结果值传递给函 数。表达式的求值结果更容易预 测。
带有副作用的参数参数可能被替换到宏体中的多个位置,所以带有副作 用的参数求值可能会产生不可预料的结果。函数参数只在传参的时候求值一 次,结果更容易控制。
参数类型宏的参数与类型无关,只要对参数的操作是合法的, 它就可以使用于任何参数类型。函数的参数是与类型有关的,如 果参数的类型不同,就需要不同 的函数,即使他们执行的任务是 相同的。
调试宏是不方便调试的函数是可以逐语句调试的
递归宏是不能递归的函数是可以递归的

栈和堆的区别

:是一种运算受限的线性表,只允许在表的一段,也就是栈顶进行插入和删除操作。栈分为顺序栈和链式栈两种。因为栈是一种线性结构,所以可以使用数组或链表(单向链表、双向链表或循环链表)作为底层数据结构。使用数组实现的栈是顺序栈,使用链表实现的叫链式栈。两者区别是顺序栈中的元素地址连续,链式栈中的怨怒是地址不连续。

:堆是一种常用的树形结构,是一种特殊的完全二叉树,分为大根堆和小根堆。


1、存储内容不同

栈:存放局部变量、函数参数。存放在栈中的数据只在当前函数及下一层函数中有效,一旦函数返回了,这些数据也就自动释放了。

堆:堆中的具体内容可以通过程序员安排

2、分配方式不同

栈:是向低地址扩展的数据结构,是一块连续的内存区域。只要栈的剩余空间大于所申请空间,系统将为程序提供内存,否则将报异常提示栈溢出。

堆:是向高地址扩展的数据结构,是不连续的内存区域。

3、空间大小不同

栈:linux下默认的栈空间大小是8M或10M

堆:堆的大小受限于计算机系统中有效的虚拟内存

进程和线程的区别

进程:操作系统资源分配的最小单元。一个进程拥有的资源有⾃⼰的堆、栈、虚存空间(页表)、文件描述符等信息。

1.PID:进程ID,是进程的唯一身份标识,但是它不是固定不变的,是每次启动进程时动态分配的。

2.进程状态:①新建状态(NEW)  ②就绪状态  ③运行状态  ④阻塞状态  ⑤销毁状态

3.优先级:决定进程的执行顺序

线程:线程是操作系统能够进行运算调度的最小单元。它被包含在进程中,是进程中实际运行的单位。一个进程中可以并发多个线程,每个线程执行不同的任务 。

优势:创建线程比创建进程快;销毁线程比销毁进程更快;带哦都线程比调度进程更快

进程 VS 线程

1、根本区别:进程是操作系统进行资源分配的最小单元。线程是操作系统进行运算调度的最小单元。

2、从属关系:进程中包含了线程,线程属于进程

3、开销不同:进程的创建、销毁和切换的开销都远大于线程

4、拥有资源不同:每个进程都有自己的内存和资源,一个进程中的线程会共享这些内存和资源。

5、控制和影响力:子进程无法影响父进程,而子线程可以影响父线程,如果主线程发生异常,会影响其所在进程和子线程。

6、CPU利用率不同:进程的CPU利用率比较低,因为上下文切换开销较大,而线程的CPU的利用率较高,上下文的切换速度快。

7、操作者不同:进程的操作者一般是操作系统,线程的操作者一般是编程人员。

技术面这次我表现的怎么样,这个岗位招多少人,这样判断你自己的竞争力有多大

大学学习方式

在遇到困难后是如何处理的

从项目入手,对Vue的理解,是否使用过组件库

Vue.js是一个用于创建用户界面的开源JavaScript框架,也是一个创建单页面应用的Web应用框架。Vue在构建用户界面时,能够:编写页面的结构,使用基础CSS美化样式;处理用户和界面之间的交互。

对ajax的理解,js如何实现的回调函数

let,var,const的区别,为什么要使用let

相同点:都可以声明变量

不同:

1、var 存在变量提升,另外两个不存在

2、var定义多次变量时,后面所定义的内容会覆盖前面的,但不会报错。let、const所定义的变量出现多次声明后会报错。

3、var、let声明的变量可以再次赋值,而const声明的变量不能再次赋值

4、var声明的变量没有自身的作用域,而let、const声明的变量由自身的作用域

Vue中父类组件如何向子类组件传递信息

整个后端的数据流转过程

你的项目是如何实现的鉴权

对于java反射的理解,什么时候用过反射

MySQL中索引的好处和坏处,都有哪些索引类型,用过哪些

left join和inner join的区别,如果有A表 100条 B表 10条,A left join B 会有多少条记录

1、返回不同。inner join只返回两个表中联结字段相等的行。left join返回包括左表中的所有记录和右表中联结字段相等的记录

2、数量不同。inner join的数量小于等于左表和右表中的记录数量。left join的数量以左表中的记录数量相同。

3、记录属性不同。inner join:不足的记录属性会被直接舍弃。left join不足的记录属性用NULL填充。

SQL优化常用的几种方法

1、对查询进行优化。尽量避免全表扫描,首先应考虑在where及order by涉及的列上建立索引;

2、尽量避免在where子句中使用 != 或 <> 操作符,否则将引擎放弃使用索引而进行全表扫描

3、尽量避免在where子句中对字段进行null判断,否则将导致引擎放弃使用索引而进行全表扫描,如:select id from t where num is null 可以在num列设置默认值0,然后通过=等号查询:select id from t where num=0

4、应尽量避免在where子句中使用or来连接条件,否则将导致引擎放弃使用索引而进行全表扫描。如:select id from t where num=10 or num=20 此查询可优化为:select id from t where num=10 union all select id from t where num = 20

值传递和引用传递的区别

java中传递数据库对象时是引用传递还是值传递

对hadoop中hive sql和mapreduce的理解,是否使用过

TCP、UDP区别

TCP(Transmission Control Protocol):传输控制协议,是一种面向连接的、可靠的、基于子节流的传输层通信协议

UDP(User Datagram Protocol):用户数据报协议,Internet协议集支持一个无连接的传输协议。UDP为应用程序提供了一种无需建立连接就可以发送封装的IP数据包的方法

区别:

  • TCP面向连接,通过三次握手建立连接,四次挥手解除连接;UDP是无连接的,即发送数据之前不需要建立连接,这种方式为UDP带来了高效的传输效率,但也导致无法确保数据的发送成功。
  • TCP是可靠的通信方式。通过TCP连接传送的数据,TCP通过超时重传、 数据校验等方式来确保数据无差错,不丢失,不重复,且按序到达;而UDP由于无需连接的原因,将会以最大速度进行传输,但不保证可靠交付,也就是会出现丢失、重复等等问题。
  • TCP面向字节流,实际上是TCP把数据看成一连串无结构的字节流,由于连接的问题,当网络出现波动时,连接可能出现响应问题;UDP是面向报文的,UDP没有拥塞控制,因此网络出现拥塞不会使源主机的发送速率降低。
  • 每一条TCP连接只能是点到点的;而UDP不建立连接,所以可以支持一对一,一对多,多对一和多对多的交互通信,也就是可以同时接受多个人的包。
  • TCP需要建立连接,首部开销20字节相比8个字节的UDP显得比较大。
  • TCP的逻辑通信信道是全双工的可靠信道,UDP则是不可靠信道

如何引用一个已经定义过的全局变量

extern

可以引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变量,假设你将那个变量写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错。

冒泡排序的时间复杂度

O(n^2)交换排序(冒泡、快速)_DalaQL的博客-CSDN博客 

堆栈溢出一般是由什么原因导致的

没有回收垃圾资源 

JVM虚拟机详解-CSDN博客

SQL Server是否支持行级锁,有什么好处

支持,设立封锁机制主要是为了对并发操作进行控制,对干扰进行封锁,保证数据的一致性和准确性,行级封锁确保在用户取得被更新的行到该行进行更新这段时间内不被其他用户所修改。因而行级锁即可保证数据的一致性又能提供数据操作的进发性。 

项目中遇到的难点,如何解决的

规划

面向对象的特征,多态原理

什么是虚函数,怎么实现

多态和继承在什么情况下使用

除了多态和继承还有什么面向对象方法

一个对象=另一个对象会发生什么(赋值构造函数) 

如果new之后出了问题直接return。会导致内存泄露,怎么办(智能指针,raii)

多进程fork后不同进程会共享哪些资源

多线程里线程的同步 

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

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

相关文章

redis笔记 三 redis持久化

文章目录 Redis持久化RDB持久化执行时机RDB原理小结 AOF持久化AOF原理AOF配置AOF文件重写 RDB与AOF对比 Redis持久化 redis持久化是为了解决redis宕机时丢失数据的问题&#xff0c;Redis有两种持久化方案&#xff1a; RDB持久化AOF持久化 RDB持久化 RDB全称Redis Database …

避免重复请求:接口重试机制最佳实践

避免重复请求是设计接口重试机制时的重要考量之一。在实际的系统开发中&#xff0c;网络通信、服务调用等操作可能会面临重试的情况&#xff0c;而重试请求如果不加以处理可能导致重复执行业务逻辑、产生重复数据或是对服务端造成压力&#xff0c;因此如何有效避免重复请求成为…

Spring Boot项目中通过 Jasypt 对属性文件中的账号密码进行加密

下面是在Spring Boot项目中对属性文件中的账号密码进行加密的完整步骤&#xff0c;以MySQL的用户名为root&#xff0c;密码为123321为例&#xff1a; 步骤1&#xff1a;引入Jasypt依赖 在项目的pom.xml文件中&#xff0c;添加Jasypt依赖&#xff1a; <dependency><…

easyConnect虚拟网卡未安装,导致连接失败(虚拟网卡安装失败)

前言 使用easyConnect&#xff0c;但是一直连接失败&#xff0c;看到提示错误 虚拟网卡未安装&#xff0c;请确保虚拟网卡安装成功 我的错误原因是因为我自己装过VM虚拟机&#xff0c;用过虚拟网卡然后产生的虚拟网卡冲突 解决方式 1.打开网络设置2.选择你的网络&#xff08…

chatgpt升级啦,训练数据时间更新到2023年4月,支持tools(升级functionCall),128k上下文

&#xff08;2023年11月7日&#xff09; gpt-4-1106-preview https://platform.openai.com/docs/models/gpt-4-and-gpt-4-turbo 训练数据日期升级到2023年四月 上线文增加到128k 调用一次chatgpt接口&#xff0c;可以得到多次函数调用 import OpenAI from "openai"…

1-前端基本知识-HTML

1-前端基本知识-HTML 文章目录 1-前端基本知识-HTML总体概述什么是HTML&#xff1f;超文本标记语言 HTML基础结构文档声明根标签头部元素主体元素注释 HTML概念词汇&#xff1a;标签、属性、文本、元素HTML基本语法规则HTML常见标签标题标签段落标签换行标签列表标签超链接标签…

华为取消6000万订单影响在扩大,高通嘴硬强调不受影响

高通公布了2023年第三季度的业绩&#xff0c;业绩显示营收下滑24%&#xff0c;净利润下滑36%&#xff0c;不过高通强调预计今年四季度业绩将回升&#xff0c;意思是说华为取消订单带来的影响较小。 一、高通处境不利已延续4年时间 2019年美国对华为采取措施&#xff0c;众多中国…

go程序获取工作目录及可执行程序存放目录的方法-linux

简介 工作目录 通常就是指用户启动应用程序时&#xff0c;用户当时所在的文件夹的绝对路径。 如&#xff1a;root用户登录到linux系统后&#xff0c;一顿cd&#xff08;change directory&#xff09;后, 到了/tmp文件夹下。此时&#xff0c;用户要启动某个应用程序&#xff0…

组成原理备考学习 day1 (第一章)

组成原理备考学习 day1 第一章 系统概述1.1 计算机发展史1.1.1 计算机软硬件的发展计算机硬件的发展计算机软件的发展 1.1.2 计算机的分类和发展方向 1.2 计算机系统层次结构1.2.1 计算机系统的组成1.2.2 CPU及工作过程取数指令 1.2.3 I/O设备1.2.4 软件系统计算机编程语言 1.2…

Android Studio新建项目下载依赖慢,只需一个操作解决

新建的安卓工程&#xff0c;下载依赖贼慢怎么办&#xff1f;水一篇吧。 首先新建工程&#xff0c;建好以后项目就自动开始下载了&#xff0c;底部开始出现进度条&#xff0c;但是进度条一直不怎么动&#xff0c;网速也就十几k&#xff0c;要是等他下载得下一天。 直入主题&…

html+css 通过div模拟出一个表格样式,优化多个边框导致的宽度计算问题

htmlcss 通过div模拟出一个表格样式&#xff0c;优化多个边框导致的宽度计算问题 实现代码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, i…

json字符串转为开闭区间

1.需求背景 1.1 前端页面展示 1.2 前后端约定交互json 按照页面每一行的从左到右 * 示例 [{"leftSymbol":">","leftNum":100,"relation":"无","rightSymbol":null,"rightNum":0}, {"left…

【Unity细节】VS不能附加到Unity程序中解决方法大全

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 秩沅 原创 &#x1f636;‍&#x1f32b;️收录于专栏&#xff1a;unity细节和bug &#x1f636;‍&#x1f32b;️优质专栏 ⭐【…

Socks5代理怎么样?安全性高吗?

Socks5代理IP的安全性取决于多个因素&#xff0c;包括代理服务器的信任度、代理提供商的可靠性以及你在使用代理时的需要注意一些动作。 下面分享一些关于Socks5代理IP安全性的重要考虑因素&#xff1a; 1. 代理服务器的信任度&#xff1a;使用代理时&#xff0c;您要确保选择信…

【笔记】原型和原型链(持续完善)

概念 原型&#xff1a;函数都具有 prototype 属性&#xff0c;称之为原型&#xff0c;也称之为原型对象 1.1 原型可以放一些属性和方法&#xff0c;共享给实例对象使用&#xff08;也就是原生方法&#xff09;。 1.2 原型可以做继承原型链&#xff1a;对象都有 __proto__ 属性…

「Verilog学习笔记」多功能数据处理器

专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点&#xff0c;刷题网站用的是牛客网 分析 注意题目要求输入信号为有符号数&#xff0c;另外输出信号可能是输入信号的和&#xff0c;所以需要拓展一位&#xff0c;防止溢出。 timescale 1ns/1ns module data_…

HR人才测评,采用线上测评做春招秋招

从人力资源管理的工作&#xff0c;已经有好些年了&#xff0c;我只想说这不是一个有创意和创造性的工作&#xff0c;因为大部分时间我都在从事数据方面的工作。关于公司内部的文案工作先且不说&#xff0c;这里分享下我做招聘工作的过程。 每年春秋两季的校招&#xff0c;算是…

安防监控EasyCVR视频汇聚平台使用海康SDK播放时,画面播放缓慢该如何解决?

视频云存储/安防监控EasyCVR视频汇聚平台基于云边端智能协同&#xff0c;支持海量视频的轻量化接入与汇聚、转码与处理、全网智能分发、视频集中存储等。安防视频平台EasyCVR拓展性强&#xff0c;视频能力丰富&#xff0c;具体可实现视频监控直播、视频轮播、视频录像、云存储、…

MySQL数据库调优策略

1. 数据库调优的措施 1.1 调优的目标 尽可能节省系统资源&#xff0c;以便系统可以提供更大负荷的服务。&#xff08;吞吐量更大&#xff09; 合理的结构设计和参数调整&#xff0c;以提高用户操作 响应的速度。&#xff08;响应速度更快&#xff09; 减少系统的瓶颈&#xff0…

抽象工厂模式 rust和java的实现

文章目录 抽象工厂模式介绍抽象工厂模式包含以下几个核心角色&#xff1a;实现架构图java实现rust实现rust代码仓库 抽象工厂模式 抽象工厂模式&#xff08;Abstract Factory Pattern&#xff09;是围绕一个超级工厂创建其他工厂。该超级工厂又称为其他工厂的工厂。 在抽象工…