void init_uart() { SCON = 0x50; TMOD = 0x20; TH1 = 0xfd; TL1 = 0xfd; TR1 = 1; EA = 1; ES = 1; } void send_byte(unsigned char dat) { SBUF = dat; while(!TI); TI = 0; } void send_string(char *str) { while(*str != '\0') { send_byte(*str++); } }含义

时间: 2024-04-25 22:26:35 浏览: 8
这段代码是定义了三个函数,分别为: 1. `init_uart()`:初始化串口通信的相关寄存器,包括设置波特率、设置串口工作方式等。 2. `send_byte(unsigned char dat)`:发送一个字节的数据到串口,使用的是SBUF寄存器进行发送。在发送完毕之前,使用while循环等待TI(Transmit Interrupt)标志位被置位,表示数据已经发送完毕。然后将TI标志位清零,以便下一次发送。 3. `send_string(char *str)`:发送一个字符串到串口,使用的是`send_byte`函数。该函数使用了一个指向字符串的指针`str`作为参数,然后在while循环中依次发送字符串中的每个字符,直到遇到字符串结束符'\0'为止。 这三个函数一起实现了在单片机上进行串口通信的功能,可以通过调用`init_uart`函数初始化串口,然后使用`send_string`函数发送字符串到串口,实现与其他设备的通信。
相关问题

#include <reg52.h>#include <stdio.h>#define FREQ 11059200UL#define BAUD_RATE 9600#define TIMER0_RELOAD_VALUE 256 - FREQ / 12 / BAUD_RATEsbit D1 = P1 ^ 0;sbit D2 = P1 ^ 1;sbit D3 = P1 ^ 2;sbit D4 = P1 ^ 3;sbit D5 = P1 ^ 4;sbit D6 = P1 ^ 5;sbit D7 = P1 ^ 6;sbit D8 = P1 ^ 7;void init_timer0();void init_uart();void send_string(char *str);void update_display();volatile unsigned char ms_counter;volatile unsigned char display_buffer[8];volatile char uart_buffer[20];volatile unsigned char uart_buffer_index;void main() { init_timer0(); init_uart(); while (1) { update_display(); }}void init_timer0() { TMOD |= 0x01; TH0 = TIMER0_RELOAD_VALUE; TL0 = TIMER0_RELOAD_VALUE; TR0 = 1; ET0 = 1; EA = 1;}void init_uart() { TMOD |= 0x20; SCON = 0x50; TH1 = 0xfd; TL1 = 0xfd; TR1 = 1; ES = 1;}void send_string(char *str) { while (*str) { SBUF = *str++; while (!TI); TI = 0; }}void update_display() { // TODO: 更新时钟显示内容 // 将时钟内容转换为字符串格式,存储到 uart_buffer 中 // 例如:sprintf(uart_buffer, "%02d:%02d:%02d", hour, minute, second); send_string(uart_buffer);}void timer0_isr() interrupt 1 { TH0 = TIMER0_RELOAD_VALUE; TL0 = TIMER0_RELOAD_VALUE; ms_counter++; if (ms_counter == 10) { ms_counter = 0; update_display(); }}void uart_isr() interrupt 4 { if (RI) { RI = 0; uart_buffer[uart_buffer_index++] = SBUF; if (uart_buffer_index >= sizeof(uart_buffer)) { uart_buffer_index = 0; } }}对上面代码逐句解析

