Linux内核中常用的C语言技巧

嵌入式ARM 2023-03-21 12:00

Linux内核采用的是GCC编译器,GCC编译器除了支持ANSI C,还支持GNU C。在Linux内核中,许多地方都使用了GNU C语言的扩展特性,如typeof、__attribute__、__aligned、__builtin_等,这些都是GNU C语言的特性。

一、typeof

下面是比较两个数大小返回最大值的经典宏写法:

#define max(a,b) ((a) > (b) ? (a) : (b))

如果a传入i++,b传入j++,那么这个比较大小就会出错。例如:

#define max(a,b) ((a)>(b)?(a):(b))

int x = 1, y = 2;
printf("max=%d\n", max(x++, y++));
printf("x = %d, y = %d\n", x, y);

输出结果:max=3,x=2,y=4。这是错误的结果,正常我们希望的是max(1,2),返回max=2。如何修改这个宏呢?

在GNU C语言中,如果知道a和b的类型,可以在宏里面定义一个变量,将a, b赋值给变量,然后再比较。例如:

#define max(a,b) ({   \
    int _a = (a);   \ 

    int _b = (b);   \
    _a > _b ? _a : _b; }) 

如果不知道具体的数据类型,可以使用typeof类转换宏,Linux内核中的例子:

#define max(a, b) ({        \
    typeof(a) _a = (a);      \
    typeof(b) _b = (b);      \
    (void) (&_a == &_b);   \
    _a > _b ? _a : _b; })

typeof(a) _a = (a):定义一个a类型的变量_a,将a赋值给_a

typeof(b) _b = (b):定义一个b类型的变量_b,将b赋值给_b

(void) (&_a == &_b):判断两个数的类型是否相同,如果不相同,会抛出一个警告。因为a和b的类型不一样,其指针类型也会不一样,两个不一样的指针类型进行比较操作,会抛出一个编译警告。

typeof用法举例:

//typeof的参数可以是表达式或类型

//参数是类型
typeof(int *) a,b;//等价于:int *a,*b;

//参数是表达式
int foo();
typeof(foo()) var;//声明了int类型的var变量,因为表达式foo()是int类型的。由于表达式不会被执行,所以不会调用foo函数。

二、零长数组

零长数组,又叫柔性数组。而它的作用主要就是为了满足需要变长度的结构体,因此有时也习惯性地称为变长数组

用法:在一个结构体的最后, 申明一个长度为0的数组, 就可以使得这个结构体是可变长的

对于编译器来说, 此时长度为0的数组并不占用空间, 因为数组名本身不占空间, 它只是一个偏移量, 数组名这个符号本身代表了一个不可修改的地址常量

结构体中定义零长数组:


struct pcpu_chunk {
    struct list_head  list;
    unsigned long    populated[];  /* 变长数组 */
};

数据结构最后一个元素被定义为零长度数组,不占结构体空间。这样,我们可以根据对象大小动态地分配结构的大小。

struct line {
    int length;
    char contents[0];
};

struct line *thisline = malloc(sizeof(struct line) + this_length);
thisline->length = this_length;

如上例所示,struct line数据结构定义了一个int length变量和一个变长数组contents[0],这个struct line数据结构的大小只包含int类型的大小,不包含contents的大小,也就是**sizeof (struct line) = sizeof (int)**。

创建结构体对象时,可根据实际的需要指定这个可变长数组的长度,并分配相应的空间,如上述实例代码分配了this_length 字节的内存,并且可以通过contents[index]来访问第index个地址的数据。

三、case范围

GNU C语言支持指定一个case的范围作为一个标签,如:

case low ...high:
case 'A' ...'Z':

这里low到high表示一个区间范围,在ASCII字符代码中也非常有用。下面是Linux内核中的代码例子。


    
static int local_atoi(const char *name){
    int val = 0;
    for (;; name++) {
        switch (*name) {
            case '0' ...'9':
                val = 10*val+(*name-'0');
                break;
            default:
                return val;
        }
    }
}

另外,还可以用整形数来表示范围,但是这里需要注意在“...”两边有空格,否则编译会出错。



