| 
						
						
							
								
							
						
						
					 | 
					 | 
					@ -45,7 +45,7 @@ fn foo(x: &str) -> String {
 | 
				
			
			
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					以上场景,我们在本章将一一讲解,后面车速较快,请系好安全带。
 | 
					 | 
					 | 
					 | 
					以上场景,我们在本章将一一讲解,后面车速较快,请系好安全带。
 | 
				
			
			
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					
 | 
					 | 
					 | 
					 | 
					
 | 
				
			
			
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					#### 使用`Box<T>`将数据存储在堆上
 | 
					 | 
					 | 
					 | 
					#### 使用`Box<T>`将数据存储在堆上
 | 
				
			
			
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					如果一个变量拥有一个数值`let a = 3`, 那变量`a`必然是存储在栈上的,那如果我们想要`a`的值存储在堆上就需要使用`Boxt<T>`: 
 | 
					 | 
					 | 
					 | 
					如果一个变量拥有一个数值`let a = 3`, 那变量`a`必然是存储在栈上的,那如果我们想要`a`的值存储在堆上就需要使用`Box<T>`: 
 | 
				
			
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					```rust
 | 
					 | 
					 | 
					 | 
					```rust
 | 
				
			
			
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					fn main() {
 | 
					 | 
					 | 
					 | 
					fn main() {
 | 
				
			
			
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					    let a = Box::new(3);
 | 
					 | 
					 | 
					 | 
					    let a = Box::new(3);
 | 
				
			
			
		
	
	
		
		
			
				
					| 
						
							
								
							
						
						
							
								
							
						
						
					 | 
					 | 
					@ -114,7 +114,7 @@ error[E0072]: recursive type `List` has infinite size //递归类型`List`拥有
 | 
				
			
			
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					  |               ---- recursive without indirection
 | 
					 | 
					 | 
					 | 
					  |               ---- recursive without indirection
 | 
				
			
			
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					```
 | 
					 | 
					 | 
					 | 
					```
 | 
				
			
			
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					
 | 
					 | 
					 | 
					 | 
					
 | 
				
			
			
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					此时若想解决这个问题,就可以使用我们的`Boxt<T>`:
 | 
					 | 
					 | 
					 | 
					此时若想解决这个问题,就可以使用我们的`Box<T>`:
 | 
				
			
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					```rust
 | 
					 | 
					 | 
					 | 
					```rust
 | 
				
			
			
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					enum List {
 | 
					 | 
					 | 
					 | 
					enum List {
 | 
				
			
			
		
	
		
		
			
				
					
					 | 
					 | 
					 | 
					    Cons(i32, Box<List>),
 | 
					 | 
					 | 
					 | 
					    Cons(i32, Box<List>),
 | 
				
			
			
		
	
	
		
		
			
				
					| 
						
							
								
							
						
						
						
					 | 
					 | 
					
 
 |