好的,让我逐句解析一下这段代码。 ```c #include <reg52.h> #include <stdio.h> ``` 这两行代码引入了头文件 `reg52.h` 和 `stdio.h`,前者是 8051 系列单片机的头文件,后者是标准 C 语言的输入输出库。 ```c #define FREQ 11059200UL #define BAUD_RATE 9600 #define TIMER0_RELOAD_VALUE 256 - FREQ / 12 / BAUD_RATE ``` 这三行代码定义了一些常量,包括时钟频率、波特率和定时器 0 的重载值。这些常量将在后面的代码中用到。 ```c sbit D1 = P1 ^ 0; sbit D2 = P1 ^ 1; sbit D3 = P1 ^ 2; sbit D4 = P1 ^ 3; sbit D5 = P1 ^ 4; sbit D6 = P1 ^ 5; sbit D7 = P1 ^ 6; sbit D8 = P1 ^ 7; ``` 这八行代码定义了八个数码管的位选端口,即 P1 口的 0 到 7 号位。 ```c void init_timer0(); void init_uart(); void send_string(char *str); void update_display(); ``` 这四行代码声明了四个函数,分别用于初始化定时器 0、初始化串口、发送字符串到串口和更新数码管显示内容。 ```c volatile unsigned char ms_counter; volatile unsigned char display_buffer[8]; volatile char uart_buffer[20]; volatile unsigned char uart_buffer_index; ``` 这四行代码定义了一些全局变量,包括毫秒计数器、数码管显示缓冲区、串口接收缓冲区和串口接收缓冲区索引。 ```c void main() { init_timer0(); init_uart(); while (1) { update_display(); } } ``` 这个 `main()` 函数是程序的入口,首先调用 `init_timer0()` 和 `init_uart()` 函数分别初始化定时器 0 和串口,然后进入一个死循环,在循环中不断调用 `update_display()` 函数更新数码管显示内容。 ```c void init_timer0() { TMOD |= 0x01; TH0 = TIMER0_RELOAD_VALUE; TL0 = TIMER0_RELOAD_VALUE; TR0 = 1; ET0 = 1; EA = 1; } ``` 这个函数用于初始化定时器 0,将其设置为模式 1(16 位定时器),并设置重载值。然后启动定时器 0 并开启定时器 0 中断和总中断。 ```c void init_uart() { TMOD |= 0x20; SCON = 0x50; TH1 = 0xfd; TL1 = 0xfd; TR1 = 1; ES = 1; } ``` 这个函数用于初始化串口,将其设置为模式 1(8 位异步收发),波特率为 9600。然后启动串口并开启串口中断。 ```c void send_string(char *str) { while (*str) { SBUF = *str++; while (!TI); TI = 0; } } ``` 这个函数用于发送字符串到串口,通过循环将字符串中的每个字符发送到 SBUF 寄存器,然后等待 TI 标志位置 1,表示数据已经发送完成,将 TI 标志位清零。 ```c void update_display() { // TODO: 更新时钟显示内容 // 将时钟内容转换为字符串格式,存储到 uart_buffer 中 // 例如:sprintf(uart_buffer, "%02d:%02d:%02d", hour, minute, second); send_string(uart_buffer); } ``` 这个函数用于更新数码管显示内容。在函数中需要更新时钟显示内容,并将时钟内容转换为字符串格式,存储到 `uart_buffer` 中。然后调用 `send_string()` 函数将 `uart_buffer` 中的内容发送到串口。 ```c void timer0_isr() interrupt 1 { TH0 = TIMER0_RELOAD_VALUE; TL0 = TIMER0_RELOAD_VALUE; ms_counter++; if (ms_counter == 10) { ms_counter = 0; update_display(); } } ``` 这个函数是定时器 0 的中断服务程序,每隔一定时间(10 毫秒)触发一次中断。在中断服务程序中需要更新毫秒计数器并调用 `update_display()` 函数更新数码管显示内容。 ```c void uart_isr() interrupt 4 { if (RI) { RI = 0; uart_buffer[uart_buffer_index++] = SBUF; if (uart_buffer_index >= sizeof(uart_buffer)) { uart_buffer_index = 0; } } } ``` 这个函数是串口的中断服务程序,每当接收到一个字符时触发一次中断。在中断服务程序中需要将接收到的字符存储到 `uart_buffer` 中,并根据需要更新 `uart_buffer_index` 变量的值。

#include "public.h" #include "smg.h" #include "ds18b20.h" #include "reg52.h" #include <stdio.h> void init_uart() { SCON = 0x50; TMOD = 0x20; TH1 = 0xfd; TL1 = 0xfd; TR1 = 1; EA = 1; ES = 1; } void send_byte(unsigned char dat) { SBUF = dat; while(!TI); TI = 0; } void send_string(char *str) { while(*str != '\0') { send_byte(*str++); } } void main() { u8 i=0; int temp_value; u8 temp_buf[5]; char str[10]; init_uart(); // ds18b20_init(); // while(1) { i++; if(i%50==0) // temp_value=ds18b20_read_temperture()*10; if(temp_value<0) { temp_value=-temp_value; temp_buf[0]=0x40; } else temp_buf[0]=0x00; temp_buf[0]=gsmg_code[temp_value/1000]; temp_buf[1]=gsmg_code[temp_value%1000/100]; temp_buf[2]=gsmg_code[temp_value%1000%100/10]; temp_buf[3]=0x00; smg_display(temp_buf,1); sprintf(str, "%d\r\n", temp_value/10, temp_value%10); send_string(str); } }请帮我逐行解释代码