static int at91sam9261_udc_init(struct at91_udc *udc){
    for (i = 0; i < NUM_ENDPOINTS; i++) {
        ep = &udc->ep[i];
        switch (i) {
            case 0:
                ep->maxpacket = 8;
                break;
            case 1 ... 3:
                ep->maxpacket = 64;
                break;
            case 4 ... 5:
                ep->maxpacket = 256;
                break;
        }
    }
}

四、标号元素

GNU C语言可以通过指定索引或结构体成员名来初始化,不必按照原来的固定顺序进行初始化。

结构体成员的初始化在 Linux 内核中经常使用,如在设备驱动中初始化file_operations数据结构:

char/mem.c>
static const struct file_operations zero_fops = {
    .llseek      = zero_lseek,
    .read        = new_sync_read,
    .write       = write_zero,
    .read_iter     = read_iter_zero,
    .aio_write     = aio_write_zero,
    .mmap        = mmap_zero,
};

如上述代码中的zero_fops的成员llseek初始化为zero_lseek函数,read成员初始化为new_sync_read函数,依次类推。当file_operations数据结构的定义发生变化时,这种初始化方法依然能保证已知元素的正确性,对于未初始化成员的值为0或者NULL

五、可变参数宏

在GNU C语言中,宏可以接受可变数目的参数,主要用在输出函数里。例如:


#define pr_debug(fmt, ...) \
dynamic_pr_debug(fmt, ##__VA_ARGS__)

“...”代表一个可以变化的参数表,“__VA_ARGS__”是编译器保留字段,预处理时把参数传递给宏。当宏的调用展开时,实际参数就传递给dynamic_pr_debug函数了。

六、函数属性

GNU C语言允许声明函数属性(Function Attribute)变量属性(Variable Attribute)类型属性(Type Attribute),以便编译器进行特定方面的优化和更仔细的代码检查。特殊属性语法格式为:

__attribute__ ((attribute-list))

attribute-list的定义有很多,如noreturnformat以及const等。此外,还可以定义一些和处理器体系结构相关的函数属性,如ARM体系结构中可以定义interruptisr等属性。

下面是Linux内核中使用format属性的一个例子。


int libcfs_debug_msg(struct libcfs_debug_msg_data *msgdata,const char *format1, ...)__attribute__ ((format (printf23)));

libcfs_debug_msg()函数里声明了一个format函数属性,它会告诉编译器按照printf的参数表的格式规则对该函数参数进行检查数字2表示第二个参数为格式化字符串,数字3表示参数“...”里的第一个参数在函数参数总数中排在第几个

noreturn属性告诉编译器,该函数从不返回值,这可以消除一些不必要的警告信息。例如以下函数,函数不会返回:

void __attribute__((noreturn)) die(void);

const 属性会让编译器只调用该函数一次,以后再调用时只需要返回第一次结果即可,从而提高效率。

static inline u32 __attribute_const__ read_cpuid_cachetype(void){
    return read_cpuid(CTR_EL0);
}

Linux还有一些其他的函数属性,被定义在compiler-gcc.h文件中。

#define __pure           __attribute__((pure))
#define __aligned(x)        __attribute__((aligned(x)))
#define __printf(a, b)      __attribute__((format(printf, a, b)))
#define __scanf(a, b)       __attribute__((format(scanf, a, b)))
#define noinline          __attribute__((noinline))
#define __attribute_const__   __attribute__((__const__))
#define __maybe_unused      __attribute__((unused))
#define __always_unused      __attribute__((unused))

七、变量属性和类型属性

变量属性可以对变量或结构体成员进行属性设置。类型属性常见的属性有alignmentpackedsections等。

alignment属性规定变量或者结构体成员的最小对齐格式,以字节为单位。

struct qib_user_info {
    __u32 spu_userversion;
    __u64 spu_base_info;
} __aligned(8);

在这个例子中,编译器以8字节对齐的方式来分配qib_user_info这个数据结构。

packed属性可以使变量或者结构体成员使用最小的对齐方式,对变量是以字节对齐,对域是以位对齐

struct test{
 char a;
    int x[2] __attribute__ ((packed));
};

x成员使用了packed属性,它会存储在变量a后面,所以这个结构体一共占用9字节

八、内建函数

内建函数以“_builtin_”作为函数名前缀。下面介绍Linux内核常用的一些内建函数。

__builtin_constant_p(x):判断x是否在编译时就可以被确定为常量。如果x为常量,该函数返回1,否则返回0。

__builtin_expect(exp, c)

#define __swab16(x)        \
(__builtin_constant_p((__u16)(x)) ?  \
___constant_swab16(x) :      \
__fswab16(x))__builtin_expect(exp, c)

__builtin_expect(exp, c):这里的意思是exp==c的概率很大,用来引导GCC编译器进行条件分支预测。开发人员知道最可能执行哪个分支,并将最有可能执行的分支告诉编译器,让编译器优化指令序列,使指令尽可能地顺序执行,从而提高CPU预取指令的正确率

Linux内核中经常见到likely()unlikely()函数,本质也是__builtin_expect()

#define LIKELY(x) __builtin_expect(!!(x), 1) //x很可能为真
#define UNLIKELY(x) __builtin_expect(!!(x), 0) //x很可能为假

__builtin_prefetch(const void *addr, int rw, int locality)主动进行数据预取,在使用地址addr的值之前就把其值加载到cache中,减少读取的延迟,从而提高性能

该函数可以接受3个参数:

  • 第一个参数addr表示要预取数据的地址;
  • 第二个参数rw表示读写属性,1表示可写,0表示只读;
  • 第三个参数locality表示数据在cache中的时间局部性,其中0表示读取完addr的之后不用保留在cache中,而1~3表示时间局部性逐渐增强。如下面的prefetch()prefetchw()函数的实现。

#define prefetch(x) __builtin_prefetch(x)
#define prefetchw(x) __builtin_prefetch(x,1)

下面是使用prefetch()函数进行优化的一个例子。


void __init __free_pages_bootmem(struct page *page, unsigned int order){
    unsigned int nr_pages = 1 << order;
    struct page *p = page;
    unsigned int loop;
    prefetchw(p);
    for (loop = 0; loop < (nr_pages - 1); loop++, p++) {
        prefetchw(p + 1);
        __ClearPageReserved(p);
        set_page_count(p, 0);
    }
    …
}

在处理struct page数据之前,通过prefetchw()预取到cache中,从而提升性能

九、asmlinkage

在标准C语言中,函数的形参在实际传入参数时会涉及参数存放问题。

对于x86架构,函数参数局部变量被一起分配到函数的局部堆栈里。x86中对asmlinkage的定义:

asm/linkage.h>
#define asmlinkage CPP_ASMLINKAGE __attribute__((regparm(0)))

attribute((regparm(0))):告诉编译器该函数不需要通过任何寄存器来传递参数,只通过堆栈来传递

对于ARM来说,函数参数的传递有一套ATPCS标准,即通过寄存器来传递。ARM中的R0~R4寄存器存放传入参数,当参数超过5个时,多余的参数被存放在局部堆栈中。所以,ARM平台没有定义asmlinkage


#define asmlinkage CPP_ASMLINKAGE
#define asmlinkage CPP_ASMLINKAGE

十、UL

在Linux内核代码中,我们经常会看到一些数字的定义使用了UL后缀修饰。

数字常量会被隐形定义为int类型,两个int类型相加的结果可能会发生溢出。

因此使用UL强制把int类型数据转换为unsigned long类型,这是为了保证运算过程不会因为int的位数不同而导致溢出。

  • 1 :表示有符号整型数字1
  • UL:表示无符号长整型数字1

END

来源:嵌入式Linux充电站

版权归原作者所有,如有侵权,请联系删除。

推荐阅读
从STM32转到嵌入式Linux驱动开发
让嵌入式工程师欲罢不能的7个小网站(资源篇)
ChatGPT实现51、STM32、树莓派等各种点灯程序

→点关注,不迷路←

嵌入式ARM 关注这个时代最火的嵌入式ARM,你想知道的都在这里。
评论 (0)
  • 《MATLAB 深度学习简介》电子书
    《MATLAB 深度学习简介》电子书
  • CS5290兼容CS5230防破音AB/D切换,5.2W单声道GF类音频功放IC
    CS5290兼容CS5230防破音AB/D切换,5.2W单声道GF类音频功放IC
  • 信道编码;Turbo码;LDPC码
    介绍了宽带移动通信系统中先进的信道编码技术的软硬件实现,即Turbo码和LDPC码的FPGA实现。书中首先详细介绍了FPGA设计的基础知识,然后讲解信道编码技术中的码的构造、编译码算法和信道编码技术实现相关的软硬件知识
  • 从0写自己的Linux x86操作系统
    分享一套操作系统课程——从0写自己的Linux x86操作系统,附源码+课件+开发工具+参考资料+磁盘映像下载。

    适用人群
    对操作系统内部工作机制感兴趣,想要设计操作系统的大学生、软件开发人员

    课程采用从0行代码编写的方式,教你如何写一个类似于Linux 0.11的x86操作系统,从而深入掌握操作系统的工作原理。

    课程大纲
    第一阶段:引导程序设计
        设计boot程序,接管计算机运行权
        设计loader程序,加载并解析操作系统内核
    第二阶段:多进程管理
        增加中断处理模块,可处理硬件中断和异常
        利用多任务机制,实现系统中多进程的运行
        实现信号量与锁,允许进程之间同步和互斥
    第三阶段:虚拟内存管理
        为系统增加页表,实现进程加载到虚拟地址
        利用分页机制,让进程之间相互隔离,运行互不影响
    第四阶段:tty与文件系统
        增加文件系统模块,可从磁盘上加载程序并执行
        支持标准输入输出文件,允许应用使用printf输出
    第五阶段:命令行shell实现
        实现命令行接口,解析命令行参数并执行
        创建自己的应用程序,并在shell中动态加载并执行
  • C++微服务架构及安全云盘项目实训课程
    分享课程——C++微服务架构及安全云盘项目实训,包含课程配套资料下载。


    本课程从实践中理解软件工程,学习需求分析、架构设计、详细设计文档的编写,学习编程规范,了解多人协作开发策略,理解并引用软件的版本管理,熟悉git工具和软件发布管理流程, bug管理提交问题。
  • 移动端架构师体系课(30周完整版+源码+电子书)
    今天给大家分享一套移动端架构师视频教程,《移动端架构师》一共分为6大阶段,30周,500多课时!提供配套的源码+电子课件(独家)下载!

    课程大纲:
    【0】源码+电子书
    【阶段1:Kotlin x Java打造 UI 通用组件】第1周、走进移动端架构师
    【阶段1:Kotlin x Java打造 UI 通用组件】第2周、通用UI组件开发与基础框架设计
    【阶段1:Kotlin x Java打造 UI 通用组件】第3周、高级UI组件定制与解耦设计
    【阶段1:Kotlin x Java打造 UI 通用组件】第4周、Android必备Kotlin核心技术
    【阶段1:Kotlin x Java打造 UI 通用组件】第5周、Android UI核心组件剖析与实战
    【阶段1:Kotlin x Java打造 UI 通用组件】第6周、Android 导航架构探秘
    【阶段2:解锁Android高阶技能,探秘实战Jetpack】第7周、线程与线程池核心技术
    【阶段2:解锁Android高阶技能,探秘实战Jetpack】第8周、Android网络编程进阶
    【阶段2:解锁Android高阶技能,探秘实战Jetpack】第9周、架构首页模块
    【阶段2:解锁Android高阶技能,探秘实战Jetpack】第9周+、架构首页分类模块
    【阶段2:解锁Android高阶技能,探秘实战Jetpack】第10周、解密Jetpack工具库核心组件
    【阶段2:解锁Android高阶技能,探秘实战Jetpack】第11周、架构商品详情模块
    【阶段2:解锁Android高阶技能,探秘实战Jetpack】第12周、Android消息机制与类加载
    【阶段3:主流架构演进与项目架构改造】第13周、玩转Kotlin x Java 设计模式
    【阶段3:主流架构演进与项目架构改造】第14周、主流架构模式演进之路
    【阶段3:主流架构演进与项目架构改造】第15周、主流架构实战搜索模块
    【阶段3:主流架构演进与项目架构改造】第16周、IOC架构设计
    【阶段3:主流架构演进与项目架构改造】第17周、构建与打包能力
    【阶段4:混合架构设计与开发】第18周、走进Flutter开发
    【阶段4:混合架构设计与开发】第19周、Flutter混合架构原理剖析与应用
    【阶段4:混合架构设计与开发】第20周、Flutter实战应用与性能优化
    【阶段4:混合架构设计与开发】第21周、走进RN开发
    【阶段4:混合架构设计与开发】第22周、RN混合架构原理剖析与应用
    【阶段5:稳定性及性能调优】第23周、稳定性优化
    【阶段5:稳定性及性能调优】第24周、性能优化
    【阶段5:稳定性及性能调优】第25周、开发技能拓展
    【阶段6:前后端接口设计与配置中心系统】第26周、后端-DAU超千万的移动端接口设计实现
    【阶段6:前后端接口设计与配置中心系统】第27周、前端-管理后台设计实现
    【阶段6:前后端接口设计与配置中心系统】第28周、【SDK+服务端+控台】配置中心架构实现
    【阶段6:前后端接口设计与配置中心系统】第29周、HiAbility SDK开发
    【阶段6:前后端接口设计与配置中心系统】第30周、学成“下山”



    移动开发“两极分化”,没有差不多的“中间层”,唯有尽早成长为架构师,你的职业道路才能走的更远更稳!

    架构师两大核心能力:
    1、从0到100构建千万级APP的技术能力
    小型APP逐渐被小程序替代
    移动开发的重心转向
    大型APP开发

    2、驾驭大厂APP架构设计与落地能力
    行业趋于成熟,企业用人倾向于
    具备架构思维与架构设计能力的
    复合型人才


    经历千万级项目全流程,对一个工程师的成长弥足珍贵,但现实中这样的机会凤毛麟角,于是有了咱们这套《移动端架构师》课程

    掌握千万日活APP的架构能力
    · 定制移动端优质解决方案
    · 基础库&框架&模块的技术选型
    · 基础模块&组件设计开发维护

    “技术+管理” 综合发展
    解决项目中关键问题&技术难题
    · 持续优化团队开发流程
    · 提高团队开发能力&效率


    掌握大部分高阶人才必备技术栈
    底层&框架源码深度剖析
    · 多设备多版本兼容适配
    · 主流混合开发框架实践应用
  • 基于ESP32-CAM的人工智能机器人设计资料
    基于ESP32-CAM的人工智能机器人设计资料
  • 晶体管电路设计 铃木雅臣著作
    内涵晶体管基础知识与晶体管放大电路制作。包括OP放大器制作等。
  • 基于python人工智能算法的五官识别设计资料
    基于python人工智能算法的五官识别设计资料
  • 14、谷景科普0510色环电感超声波震荡后出现不良的常见原因分析
    14、谷景科普0510色环电感超声波震荡后出现不良的常见原因分析
  • 中低压配电实用技术.pdf
    中低压配电实用技术.pdf
  • 15、磁环线圈共模电感封装尺寸你知道怎么选吗
    15、磁环线圈共模电感封装尺寸你知道怎么选吗
  • 实用电源电路集锦-开关电源、直流稳压电源、交流稳压电源等

    一、直流稳压电源

    二、可调直流稳压电源

    三、开关电源

    四、交流稳压电源

    五、变换电源

    六、逆变电源

    七、充电电源

    八、应急电源

  • 一、二极管基础 1、   基础知识 2、   各项参数: (1)    结电容       结电容有两种,分别是势垒电容和扩散电容。        势垒电容:PN结两端电压变化,引起积累在中间区域的电荷数量的改变,从而呈现电容效应,这个电容就是势垒电容。 扩散电容:当有外加正向偏压时,在PN结两侧的少子扩散
    HGno1 2023-05-29 22:55 152浏览
  • 射频(RF)电路板设计虽然在理论上还有很多不确定性,但RF电路板设计还是有许多可以遵循的法则。不过,在实际设计时,真正实用的技巧是当这些法则因各种限制而无法实施时,如何对它们进行折衷处理,本文将集中探讨与RF电路板分区设计有关的各种问题。1、微过孔的种类电路板上不同性质的电路必须分隔,但是又要在不产生电磁干扰的最佳情况下连接,这就需要用到微过孔(microvia)。通常微过孔直径为0.05mm~0.20mm,这些过孔一般分为三类,即盲孔(blind via)、埋孔(bury via)和通孔(th
    攻城狮华哥 2023-05-30 11:27 145浏览
  • 据每经AI快讯:国瓷材料以3.98亿元收购赛创电气(铜陵)有限公司 100%股权,赛创电气(铜陵)有限公司更名为国瓷赛创电气(铜陵)有限公司 国瓷材料收购大赛创意电气(铜陵)一事,是中国电子元器件行业的一则重要收购案例。 在这个收购案例中,国瓷材料是一家中国领先的电子陶瓷材料生产商,而创意电气是一家专门从事电子元器件研发和制造的企业,主要产品包括电源芯片、功率晶体管等。此次收购将有助于国瓷材料进一步扩大其在电子元器件领域的业务,并加强其在中国电子元器件行业的市场地位。 从积极的角度来看,这
    斯利通陶瓷电路板 2023-05-29 16:57 219浏览
  • 今日(5月29日),广东省人民政府网站发布,中共广东省委、广东省人民政府关于新时代广东高质量发展的若干意见(以下简称意见)。意见指出,要坚持制造业当家,强化高质量发展的产业根基。《意见》指出,到2027年,全省高质量发展实现新进步,自主创新能力明显提高。到2035年,高质量发展实现更大成效,科技创新能力大幅跃升,城乡区域发展更加协调更加平衡。意见称,广东建设现代化产业集群。着力发展先进制造业,打造梯次型产业格局,争创国家先进制造业集群。推动20个战略性产业集群发展,重点加快发展集成电路、新能源汽
    传感器专家网 2023-05-29 19:54 115浏览
  • [2] 电容器与电容 (1)什么是电容器? 电容器是用于储存电荷的器件,其中包含一对或多对由绝缘体分隔的导体。容器通常由铝、钽或陶瓷等材料制成。各种材料的电容器在系统中使用时具有各自的优缺点,如表 1 所示。陶瓷电容器通常是理想的选择,因为其电容变化最小,而且成本较低。                 (2)  直流电压降额        
    HGno1 2023-05-29 23:42 141浏览
  • [1] 压降 (1)什么是压降? 压降电压 VDO 是指为实现正常稳压,输入电压 VIN 必须高出所需输出电压 VOUT(nom) 的最小压差。 (2)决定压降的因素是什么?                           
    HGno1 2023-05-29 23:34 136浏览
  • MEMS芯片和ASIC芯片是一个MEMS传感器中技术和价值含量最高的部分。你知道MEMS芯片是怎么被制造出来的吗?MEMS芯片与集成电路芯片有什么区别?此外,谈到MEMS传感器,我们还常说ASIC芯片,ASIC芯片是什么?对MEMS传感器有什么作用?MEMS传感器的ASIC芯片相比其他ASIC芯片有什么特别?MEMS传感器的主要构造?MEMS芯片与集成电路芯片有什么区别?MEMS是Micro-Electro-MechanicalSystem的缩写,中文名称是微机电系统,是将微电子电路技术与微机械
    传感器专家网 2023-05-29 20:00 124浏览
  • 网约车行业竞争越来越卷,自动驾驶成为网约车平台重要的发力点,滴滴、T3出行、曹操出行等网约车平台相继对外宣布自动驾驶的计划并提出了“小目标”。滴滴发布两款自动驾驶核心硬件——“北曜Beta”激光雷达和三域融合计算平台“Orca虎鲸”,并宣布首款自动驾驶量产车型计划于2025年接入滴滴共享出行网络。T3出行联手轻舟智航在苏州启动Robtaxi的公开运营,并计划到2026年末,L4自动驾驶车辆商业运营达1000辆。曹操出行与吉利汽车达成战略合作,计划围绕出行平台构建集车内空间开发、定制车、智能驾驶、
    刘旷 2023-05-30 10:51 178浏览
  • 阻抗匹配是指负载阻抗与激励源内部阻抗互相适配,得到最大功率输出的一种工作状态。阻抗匹配是微波电子学的一部分,也是射频电路中非常重要的一部分,主要用于传输线路中,以达到能够将所有高频微波信号传输到负载点的目的。回溯到原点,提高能源效率。阻抗,顾名思义就是对电路中电流起到阻碍作用的元器件。我们在射频电路中,又引入了特征阻抗和等效阻抗两个概念。特征阻抗是射频传输线的一个固有特性,其物理意义是在射频传输线上入射波电压与入射波电流的比值,或者反射波电压和反射波电流的比值。等效阻抗也是传输线理论的一个概念,
    cxtf004 2023-05-30 14:58 132浏览
  • 前言 2022年,全球半导体产业连续高增长,进入调整周期。与此形成对比,在新能源汽车、光伏、储能等需求带动下,第三代半导体产业保持高速发展,全球化供应链体系正在形成,竞争格局逐步确立,产业步入快速成长期。而国内第三代半导体产业经过前期产能部署和产线建设,国产第三代半导体产品相继开发成功并通过验证,技术稳步提升,产能不断释放,国产碳化硅(SiC)器件及模块开始“上机”,生态体系逐渐完善,自主可控能力不断增强,整体竞争实力日益提升。 01 产能释放,第三代半导体产业即将进入”战国
    普赛斯仪表 2023-05-29 17:31 150浏览
  •  近日,财政部会计司发布了《关于公布电子凭证会计数据标准(试行版)的通知》,为做好电子凭证会计数据标准深化试点工作,研究制定了9类电子凭证的会计数据标准。在通知的《电子凭证会计数据标准——全面数字化的电子发票(试行版)》指南中,明确了数电票报销入账归档的具体处理方式。    指南明确: 接收方取得数电票报销入账归档的,应按照《财政部 国家档案局关于规范电子会计凭证报销入账归档的通知》(财会〔2020〕6号,以下称《通知》)和《会计档案管
    科技财经汇 2023-05-29 20:47 166浏览
  • 当谈及现代科技中的传感器射频/微波技术时,陶瓷线路板是不可或缺的重要组成部分。作为这一领域的创新引领者,陶瓷线路板以其卓越的性能和独特的特点,推动着传感器射频/微波技术的革新。本文将为您揭示陶瓷线路板在该领域的重要性,并通过数据展示其卓越的优势。 陶瓷线路板以其材料特性和制造工艺成为传感器射频/微波应用的理想选择。 一、首先,陶瓷材料具有优异的机械强度和耐高温性能,能够承受高功率和极端环境条件下的工作。根据数据显示,陶瓷线路板的机械强度远超过传统的有机基板,可以承受更高的压力和振动,从而
    斯利通陶瓷电路板 2023-05-29 16:58 235浏览
  • 近日,经纬恒润AUTOSAR基础软件产品INTEWORK-EAS-CP成功适配智芯半导体的Z20K14x产品家族。同时,经纬恒润完成了对智芯半导体Z20K14X 产品MCAL软件适配和工程集成,为智芯半导体提供了全套AUTOSAR解决方案。  左图:经纬恒润AUTOSAR EAS CP软件工程配置页面  右图:智芯半导体Z20K14x产品板   通过本次合作,智芯半导体的芯片产品将以功能更加完善、性能更加量化、服务更加完整的状态面向车
    hirain 2023-05-30 11:12 168浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