1. 程式人生 > >C++中的typename關鍵字

C++中的typename關鍵字

在C++中typename除了用於在定義模板函式和模板類中來替代關鍵字class,例如template<class T>換成template<typename T>意外,typename還可以用來做型別的定義。

注意:下面的程式碼是有問題的

template<typename C>
void print2nd(const C& container)
{
	if(container.size()>=2)
	{
		C::const_iterator iter(container.begin());
		++iter;
		in value=*iter;
		std::cout<<value;
	}
}
如上述程式碼所示,template內出現的名稱如果相依於某個template引數,稱之為從屬名稱。如果從屬名稱在class內呈巢狀裝,我們稱它為巢狀從屬名稱,如C s,即用template內出現的名稱定義了一個物件。C::const_iterator就是這樣一個名稱,因此在用這樣的巢狀從屬名稱時,需要用typename來說明這個C::const_iterator是一個型別,而不是一個變數。如果不是巢狀從屬型別,就不能用typename來進行說明,如前面說的C s,就不需要進行typename的說明。

例外情況:typename不可以出現在base classes list內的巢狀從屬型別名稱之前,也不可以出現在成員初始化列表中作為base class修飾符。如下面程式所示:

template<typename T>
class Derived:public Base<T>::Nested//base class list中不允許使用typename
{
public:
	explicit Derived(int x):Base<T>::Nested(x)//成員函式列表中不允許使用typename巢狀從屬型別名稱
	{
		typename Base<T>::Nested temp;//其他地方,巢狀從屬型別名稱必須加上typename
	}
}


相關推薦

C++typename關鍵字的使用方法和注意事項

目錄起因近日,看到這樣一行程式碼:typedef typename __type_traits<T>::has_trivial_destructor trivial_destructor; 雖說已經有多年C++經驗,但上面這短短一行程式碼卻看得我頭皮發麻。看起來它

C/C++extern關鍵字詳解

編譯器 fin 生成 接口 bcd 只需要 c++環境 結束 編程 轉自:http://www.cnblogs.com/yc_sunniwell/archive/2010/07/14/1777431.html 1 基本解釋:extern可以置於變量或者函數前,以標示變量或者

C++typename和class的區別

type .get true 能夠 class .... ray pla 依賴 在c++Template中很多地方都用到了typename與class這兩個關鍵字,而且好像可以替換,是不是這兩個關鍵字完全一樣呢? 相信學習C++的人對class這個關鍵字都非常明白,clas

c#params關鍵字應用

語言 bsp for arr als new 傳參數 lin long c#params應用 params 是C#開發語言中關鍵字, params主要的用處是在給函數傳參數的時候用,就是當函數的參數不固定的時候。 在方法聲明中的 params 關鍵字之後不允許任何其他參數,

C/C++const關鍵字的用法及其與宏定義的比較

類型安全 屬性 const關鍵字 code oid 程序 函數返回值 存儲空間 臨時對象 1.const關鍵字的性質 簡單來說:const關鍵字修飾的變量具有常屬性。 即它所修飾的變量不能被修改。 2.修飾局部變量 1 const int a = 10; 2 int co

C++static關鍵字作用總結

可見性 apple 局部變量 內存 父類靜態 初始化 ati 退出 變量存儲 1.先來介紹它的第一條也是最重要的一條:隱藏。(static函數,static變量均可) 當同時編譯多個文件時,所有未加static前綴的全局變量和函數都具有全局可見性。舉例來說明。同時編譯兩個源

淺析C++static關鍵字

參數 extern 函數 iostream 出現 har 兩個 什麽 註意事項 C++的static有兩種用法:面向過程程序設計中的static和面向對象程序設計中的static。前者應用於普通變量和函數,不涉及類;後者主要說明static在類中的作用。 一、面向過程設計中

c++extern關鍵字和static的作用域的學習

之前對static修飾變數後作用域的問題一直是大體瞭解,感覺和普通變數的作用域並沒有什麼區別。聚個栗子 在A.h中: #pragma once static int a=365; class A { public: A(); ~A(); }; 在main.c中: #include

C/C++volatile關鍵字詳解

asm 運行 多線程並發 這樣的 修改 由於 設定 其他 硬件 1. 為什麽用volatile? C/C++ 中的 volatile 關鍵字和 const 對應,用來修飾變量,通常用於建立語言級別的 memory barrier。這是 BS 在 "The C++ P

C/C++ static關鍵字

C 語言的 static 關鍵字有三種(具體來說是兩種)用途: 1. 靜態區域性變數:用於函式體內部修飾變數,這種變數的生存期長於該函式。 int foo(){ static int i = 1; // note:1 //int i = 1

C++static關鍵字的作用

static的作用主要有兩個方面: 限定作用域; 保持變數內容持久化。 static關鍵字在C++中的用法: 只在cpp內有效的全域性變數: 在cpp檔案的全域性範圍內宣告:   static int val = 0; 這個變數的含義是該cpp內有效,

C++const關鍵字詳解

const關鍵字作用    1. 修飾變數        用法:const 型別說明符 變數名。        含義:說明該變數不可以被改變。        用途:常量命名等    2. 修飾

C++const關鍵字修飾

C++中const使用的地方非常多,修飾包括:全域性變數、函式、函式引數等等,這篇文章主要是總結一下const各種使用的規則以及需要注意事項。 const名叫常量限定符,用來限定特定變數,以通知編譯器該變數是不可修改的。習慣性的使用const,可以避免在函式中對某些不應

C++static關鍵字作用

@著作權歸作者所有:來自CSDN部落格作者大鬍子的艾娃的原創作品,如需轉載,請註明出處,否則將追究法律責任。 如有錯誤的地方歡迎指正,謝謝! 一、 static宣告全域性靜態變數和區域性靜態變數 1、static宣告全域性靜態變數 該全域性變數只能供本模組使用,

C++const關鍵字增強

.c檔案 #include<stdio.h> const int m_a = 10; //全域性作用域的const不能使用指標進行修改 int main() { const int m_b = 10; int *p = (int *)&m_b; *p =

C++explicit關鍵字的作用

explicit用來防止由建構函式定義的隱式轉換。   要明白它的作用,首先要了解隱式轉換:可以用單個實參來呼叫的建構函式定義了從形參型別到該類型別的一個隱式轉換。 例如:  

CC#static關鍵字的作用

1. static 變數  靜態變數的型別說明符是static。靜態變數當然是屬於靜態儲存方式,但是屬於靜態儲存方式的量不一定就是靜態變數。例如外部變數雖屬於靜態儲存方式,但不一定是靜態變數,必須由static加以定義後才能成為靜態外部變數,或稱靜態全域性變數。2. 靜態區域性變數  靜態區域性變數屬於靜態儲

C++auto關鍵字的使用及編譯錯誤解決

auto可以自動幫我們推斷變數的型別 比如在定義一些難以確定的變數型別時  35     func_log(__func__, "");  36     // vector<Student>::iterator it = St

C#this關鍵字的使用

 this的兩個作用: 1、代表當前類的物件; 2、在類當中顯示的呼叫本類的建構函式 例如以下兩個建構函式中:  public Students(string name,char gender,i

c#volatile關鍵字的作用(zz)

恐怕比較一下volatile和synchronized的不同是最容易解釋清楚的。volatile是變 量修飾符,而synchronized則作用於一段程式碼或方法;看如下三句get程式碼: int i1;              int geti1() {return