好的,我来逐行解释这段代码: ```c #include "public.h" #include "smg.h" #include "ds18b20.h" #include "reg52.h" #include <stdio.h> void init_uart() { SCON = 0x50; // 配置串口为模式1,波特率为9600bps TMOD = 0x20; // 配置定时器1为模式2,8位自动重装载 TH1 = 0xfd; // 定时器1初值为0xfd TL1 = 0xfd; // 定时器1初值为0xfd TR1 = 1; // 启动定时器1 EA = 1; // 开启总中断使能 ES = 1; // 开启串口中断使能 } void send_byte(unsigned char dat) { SBUF = dat; // 将数据存入SBUF寄存器 while(!TI); // 等待数据发送完成 TI = 0; // 清除发送中断标志位 } void send_string(char *str) { while(*str != '\0') { // 判断是否到达字符串末尾 send_byte(*str++); // 逐个发送字符串中的字符 } } void main() { u8 i=0; // 定义并初始化计数器为0 int temp_value; // 定义温度值为整型变量 u8 temp_buf[5]; // 定义存储数码管显示数据的缓冲区 char str[10]; // 定义字符串数组,用于存储温度值字符串 init_uart(); // 初始化串口 ds18b20_init(); // 初始化温度传感器 while(1) { // 无限循环 i++; // 计数器递增 if(i%50==0) { // 每50次循环读取一次温度值 temp_value=ds18b20_read_temperture()*10; // 读取温度值并乘以10 if(temp_value<0) { // 如果温度值为负数 temp_value=-temp_value; // 取绝对值 temp_buf[0]=0x40; // 数码管第一位显示负号 } else { temp_buf[0]=0x00; // 数码管第一位不显示负号 } // 将温度值拆分为千位、百位、十位和个位,并存入缓冲区 temp_buf[1]=gsmg_code[temp_value/1000]; temp_buf[2]=gsmg_code[temp_value%1000/100]; temp_buf[3]=gsmg_code[temp_value%1000%100/10]; temp_buf[4]=gsmg_code[temp_value%1000%100%10]; smg_display(temp_buf,1); // 在数码管上显示温度值 sprintf(str, "%d.%d\r\n", temp_value/10, temp_value%10); // 将温度值转换成字符串 send_string(str); // 发送温度值字符串到串口 } } } ``` 这段代码的功能是读取DS18B20温度传感器的温度值,并将温度值显示在数码管上,并通过串口发送到其他设备。具体解释如下: 首先,代码引入了一些头文件,包括公共头文件public.h、数码管头文件smg.h、DS18B20头文件ds18b20.h,以及reg52.h和stdio.h。其中,reg52.h是Keil C51编译器针对STC89C52单片机所提供的头文件,stdio.h是C语言的标准输入输出头文件。 接下来,代码定义了三个函数:init_uart()、send_byte()和send_string()。其中,init_uart()函数用于初始化串口,包括配置串口为模式1,波特率为9600bps,以及启动定时器1和中断;send_byte()函数用于向串口发送单个字节的数据;send_string()函数用于向串口发送字符串数据。 在main函数中,首先定义了一些变量。i是计数器,用于控制温度读取的频率;temp_value是温度值,以整型表示;temp_buf是存储数码管显示数据的缓冲区,包括数码管第一位的负号和温度值的千位、百位、十位和个位;str是字符串数组,用于存储温度值字符串。 接着,调用了init_uart()函数和ds18b20_init()函数,分别用于初始化串口和DS18B20温度传感器。 最后,代码进入了一个无限循环中。在循环中,i计数器递增,每50次循环读取一次温度值。读取温度值时,先通过ds18b20_read_temperture()函数读取温度值,然后乘以10以增加精度。如果温度值为负数,则将temp_buf[0]设为0x40表示数码管第一位显示负号,否则设为0x00表示数码管第一位不显示负号。接着,将温度值拆分为千位、百位、十位和个位,并存入temp_buf数组中。调用smg_display()函数将温度值显示在数码管上。最后,通过sprintf()函数将温度值转换成字符串,并调用send_string()函数将字符串发送到串口中。

相关推荐

#include <reg52.h> #include <stdio.h> #define LCD1602_RS P2_0 // LCD1602?RS?? #define LCD1602_RW P2_1 // LCD1602?RW?? #define LCD1602_EN P2_2 // LCD1602?EN?? #define LCD1602_DATAPINS P0 // LCD1602????? sbit UART_RXD = P3^0; // ?????? sbit UART_TXD = P3^1; // ?????? void init_uart() // ????? { TMOD |= 0x20; // ?????1???2 TH1 = 0xfd; // ??????9600 TL1 = 0xfd; TR1 = 1; // ?????1 SCON = 0x50; // ???????1 ES = 1; // ?????? EA = 1; // ????? } void init_lcd() // ???LCD { LCD1602_RS = 0; LCD1602_RW = 0; LCD1602_EN = 0; delay_ms(15); lcd_write_cmd(0x38); // ??LCD?16x2????? delay_ms(5); lcd_write_cmd(0x0c); // ??LCD?? delay_ms(5); lcd_clear(); // ?? lcd_write_cmd(0x06); // ???????? } void lcd_write_cmd(unsigned char cmd) // ????LCD { LCD1602_RS = 0; LCD1602_DATAPINS = cmd; LCD1602_EN = 1; delay_us(2); LCD1602_EN = 0; delay_ms(1); } void lcd_write_data(unsigned char dat) // ????LCD { LCD1602_RS = 1; LCD1602_DATAPINS = dat; LCD1602_EN = 1; delay_us(2); LCD1602_EN = 0; delay_ms(1); } void lcd_clear() // ?? { lcd_write_cmd(0x01); } void lcd_set_cursor(unsigned char x, unsigned char y) // ?????? { unsigned char addr; if (y == 0) addr = 0x80 + x; else addr = 0xc0 + x; lcd_write_cmd(addr); } void lcd_puts(unsigned char x, unsigned char y, unsigned char *str) // ?????????? { lcd_set_cursor(x, y); while (*str != '\0') { lcd_write_data(*str); str++; } } void uart_isr() interrupt 4 // ???????? { if (RI) { RI = 0; lcd_write_data(SBUF); // ?????????LCD? } } void main() { init_uart(); init_lcd(); while (1); }

请帮我优化这段代码include <reg52.h> #include <stdio.h> #include <string.h> #define LCD_DATA P0 #define LCD_RS P2_0 #define LCD_RW P2_1 #define LCD_EN P2_2 #define LED_PIN P1_0 #define BUZZER_PIN P1_1 void delay(unsigned int ms); void LCD_init(); void LCD_command(unsigned char cmd); void LCD_data(unsigned char dat); void LCD_string(char *str); void LCD_clear(); void UART_init(); void UART_sendChar(unsigned char ch); void UART_sendString(char *str); unsigned char UART_receiveChar(); void executeCommand(char *command); void main() { char command[20]; UART_init(); LCD_init(); while (1) { if (UART_receiveChar() == ':') { UART_receiveChar(); // Ignore space after ':' fgets(command, sizeof(command), stdin); executeCommand(command); UART_sendString(command); // Send back the received command } } } void delay(unsigned int ms) { unsigned int i, j; for (i = 0; i < ms; i++) for (j = 0; j < 110; j++); } void LCD_init() { LCD_command(0x38); // 2 lines, 5x7 matrix LCD_command(0x0C); // Display on, cursor off LCD_command(0x06); // Increment cursor LCD_command(0x01); // Clear display delay(2); } void LCD_command(unsigned char cmd) { LCD_RS = 0; LCD_RW = 0; LCD_EN = 1; LCD_DATA = cmd; delay(2); LCD_EN = 0; } void LCD_data(unsigned char dat) { LCD_RS = 1; LCD_RW = 0; LCD_EN = 1; LCD_DATA = dat; delay(2); LCD_EN = 0; } void LCD_string(char *str) { while (*str) { LCD_data(*str++); } } void LCD_clear() { LCD_command(0x01); // Clear display delay(2); } void UART_init() { TMOD = 0x20; // Timer1 mode 2: 8-bit auto-reload TH1 = 0xFD; // 9600 baud rate SCON = 0x50; // Serial mode 1: 8-bit data, 1 stop bit, receive enabled TR1 = 1; // Start Timer1 } void UART_sendChar(unsigned char ch) { SBUF = ch; while (TI == 0); // Wait for transmission to complete TI = 0; // Clear transmission flag } void UART_sendString(char *str) { while (*str) { UART_sendChar(*str++); } } unsigned char UART_receiveChar() { while (RI == 0); // Wait for reception to complete RI = 0; // Clear reception flag return SBUF; } void executeCommand(char *command) { if (strncmp(command, "LED on", 6) == 0) { LED_PIN = 1; } else if (strncmp(command, "buzzer on", 9) == 0) { BUZZER_PIN = 1; } else if (strncmp(command, "showstr", 7) == 0) { char *str = command + 8; // Get the string after "showstr" LCD_clear(); LCD_command(0x80); // Move cursor to the beginning of the first line LCD_string(str); } }

#include<reg51.h> #include<intrins.h> #define uchar unsigned char #define uint unsigned int sbit DQ=P3^7; sbit P2_0=P2^0; sbit k2=P2^2; sbit k4=P2^4; sbit k3=P2^3; uchar timp,F=0; float c; uchar a[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x40}; uchar b[]={0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,0x87,0xff,0xef}; void delay5(uchar n) { do { _nop_(); _nop_(); _nop_(); n--; } while(n); } void init_DS18B20() { uchar x=0; DQ=0; delay5(120); DQ=1; delay5(16); delay5(80); } uchar readbyte() { uchar i=0; uchar date=0; for(i=8;i>0;i--) { DQ=0; delay5(1); DQ=1; date>>=1; if(DQ) date|=0x80; delay5(11); } return(date); } void writebyte(uchar dat) { uchar i=0; for(i=8;i>0;i--) { DQ=0; DQ=dat&0x01; delay5(12); DQ=1; dat>>=1; delay5(5); } } uchar retemp() { uchar a,b,tt; uint t; init_DS18B20(); writebyte(0xCC); writebyte(0x44); init_DS18B20(); writebyte(0xCC); writebyte(0xBE); a=readbyte(); b=readbyte(); t=b; t<<=8; t=t|a; if((t&0xf800)!=0xf800) { F=0; c=t*0.0625; tt=t*0.0625; timp=t*0.625-tt*10; } else { F=1; t=(~t)+1; c=t*0.0625; tt=t*0.0625; timp=t*0.625-tt*10; } return tt; } void main() { uchar i,temp; delay5(1000); while(1) { temp=retemp(); if(c>=25&&F==0) P2_0=0; else P2_0=1; for(i=0;i<15;i++) { k2=1;k3=1;k4=1; if(F==0) P0=a[temp/100]; else P0=a[10]; delay5(1000); // P2=0xfb;//11111011,0xfb k2=0;k3=1;k4=1; P0=a[temp%100/10]; delay5(1000); //P2=0xf7;//11110111,0xf7 k2=1;k3=0;k4=1; P0=b[temp%10]; delay5(1000); //P2=0xf3;//11110011,0xf3 k2=0;k3=0;k4=1; P0=a[timp]; delay5(1000); } if(c>=25&&F==0) P2_0=1; else P2_0=1; } }在这个代码的基础上利用串口把数据发送到电脑上的串口助手

最新推荐

recommend-type

基于Python的蓝桥杯竞赛平台的设计与实现

【作品名称】:基于Python的蓝桥杯竞赛平台的设计与实现 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【项目介绍】:基于Python的蓝桥杯竞赛平台的设计与实现
recommend-type

python实现基于深度学习TensorFlow框架的花朵识别项目源码.zip

python实现基于深度学习TensorFlow框架的花朵识别项目源码.zip
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这
recommend-type

导入numpy库,创建两个包含9个随机数的3*3的矩阵,将两个矩阵分别打印出来,计算两个数组的点积并打印出来。(random.randn()、dot()函数)

可以的,以下是代码实现: ```python import numpy as np # 创建两个包含9个随机数的3*3的矩阵 matrix1 = np.random.randn(3, 3) matrix2 = np.random.randn(3, 3) # 打印两个矩阵 print("Matrix 1:\n", matrix1) print("Matrix 2:\n", matrix2) # 计算两个数组的点积并打印出来 dot_product = np.dot(matrix1, matrix2) print("Dot product:\n", dot_product) ``` 希望